对象池2(方法功能)Pools
对象池Pools(主要调用方法功能)
namespace kernal
{
public class Pools : MonoBehaviour
{
[HideInInspector]
public Transform ThisGameObjectPosition; //本类挂载游戏对象位置
public List<PoolOption> PoolOptionArrayLib = new List<PoolOption>();
//“单模缓冲池”集合容器
public bool IsUsedTime = false; //是否用“时间戳”
void Awake()
{
PoolManager.Add(this); //加入“多模复合池”管理器
ThisGameObjectPosition = transform;
//预加载
PreLoadGameObject();
}
void Start()
{
//开始时间戳处理
if (IsUsedTime)
{
InvokeRepeating("ProcessGameObject_NameTime", 1F, 10F);
}
}
// 时间戳处理:每间隔10秒种,对所有正在使用的活动状态游戏对象的时间戳减去10秒,活动状态的游戏对象名称的时间戳如果小于等于0,则进入禁用状态,重新进入活动状态的游戏对象,获得预先设定的存活时间写入对象名称的时间戳中。(时间的判断根据命名来判断)
void ProcessGameObject_NameTime()
{
//循环体为定义的“种类”数量
for (int i = 0; i < PoolOptionArrayLib.Count; i++)
{
PoolOption opt = this.PoolOptionArrayLib[i];
//所有正在使用的活动状态游戏对象的时间戳减去10秒,检查每个活动状态的游戏对象名称的时间戳如果小于等于0,则进入禁用状态
opt.AllActiveGameObjectTimeSubtraction();
}
}
public void PreLoadGameObject() //预加载
{
for (int i = 0; i < this.PoolOptionArrayLib.Count; i++)
{ //“多模”集合
PoolOption opt = this.PoolOptionArrayLib[i]; //“单模”集合
for (int j = opt.totalCount; j < opt.IntPreLoadNumber; j++)
{
GameObject obj = opt.PreLoad(opt.Prefab, Vector3.zero, Quaternion.identity);
//所有预加载的游戏对象规定为Pool类所挂游戏对象的子对象。
obj.transform.parent = ThisGameObjectPosition;
}
}
}
// 得到游戏对象,从缓冲池中(“多模”集合) 功能描述: 对指定“预设”在自己的缓冲池中激活一个,且加入自己缓冲池中的"可用激活池",然后再建立一个池对象,且激活预设,再加入自己的缓冲池中的“可用激活池”中。
public GameObject GetGameObjectByPool(GameObject prefab, Vector3 pos, Quaternion rot)
{
GameObject obj = null;
//循环体为定义的“种类”数量
for (int i = 0; i < PoolOptionArrayLib.Count; i++)
{
PoolOption opt = this.PoolOptionArrayLib[i];
if (opt.Prefab == prefab)
{
//激活指定“预设”
obj = opt.Active(pos, rot);
if (obj == null) return null;
//所有激活的游戏对象必须是本类所挂空对象的子对象。
if (obj.transform.parent != ThisGameObjectPosition)
{
obj.transform.parent = ThisGameObjectPosition;
}
}
}
return obj;
}
// 收回游戏对象(“多模”集合)
public void RecoverGameObjectToPools(GameObject instance)
{
for (int i = 0; i < this.PoolOptionArrayLib.Count; i++)
{
PoolOption opt = this.PoolOptionArrayLib[i];
//检查自己的每一类“池”中是否包含指定的“预设”对象。
if (opt.ActiveGameObjectArray.Contains(instance))
{
if (instance.transform.parent != ThisGameObjectPosition)
instance.transform.parent = ThisGameObjectPosition;
//特定“池”回收这个指定的对象。
opt.Deactive(instance);
}
}
}
// 销毁无用的对象(“多模”集合)
public void DestoryUnused()
{
for (int i = 0; i < this.PoolOptionArrayLib.Count; i++)
{
PoolOption opt = this.PoolOptionArrayLib[i];
opt.ClearUpUnused();
}
}
// 销毁指定数量的游戏对象
public void DestoryPrefabCount(GameObject prefab, int count)
{
for (int i = 0; i < this.PoolOptionArrayLib.Count; i++)
{
PoolOption opt = this.PoolOptionArrayLib[i];
if (opt.Prefab == prefab)
{
opt.DestoryCount(count);
return;
}
}
}
// 当本脚本所挂载的游戏对象销毁时候,清空所有集合内全部数据
public void OnDestroy()
{
//停止时间戳的检查
if (IsUsedTime)
{
CancelInvoke("ProcessGameObject_NameTime");
}
for (int i = 0; i < this.PoolOptionArrayLib.Count; i++)
{
PoolOption opt = this.PoolOptionArrayLib[i];
opt.ClearAllArray();
}
}
}
}
注:这段对象池代码是对象池的调用实现功能的人方法,主要调用基础的实现方式,加载、显示、隐藏、时间控制等返回给上层调用的地方。
对象池2(方法功能)Pools的更多相关文章
- unity游戏开发_对象池
现在假设游戏中我们需要实现一个这样功能,按下鼠标左键,发射一颗子弹,3秒之后消失.在这个功能中,我们发射了上百上千发子弹,就需要实例化生成上百上千次.这时候,我们就需要使用对象池这个概念,每次实例化生 ...
- 通用对象池ObjectPool的一种简易设计和实现方案
对象池,最简单直接的作用当然是通过池来减少创建和销毁对象次数,实现对象的缓存和复用.我们熟知的线程池.数据库连接池.TCP连接池等等都是非常典型的对象池. 一个基本的简易对象池的主要功能实现我认为应该 ...
- Java对象池技术的原理及其实现
看到一片有关于java 对象基础知识,故转载一下,同时学习一下. 摘 要 本文在分析对象池技术基本原理的基础上,给出了对象池技术的两种实现方式.还指出了使用对象池技术时所应注意的问题. 关键词 对象池 ...
- 抓到 Netty 一个隐藏很深的内存泄露 Bug | 详解 Recycler 对象池的精妙设计与实现
欢迎关注公众号:bin的技术小屋,如果大家在看文章的时候发现图片加载不了,可以到公众号查看原文 本系列Netty源码解析文章基于 4.1.56.Final版本 最近在 Review Netty 代码的 ...
- 屏幕坐标和世界坐标的转换+对象池技术(3D打地鼠小游戏)
游戏中可能经常会遇到需要某个物体跟着鼠标移动,然后又需要把物体放在某个鼠标指定的位置 实现方式 Camera.main.WorldToScreenPoint Camera.main.ScreenToW ...
- 对象池3(方法功能)PoolManager(控制)PoolTimeObject(时间管理)text01(调用)Destorys(销毁)
1.对象池PoolManager namespace kernal { public class PoolManager : MonoBehaviour { //“缓冲池”集合 public stat ...
- 对象池1(方法功能)PoolOption
2.对象池PoolOption(方法功能) //单类型缓冲对象管理(单模池操作管理)功能: 激活.收回.预加载等. namespace kernal { [System.Serializable] p ...
- 常量池与方法区以及又读new String对象创建问题
又拿出这道String str1 = new String("abc");创建几个对象的面试题梳理了一下常量池与方法区的关系,希望能把这两者的关系通过这道面试题说明白 方法区是什么 ...
- Spring实战(十)Spring AOP应用——为方法引入新功能、为对象引入新方法
切面最基本的元素是通知和切点,切点用于准确定位应该在什么地方应用切面的通知. 1.Spring借助AspectJ的切点表达式语言来定义Spring切面 在Spring中,要使用AspectJ的切点表达 ...
随机推荐
- 数据结构_wow(泡泡的饭碗)
问题描述 饱了吗终于发现泡泡破解了它的代码并借此白吃白喝.饱了吗当即改变了自己的幸运儿生成源码,但是,又被机智的泡泡偷瞄到了,机智的泡泡马上意识到可能要饭碗不保了:每当有人参与抽奖,这个人就进入队列. ...
- 多线程学习-基础( 十)一个synchronized(){/*代码块*/}简单案例分析
一.提出疑惑 上一篇文章中,分析了synchronized关键字的用法.但是好像遗漏了一种情况. 那就是: synchronized(obj){/*同步块代码*/} 一般有以下几种情况: (1)syn ...
- appium自动化安装(一)
1.首先去 https://github.com/ 了解一下appium一些相关信息 2.安装node.js:node.js官方网站:https://nodejs.org/ 安装完成,打开Wind ...
- 【Arcgis for android】spatialite打开shapefile
互联网(free and share) 本文参考下面的博文: http://blog.csdn.net/arcgis_all/article/details/8232976 Preparation: ...
- SQL的发展史
在20世纪60年代,网状数据库系统(如CODASYL)和分层数据库系统(如IMS TM)是用于自动化银行业务.记帐和订单处理系统的一流技术,这些系统是由于商业大型计算机的引入才启用的.而SQL是在70 ...
- Unity UGUI 原理篇(二):Canvas Scaler 縮放核心
https://blog.csdn.net/gz_huangzl/article/details/52484611 Canvas Scaler Canvas Scaler是Unity UI系統中,控制 ...
- 第一次接触C++------感触
2018/09/24 上大学第一次接触C++,感觉还挺有趣的. C语言是计算机的一门语言,顾名思义,语言嘛,有它自己独特的语法. 第一次用C++敲代码,觉得还挺不错的,可以从中找到乐趣.咏梅老师布置的 ...
- [SinGuLaRiTy] (树形)数据结构题目复习
[SinGuLaRiTy-1023] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. 普通平衡树 题目描述 你需要写一种数据结构(可参考题目标 ...
- php 伪造HTTP_REFERER页面URL来源的三种方法
php获取当前页面的前一个页面URL地址,即当前页面是从哪个页面链接过来的,可以使用$_SERVER['HTTP_REFERER']; 但是$_SERVER['HTTP_REFERER']也是可以被伪 ...
- 六度分离 (folyd算法)
1967年,美国著名的社会学家斯坦利·米尔格兰姆提出了一个名为"小世界现象(small world phenomenon)"的著名假说,大意是说,任何2个素不相识的人中间最多只隔着 ...