对象池1(方法功能)PoolOption
2.对象池PoolOption(方法功能)
//单类型缓冲对象管理(单模池操作管理)功能: 激活、收回、预加载等。
namespace kernal
{
[System.Serializable]
public class PoolOption
{
public GameObject Prefab; //存储的“预设”
public int IntPreLoadNumber = 0; //初始缓冲数量
public int IntAutoDeactiveGameObjectByTime = 30; //按时间自动禁用游戏对象
[HideInInspector]
//活动使用的游戏对象集合
public List<GameObject> ActiveGameObjectArray = new List<GameObject>();
[HideInInspector]
//非活动状态(禁用)的游戏对象集合
public List<GameObject> InactiveGameObjectArray = new List<GameObject>();
private int _Index = 0;
// 预加载
internal GameObject PreLoad(GameObject prefab, Vector3 positon, Quaternion rotation)
{
GameObject obj = null;
if (prefab)
{
obj = Object.Instantiate(prefab, positon, rotation) as GameObject;
Rename(obj);
obj.SetActive(false); //设置非活动状态
//加入到“非活动游戏对象”集合中。
InactiveGameObjectArray.Add(obj);
}
return obj;
}
// 激活游戏对象
internal GameObject Active(Vector3 pos, Quaternion rot)
{
GameObject obj;
if (InactiveGameObjectArray.Count != 0)
{
//从“非活动游戏集合”容器中取出下标为0的游戏对象
obj = InactiveGameObjectArray[0];
//从“非活动游戏集合”容器中移除下标为0的游戏对象
InactiveGameObjectArray.RemoveAt(0);
}
else
{
//“池”中没有多余的对象,则产生新的对象
obj = Object.Instantiate(Prefab, pos, rot) as GameObject;
//新的对象进行名称“格式化”处理
Rename(obj);
}
//对象的方位处理
obj.transform.position = pos;
obj.transform.rotation = rot;
//新对象正式加入“活动池”容器中。
ActiveGameObjectArray.Add(obj);
obj.SetActive(true);
return obj;
}
// 禁用游戏对象
internal void Deactive(GameObject obj)
{
ActiveGameObjectArray.Remove(obj);
InactiveGameObjectArray.Add(obj);
obj.SetActive(false);
}
// 统计两个“池”中所有对象的数量
internal int totalCount
{
get
{
int count = 0;
count += this.ActiveGameObjectArray.Count;
count += this.InactiveGameObjectArray.Count;
return count;
}
}
// 全部清空集合(两个“池”)
internal void ClearAllArray()
{
ActiveGameObjectArray.Clear();
InactiveGameObjectArray.Clear();
}
// 彻底删除所有“非活动”集合容器中的游戏对象。
internal void ClearUpUnused()
{
foreach (GameObject obj in InactiveGameObjectArray)
{
Object.Destroy(obj);
}
InactiveGameObjectArray.Clear();
}
// 游戏对象重命名,对新产生的游戏对象做统一格式处理,目的是做“时间戳”处理。
private void Rename(GameObject instance)
{
instance.name += (_Index + 1).ToString("#000");
//游戏对象(自动禁用)时间戳 [Adding]
instance.name = IntAutoDeactiveGameObjectByTime + "@" + instance.name;
_Index++;
}
// 删除“非活动”容器集合中的一部分指定数量数据
internal void DestoryCount(int count)
{
if (count > InactiveGameObjectArray.Count)
{
ClearUpUnused();
return;
}
for (int i = InactiveGameObjectArray.Count - 1; i >= InactiveGameObjectArray.Count - count; i--)
{
Object.Destroy(InactiveGameObjectArray[i]);
}
InactiveGameObjectArray.RemoveRange(InactiveGameObjectArray.Count - count, count);
}
// 回调函数、时间管理、所有游戏对象进行时间倒计时管理,时间小于零则进行“非活动”容器集合中,即:按时间自动回收游戏对象。
internal void AllActiveGameObjectTimeSubtraction()
{
for (int i = 0; i < ActiveGameObjectArray.Count; i++)
{
string strHead = null;
string strTail = null;
int intTimeInfo = 0;
GameObject goActiveObj = null;
goActiveObj = ActiveGameObjectArray[i];
//得到每个对象的时间戳
string[] strArray = goActiveObj.name.Split('@');
strHead = strArray[0];
strTail = strArray[1];
//时间戳-10 处理
intTimeInfo = System.Convert. (strHead);
if (intTimeInfo >= 10)
{
strHead = (intTimeInfo - 10).ToString();
}
else if (intTimeInfo <= 0)
{
//游戏对象自动转入禁用
goActiveObj.name = IntAutoDeactiveGameObjectByTime.ToString() + "@" + strTail;
this.Deactive(goActiveObj);
continue;
}
//时间戳重新生成
goActiveObj.name = strHead + '@' + strTail;
}
}
}
注:这段对象池代码是对象池的功能方法,基础的实现方式,加载、显示、隐藏、时间控制等
对象池1(方法功能)PoolOption的更多相关文章
- 通用对象池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 ...
- 对象池2(方法功能)Pools
对象池Pools(主要调用方法功能) namespace kernal { public class Pools : MonoBehaviour { [HideInInspector] public ...
- 常量池与方法区以及又读new String对象创建问题
又拿出这道String str1 = new String("abc");创建几个对象的面试题梳理了一下常量池与方法区的关系,希望能把这两者的关系通过这道面试题说明白 方法区是什么 ...
- Spring实战(十)Spring AOP应用——为方法引入新功能、为对象引入新方法
切面最基本的元素是通知和切点,切点用于准确定位应该在什么地方应用切面的通知. 1.Spring借助AspectJ的切点表达式语言来定义Spring切面 在Spring中,要使用AspectJ的切点表达 ...
- C# 对象池的实现(能限制最大实例数量,类似于WCF的MaxInstanceCount功能)
对象池服务可以减少从头创建每个对象的系统开销.在激活对象时,它从池中提取.在停用对象时,它放回池中,等待下一个请求.我们来看下主线程中,如何与对象池打交道: static void Main(stri ...
随机推荐
- WordCount 编码与测试
word count github 项目地址:https://github.com/liuqiang666/wordCount PSP表格 PSP2.1 PSP阶段 预估耗时(小时) 实际耗时( ...
- 利用using和try/finally语句来清理资源
使用非托管资源的类型必须实现IDisposable接口的Dispose()方法来精确的释放系统资源..Net环境的这一规则使得释放资源代码的职责 是类型的使用者,而不是类型或系统.因此,任何时候你在使 ...
- Java50道经典习题-程序49 子串出现的个数
题目:计算首末不含空格各个子串之间只含一个空格的字符串中子串出现的次数分析:例如输入的字符串为"I come from County DingYuan Province AnHui.&quo ...
- ConfigParser简介
一.ConfigParser简介 ConfigParser 是用来读取配置文件的包.配置文件的格式如下:中括号“[ ]”内包含的为section.section 下面为类似于key-value 的配置 ...
- unity编辑器拓展
[ExecutelnEditMode] 在EditMode下也可以执行脚本,Unity默认情况下,脚本只有运行时被执行,加上此属性后,不运行程序也能执行.与PlayMode不同的是函数不会不停 ...
- c# 大文件分割 复制 Filestream 进度条
大文件分割复制,每次复制100M 也可以复制别的较大数值. 小于1G的小文件就直接复制得了.代码里没写 ,但是很简单 直接写进去就好了,难得是分割复制 所以没写. 好吧 我还是改了 改成小文件也可以复 ...
- Binder学习笔记(九)—— 服务端如何响应Test()请求 ?
从服务端代码出发,TestServer.cpp int main() { sp < ProcessState > proc(ProcessState::self()); sp < I ...
- 为什么选择Angular 2?
没有选择是痛苦的,有太多的选择却更加痛苦.而后者正是目前前端领域的真实写照.新的框架层出不穷:它难吗?它写得快吗?可维护性怎样?运行性能如何?社区如何?前景怎样?好就业吗?好招人吗?组建团队容易吗? ...
- LINQ和Lambda表达式
前言 前段时间接触了一种新的表达式,但是不知道这个是什么意思,所以就先站在巨人的肩膀用了,现在听师哥说这种写法是Lambda表达式.我一直以为,这个Lambda表达式和LINQ查询有异曲同工之妙,可惜 ...
- Loadrunner 性能测试笔记
性能测试脚本 // 关联token 放在请求返回前 web_reg_save_param("tokenId", "LB=,\"tokenId\":\& ...