untiy3d action管理机制的编写
使用unity3d对于一些可视化强迫者来说,是一个不错的选择,但unity3d没有cocos2d的action管理机制,比如cocos2dx的CCMoveTo,CCScale等action,所以笔者通过封装action管理来实现类似cocos2dx的actionmanager。
首先需要写一个ActionManager来创建、更新、移除所有action。编写代码实现如下:
using UnityEngine;
using System.Collections;
using System;
public class ActionManager : MonoBehaviour {
private ArrayList actionList = null;
private static ActionManager instance = null;//创建一个ActionManager单例
public static ActionManager Instance
{
get
{
instance = UnityEngine.Object.FindObjectOfType(typeof(ActionManager)) as ActionManager;
if (instance == null)
{
GameObject obj = new GameObject("ActionManager");//每个场景都有一个ActionManager的gameobject来管理所有Action
instance = obj.AddComponent(typeof(ActionManager)) as ActionManager;
instance.InitActionList();
}
return instance;
}
}
public void InitActionList()
{
actionList = new ArrayList();//初始化所有Action容器
}
void Update () {
for (int i = 0; i < actionList.Count;i++ )
{
BasicAction action = (BasicAction)actionList[i];
action.Update();
if(action.bCompleted)//bComplete变量用于判断action是否回收
{
actionList.RemoveAt(i);
i--;
}
}
}
public void AddMoveByAction(GameObject obj, Vector3 moveDirection, float moveDistance,Space relative, float useTime,Action cb)
{
actionList.Add(new MoveBy(obj, moveDirection, moveDistance,relative, useTime, cb));
}
public void AddMoveToAction(GameObject obj, Vector3 targetPos, Space relative, float useTime, Action cb)
{
actionList.Add(new MoveTo(obj,targetPos, relative, useTime, cb));
}
public void RemoveActionByGameObject(GameObject obj)//通过gameobject来移除action
{
foreach (BasicAction action in actionList)
{
if (action.myObj.Equals(obj))
{
actionList.Remove(action);
break;
}
}
}
public void RemoveAllAction()//清除所有action
{
actionList.Clear();
}
void OnDestroy()
{
actionList.Clear();
}
在所有action中具有共同的成员变量,所以需要编写基类函数来减少共同的成员变量和函数,编写action的基类BaseAction:
using UnityEngine;
using System.Collections;
public class BasicAction
{
public bool bCompleted = false;//用于判断action是否完成
public GameObject myObj;//action作用的gameobject
public BasicAction(){}
public virtual void Update(){}//update函数,需要子类重写
}
写完基类,就能入手一个action了,以下是一个比较简单的moveby action:
using UnityEngine;
using System.Collections;
using System;
public class MoveBy : BasicAction { //通过具体距离和方向移动
/*
* moveDirection 移动方向
* moveDistance 移动距离
* useTime 使用的时间,单位秒
*/
private Vector3 speed;
private float time;
//private float deltaTime = 0;
private Space myRelative;
private Action mcb=null;
private float deltaDis = 0,speedLen,moveDistance;
private Vector3 targetPos;
public MoveBy(GameObject obj,Vector3 moveDirection,float moveDistance,Space relative,float useTime,Action cb)
{
this.myObj=obj;
this.mcb = cb;
this.myRelative = relative;
this.moveDistance = moveDistance;
this.time = useTime;
moveDirection.Normalize();
if (myRelative == Space.World)
this.targetPos = this.myObj.transform.position + (moveDirection * moveDistance);
else
this.targetPos = this.myObj.transform.localPosition + (moveDirection * moveDistance);
useTime *= (1 / 0.02f);
speed = (moveDirection * moveDistance) / useTime;
speedLen = Vector3.Distance(speed,Vector3.zero);
}
public override void Update()
{
if(myObj==null)
{
bCompleted = true;
return;
}
deltaDis += speedLen;
if (deltaDis >= moveDistance)
{
myObj.transform.localPosition = targetPos;//确保gameobject到达目标点
if (mcb != null)//完成action后可回调callback
mcb();
bCompleted = true;//如果完成当前action,把action标记可以回收
}
else
{
if (myRelative == Space.World)
myObj.transform.position = new Vector3(myObj.transform.position.x + speed.x, myObj.transform.position.y + speed.y, myObj.transform.position.z + speed.z);
else
myObj.transform.localPosition = new Vector3(myObj.transform.localPosition.x + speed.x, myObj.transform.localPosition.y + speed.y, myObj.transform.localPosition.z + speed.z);
}
}
}
使用例子:
ActionManager.Instance.AddMoveByAction(GameObject obj, Vector3 moveDirection, float moveDistance,Space relative, float useTime,Action cb)
以上时一个比较简单的action封装过程,你也可以通过实现多种action封装,比如moveto,rotationto,rotationby等等。
(转载时请注明出处,from 博客园:HemJohn)
untiy3d action管理机制的编写的更多相关文章
- 【Cocos2d-x 3.x】内存管理机制与源码分析
侯捷先生说过这么一句话 : 源码之前,了无秘密. 要了解Cocos2d-x的内存管理机制,就得阅读源码. 接触Cocos2d-x时, Cocos2d-x的最新版本已经到了3.2的时代,在学习Coco ...
- IOS- 内存管理机制
iOS平台内存常见问题 作为iOS平台的开发者,是否曾经为内存问题而苦恼过?内存莫名的持续增长,程序莫名的crash,难以发现 的内存泄漏,这些都是iOS平台内存相关的常见问题:本文将会详细介绍iOS ...
- Android内存进程管理机制
参考文章: http://www.apkbus.com/android-104940-1-1.htmlhttp://blog.sina.com.cn/s/blog_3e3fcadd0100yjo2.h ...
- 正确认识Android的内存管理机制,合理关闭进程 (一)
随着大家收货后会有很多乐粉晒内存,为啦方便大家,在网上搜集了一些相关Andriod管理的相关机制合理管理内存,整理下发个贴. 首先要知道Android系统是基于Linux 2.6内核开发的开源操作系统 ...
- IOS中内存管理机制浅解
我们知道在程序运行过程中要创建大量的对象,和其他高级语言类似,在ObjC中对象时存储在堆中的,系统并不会自动释放堆中的内存(注意基本类型是 由系统自己管理的,放在栈上).如果一个对象创建并使用后没有得 ...
- JVM介绍&自动内存管理机制
1.介绍JVM(Java Virtual Machine,Java虚拟机) JVM是Java Virtual Machine的缩写,通常成为java虚拟机,作为Java可以进行一次编写,到处执行(Wr ...
- Spark内存管理机制
Spark内存管理机制 Spark 作为一个基于内存的分布式计算引擎,其内存管理模块在整个系统中扮演着非常重要的角色.理解 Spark 内存管理的基本原理,有助于更好地开发 Spark 应用程序和进行 ...
- Android包管理机制(一) PackageInstaller的初始化
前言 包管理机制是Android中的重要机制,是应用开发和系统开发需要掌握的知识点之一. 包指的是Apk.jar和so文件等等,它们被加载到Android内存中,由一个包转变成可执行的代码,这就需要一 ...
- Linux中断管理 (1)Linux中断管理机制
目录: <Linux中断管理> <Linux中断管理 (1)Linux中断管理机制> <Linux中断管理 (2)软中断和tasklet> <Linux中断管 ...
随机推荐
- 剑指Offer的学习笔记(C#篇)-- 二叉搜索树的后序遍历序列
题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 一 . 解题思想与二叉搜索树概念 (1). 二叉树 ...
- nodejs动态路由
主要功能:根据输入路由的不同,加载访问不同的HTML页面 在这里我不得不说webstorm真的是一个很棒的开发工具,我学习nodejs也是用的它. 文件目录: first_server.js: 首先我 ...
- c#之quartz任务调度的使用
这里讲下,quartz这种任务调度程序的简单使用 这是使用的quartz的3.x 版本 2.x 版本与此稍有区别,可以在网上查看2.x版本教程 使用语言为c# quartz的使用分为几个步骤 创建一个 ...
- 第七篇 .NET高级技术之关于相等 Equals
查看判断两个对象是否是同一个对象要用:object.ReferenceEquals(); 因为“==”默认值是比较两个对象是不是同一个对象.所以有时候两个对象的内容相等,但是比较后还是false. O ...
- CSS揭秘—打字动效(四)
前言: 所有实例均来自<CSS揭秘>,该书以平时遇到的疑难杂症为引,提供解决方法,只能说秒极了,再一次刷新了我对CSS的认知 该书只提供了关键CSS代码,虽然有在线示例代码链接,但 ...
- 洛谷 P1908 逆序对(归并排序解法)
树状数组解法:https://www.cnblogs.com/lipeiyi520/p/10846927.html 题目描述 猫猫TOM和小老鼠JERRY最近又较量上了,但是毕竟都是成年人,他们已经不 ...
- ES6新特性使用小结(三)
九.数据类型 Symbol /* * Symbol 数据类型 概念: Symbol 提供一个独一无二的值 * */ { let a1 = Symbol(); let a2 = Symbol(); co ...
- 前端HTML(二/三)
待补充 一.字体标签 字体标签包含:h1~h6.<font>.<u>.<b>.<strong>.<em>.<sup>.<s ...
- B - Median Pyramid Easy 构造题
B - Median Pyramid Easy Time limit : 2sec / Memory limit : 256MB Score : 400 points Problem Statemen ...
- MapReduce编程入门实例之WordCount:分别在Eclipse和Hadoop集群上运行
上一篇博文如何在Eclipse下搭建Hadoop开发环境,今天给大家介绍一下如何分别分别在Eclipse和Hadoop集群上运行我们的MapReduce程序! 1. 在Eclipse环境下运行MapR ...