这篇文章主要为大家详细介绍了unity实现延迟回调工具,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
一个实用的计时器,可以计时延迟调用和延迟重复次数调用。
可以自己封装成单例模式挂在GameObject上使用,或者在另一个behavior的Update里执行这个类的OnUpdate()方法再使用。
为了更加安全的使用,建议在销毁MonoBehaviour时清理一下对应的所有计时器。
或者调用时可选择传入回调所在的MonoBehaviour,这样就可以自动清理了。
using System.Collections;
using System;
using System.Collections.Generic;
using UnityEngine;
public static class DelayCall
{
private static List<CallTimeObj> calltimes = new List<CallTimeObj>();
private static Dictionary<int, CallObj> callsort = new Dictionary<int, CallObj>();
private static int countid = 0;
/// <summary>
/// 生成id
/// </summary>
/// <returns>The new identifier.</returns>
/// <param name="call">Call.</param>
private static int getNewId(CallObj call)
{
countid++;
if (countid >= int.MaxValue)
{
countid = 1;
}
while (callsort.ContainsKey(countid)) countid++;
call.callid = countid;
callsort.Add(countid, call);
return countid;
}
public static void ClearAll()
{
calltimes.Clear();
callsort.Clear();
}
/// <summary>
/// 删除延迟执行.
/// </summary>
/// <param name='call'>
/// Call.
/// </param>
public static void remove(int callid)
{
if (callid > 0 && callsort.ContainsKey(callid))
{
CallObj call = callsort[callid];
callsort.Remove(callid);
if (call != null)
{
calltimes.Remove((CallTimeObj)call);
}
}
}
public static int AddTime(float delayTime, object arg, int repeat = 1,Action<object> call)
{
var callobj = new CallTimeObj();
callobj.argsCall = call;
callobj.arg = arg;
callobj.repeat = repeat;
callobj.time = Time.realtimeSinceStartup + delayTime;
callobj.delayTime = delayTime;
if (repeat == 0)
{
callobj.isloop = true;
}
calltimes.Add(callobj);
getNewId(callobj);
return callobj.callid;
}
/// <summary>
/// 添加延迟执行
/// </summary>
/// <param name="call">回调方法</param>
/// <param name="delayTime">延迟时间</param>
/// <param name="repeat">重复回调次数</param>
/// <param name="mn">承载回掉函数的实例是否存在的判断</param>
/// <param name="isUnique">是否是唯一的方法</param>
/// <param name="isReplace">如果重复是否覆盖</param>
/// <returns></returns>
public static int AddTime(float delayTime, int repeat = 1, MonoBehaviour mn = null, bool isUnique = false, bool isReplace = false,Action call)
{
if (isUnique)
{
for (int i = 0; i < calltimes.Count; i++)
{
CallTimeObj call2 = calltimes[i];
if (call2.mn == mn && call2.call == call)
{
if (isReplace)
{
call2.time = Time.realtimeSinceStartup + delayTime;
}
return call2.callid;
}
}
}
var callobj = new CallTimeObj();
callobj.call = call;
callobj.isMN = (mn != null);
callobj.mn = mn;
callobj.repeat = repeat;
callobj.time = Time.realtimeSinceStartup + delayTime;
callobj.delayTime = delayTime;
if (repeat == 0)
{
callobj.isloop = true;
}
calltimes.Add(callobj);
getNewId(callobj);
return callobj.callid;
}
public static void OnUpdate()
{
//time call
if (calltimes.Count != 0) for (int i = 0; i < calltimes.Count; ++i)
{
CallTimeObj call = calltimes[i];
if (call.time <= Time.realtimeSinceStartup)
{
if (call.isloop == false)
{
call.repeat--;
if (call.repeat <= 0)
{
calltimes.RemoveAt(i);
callsort.Remove(call.callid);
--i;
}
else
{
//重新累加时间
call.time += call.delayTime;
}
}
else
{
call.time += call.delayTime;
}
if (!call.isMN || call.mn != null)
{
try
{
if (call.argsCall != null)
{
call.argsCall.Invoke(call.arg);
if (call.isloop == false)
{
if (call.repeat <= 0)
{
call.arg = null;
call.argsCall = null;
call.mn = null;
}
}
}
else
{
call.call();
}
}
catch (Exception e)
{
Debug.LogException(e);
}
}
}
}
}
private class CallObj
{
public Action call = null;
public int frame;
public bool isMN;
public MonoBehaviour mn;
public int callid = 0;
}
private class CallTimeObj : CallObj
{
public Action<object> argsCall = null;
public float time;
public int repeat = 1;
public float delayTime = 0;
public object arg;
public bool isloop = false;
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持得得之家。
织梦狗教程
本文标题为:unity实现延迟回调工具


基础教程推荐
猜你喜欢
- C#调用摄像头实现拍照功能的示例代码 2023-03-09
- Unity 如何获取鼠标停留位置下的物体 2023-04-10
- C#通过标签软件Bartender的ZPL命令打印条码 2023-05-16
- C#中的Linq to JSON操作详解 2023-06-08
- C#中 Json 序列化去掉null值的方法 2022-11-18
- C# 解析XML和反序列化的示例 2023-04-14
- C#获取指定目录下某种格式文件集并备份到指定文件夹 2023-05-30
- 实例详解C#实现http不同方法的请求 2022-12-26
- Unity shader实现高斯模糊效果 2023-01-16
- c# – USING块在网站与Windows窗体中的行为不同 2023-09-20