对象池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 ...
随机推荐
- Eclipse报错could not write metadata for '/remotesystemstempfiles'
1. windows-Preferences 中,在search中输入remote,取消选中reopen remote systems view to previous state'. 2. win ...
- mono-3.0.2安装指南
install-mono.sh.zip mono-3.0.2安装指南.pdf mod_mono.diff.zip mono-3.0.2安装指南 一见 2012/12/27 目录 1. 前言 ...
- Linux修改MySQL max_allowed_packet 值
修改配置文件 vi /etc/my.cnf change "max_allowed_packet = 1M" to "max_allowed_packet = 32M&q ...
- c# interface(接口)和abstract(抽象类)区别
抽象类依然是一个类,不能被实例化,可以包含字段.成员变量.抽象方法.或者不抽象方法. 类继承抽象类,只重写抽象方法即可,其他是可以得到继承的. 接口是规则,里面只包含:方法.属性.索引.事件.类继承接 ...
- 《Linux内核设计与实现》读书笔记(七)- 中断处理
中断处理一般不是纯软件来实现的,需要硬件的支持.通过对中断的学习有助于更深入的了解系统的一些底层原理,特别是驱动程序的开发. 主要内容: 什么是中断 中断类型 中断相关函数 中断处理机制 中断控制方法 ...
- ubuntu - 14.10,安装uget和aria2(下载工具)
Windows下的下载工具--迅雷,之所以下载速度快,乃是它能搜索资源.为己所用,而不是仅仅从原始地址这单一资源处下载. Ubuntu下也有类似的工具,那就是aira2. aira2是一个命令行下载工 ...
- linux 学习文档
1.nginx中文文档 http://www.nginx.cn/doc/
- 微信小程序小结(5) -- 常用语法
在 pages 字段的第一个页面就是这个小程序的首页(打开小程序看到的第一个页面). Page生命周期 属性 类型 描述 onLoad Function 生命周期函数--监听页面加载.一个页面只会调用 ...
- P3348 [ZJOI2016]大森林
\(\color{#0066ff}{ 题目描述 }\) 小Y家里有一个大森林,里面有n棵树,编号从1到n.一开始这些树都只是树苗,只有一个节点,标号为1.这些树都有一个特殊的节点,我们称之为生长节点, ...
- jdk 1.6.0_39 下载
Java SE Development Kit 6u39 Product / File Description File Size Download password Linux x86 65.42 ...