Merge branch 'master' of http://192.168.31.100:8088/framework/xosmopluginlibrary
This commit is contained in:
@@ -4,27 +4,31 @@ using UnityEngine;
|
|||||||
|
|
||||||
namespace Stary.Evo
|
namespace Stary.Evo
|
||||||
{
|
{
|
||||||
public interface FSMIState {
|
public interface FSMIState
|
||||||
|
{
|
||||||
IFsmSystem FsmSystem { get; }
|
IFsmSystem FsmSystem { get; }
|
||||||
string Name { get; }
|
string Name { get; }
|
||||||
|
|
||||||
//进入该状态时调用
|
//进入该状态时调用
|
||||||
UniTask OnEnterAsync();
|
UniTask OnEnterAsync();
|
||||||
|
|
||||||
|
UniTask OnEnterAsync(object param);
|
||||||
|
|
||||||
UniTask OnEnterAsync<T>(T param);
|
UniTask OnEnterAsync<T>(T param);
|
||||||
|
|
||||||
UniTask OnEnterAsync<T1,T2>(T1 param1, T2 param2);
|
UniTask OnEnterAsync<T1, T2>(T1 param1, T2 param2);
|
||||||
|
|
||||||
//每帧调用
|
//每帧调用
|
||||||
void OnUpdate();
|
void OnUpdate();
|
||||||
//退出该状态时调用
|
//退出该状态时调用
|
||||||
|
|
||||||
UniTask OnExitAsync();
|
UniTask OnExitAsync();
|
||||||
}
|
}
|
||||||
|
|
||||||
public abstract class AbstractFSMIState : FSMIState
|
public abstract class AbstractFSMIState : FSMIState
|
||||||
{
|
{
|
||||||
public IFsmSystem FsmSystem { get; }
|
public IFsmSystem FsmSystem { get; }
|
||||||
public string Name { get; }
|
public string Name { get; }
|
||||||
|
|
||||||
public AbstractFSMIState(IFsmSystem system)
|
public AbstractFSMIState(IFsmSystem system)
|
||||||
{
|
{
|
||||||
@@ -32,17 +36,28 @@ namespace Stary.Evo
|
|||||||
Name = GetType().Name;
|
Name = GetType().Name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public abstract UniTask OnEnterAsync<T>(T param);
|
public virtual UniTask OnEnterAsync(object param)
|
||||||
|
{
|
||||||
|
return UniTask.CompletedTask;
|
||||||
|
}
|
||||||
|
|
||||||
public abstract UniTask OnEnterAsync<T1,T2>(T1 param1, T2 param2);
|
public virtual UniTask OnEnterAsync<T>(T param)
|
||||||
|
{
|
||||||
|
return UniTask.CompletedTask;
|
||||||
|
}
|
||||||
|
|
||||||
|
public virtual UniTask OnEnterAsync<T1, T2>(T1 param1, T2 param2)
|
||||||
|
{
|
||||||
|
return UniTask.CompletedTask;
|
||||||
|
}
|
||||||
public abstract UniTask OnEnterAsync();
|
public abstract UniTask OnEnterAsync();
|
||||||
|
|
||||||
public virtual void OnUpdate()
|
public virtual void OnUpdate()
|
||||||
{
|
{
|
||||||
// Timer += Time.deltaTime;
|
// Timer += Time.deltaTime;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public abstract UniTask OnExitAsync();
|
public abstract UniTask OnExitAsync();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -10,6 +10,8 @@ namespace Stary.Evo
|
|||||||
void AddState(FSMIState state);
|
void AddState(FSMIState state);
|
||||||
void RemoveState(FSMIState state);
|
void RemoveState(FSMIState state);
|
||||||
UniTask SetCurState(string name);
|
UniTask SetCurState(string name);
|
||||||
|
|
||||||
|
UniTask SetCurState(string name, object param);
|
||||||
UniTask SetCurState<T>(string name, T param);
|
UniTask SetCurState<T>(string name, T param);
|
||||||
UniTask SetCurState<T1, T2>(string name, T1 param1, T2 param2);
|
UniTask SetCurState<T1, T2>(string name, T1 param1, T2 param2);
|
||||||
FSMIState GetStateWithName(string name);
|
FSMIState GetStateWithName(string name);
|
||||||
@@ -64,7 +66,23 @@ namespace Stary.Evo
|
|||||||
CurState = state;
|
CurState = state;
|
||||||
CurState.OnEnterAsync();
|
CurState.OnEnterAsync();
|
||||||
}
|
}
|
||||||
|
/// <summary>
|
||||||
|
/// 异步状态切换,适用于有参
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="name"></param>
|
||||||
|
/// <param name="param"></param>
|
||||||
|
/// <typeparam name="T"></typeparam>
|
||||||
|
public async UniTask SetCurState(string name, object param)
|
||||||
|
{
|
||||||
|
if (CurState != null)
|
||||||
|
{
|
||||||
|
await CurState.OnExitAsync();
|
||||||
|
}
|
||||||
|
|
||||||
|
FSMIState state = GetStateWithName(name);
|
||||||
|
CurState = state;
|
||||||
|
await CurState.OnEnterAsync(param);
|
||||||
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 异步状态切换,适用于有参
|
/// 异步状态切换,适用于有参
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -80,7 +98,7 @@ namespace Stary.Evo
|
|||||||
|
|
||||||
FSMIState state = GetStateWithName(name);
|
FSMIState state = GetStateWithName(name);
|
||||||
CurState = state;
|
CurState = state;
|
||||||
await CurState.OnEnterAsync(param);
|
await CurState.OnEnterAsync<T>(param);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "com.staryevo.main",
|
"name": "com.staryevo.main",
|
||||||
"version": "1.0.16",
|
"version": "1.0.21",
|
||||||
"displayName": "00.StaryEvo",
|
"displayName": "00.StaryEvo",
|
||||||
"description": "This is an Framework package",
|
"description": "This is an Framework package",
|
||||||
"unity": "2021.3",
|
"unity": "2021.3",
|
||||||
|
|||||||
Reference in New Issue
Block a user