BDtree记录1
来源:互联网 发布:java 多线程同步 编辑:程序博客网 时间:2024/06/11 16:13
1.自定义TriggerSelector: 通过事件触发机制自定义TriggerSelector,就像switch那样根据类型选择其中一个选项
2.绝对不能在Update里面去new对象,万不得已只能借一个空壳去建立,或者用对象池
3.通用的对象池写法
另外绝对不能总是composite里面做重复操作,如果可能最好是用Repeater或者UtilSuccess这类东西,然后接上一个叶子节点。这样性能方面会有所减少损耗
.
5.共享数据保存对象的话,如SharedTransform保存下来的话,那么就已经关联了这个gameobject的transform,所以在获得位置的时候直接拿这个shared就可
以了,无需手动去调用下更新.
6.Running的action 要有结束的时候,无论是Success还是Failure,如WalkToTarget,移动到某个目标点,那么就是当距离目标点位置约等于0的时候返回
Success。假如是Idle状态那么就不需要running了,因为只需要改变下状态机即可。
2.绝对不能在Update里面去new对象,万不得已只能借一个空壳去建立,或者用对象池
3.通用的对象池写法
public static class ObjectPool
{
private static Dictionary<Type, object> poolDictionary = new Dictionary<Type, object>();
public static T Get<T>()
{
if (ObjectPool.poolDictionary.ContainsKey(typeof(T)))
{
List<T> list = ObjectPool.poolDictionary[typeof(T)] as List<T>;
if (list.Count > 0)
{
T result = list[0];
list.RemoveAt(0);
return result;
}
}
return Activator.CreateInstance<T>();
}
public static void Return<T>(T obj)
{
if (ObjectPool.poolDictionary.ContainsKey(typeof(T)))
{
List<T> list = ObjectPool.poolDictionary[typeof(T)] as List<T>;
list.Add(obj);
}
else
{
List<T> list2 = new List<T>();
list2.Add(obj);
ObjectPool.poolDictionary.Add(typeof(T), list2);
}
}
}
另外绝对不能总是composite里面做重复操作,如果可能最好是用Repeater或者UtilSuccess这类东西,然后接上一个叶子节点。这样性能方面会有所减少损耗
.
5.共享数据保存对象的话,如SharedTransform保存下来的话,那么就已经关联了这个gameobject的transform,所以在获得位置的时候直接拿这个shared就可
以了,无需手动去调用下更新.
6.Running的action 要有结束的时候,无论是Success还是Failure,如WalkToTarget,移动到某个目标点,那么就是当距离目标点位置约等于0的时候返回
Success。假如是Idle状态那么就不需要running了,因为只需要改变下状态机即可。
0 0
- BDtree记录1
- 记录1
- 记录1
- 记录1
- 记录1
- 记录1
- 记录1
- 记录1
- 记录1
- 记录-1
- 记录1
- 记录1
- 记录1
- 记录1
- 记录1
- 记录1
- 记录【1】
- [学习记录]Kepware学习记录(1)
- 模版网站480元一个,原创网站最低1180元全包
- bcp of sqlserver
- AndroidManifest.xml中android:configChanges的简介
- Xcode 6 打包ipa文件
- 金蝶盘点机条码数据采集器PDA,WIFI已经连接,但是PDA应用程序还是网络初始化不成功?
- BDtree记录1
- c++11新特性for循环
- 测试博文
- SQL SERVER 2005 分区的基本操作
- netty 多线程用一个长连接(channel) 发送消息 并发安全吗?
- 正则表达式
- 生成删除所有外键约束语句
- 二维码登陆
- 成员变量的初始化区别