summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Assets/Art/Controllers/Controller_Saionji.controller31
-rw-r--r--Assets/Art/PostProcessing_setup.asset2
-rw-r--r--Assets/Scenes/Demo/SaionjiShowOff.unity26
-rw-r--r--Assets/Scripts/AbilitySystem/Abilities/AttackAbility.cs21
-rw-r--r--Assets/Scripts/AbilitySystem/Abilities/IdleAbility.cs2
-rw-r--r--Assets/Scripts/AbilitySystem/Actions/ActionDontUseGravity.cs22
-rw-r--r--Assets/Scripts/AbilitySystem/Actions/ActionTowardLeft.cs19
-rw-r--r--Assets/Scripts/AbilitySystem/Actions/ActionTowardLeft.cs.meta11
-rw-r--r--Assets/Scripts/AbilitySystem/Actions/ActionTowardRight.cs19
-rw-r--r--Assets/Scripts/AbilitySystem/Actions/ActionTowardRight.cs.meta11
-rw-r--r--Assets/Scripts/AbilitySystem/Actions/ActionTurn180.cs19
-rw-r--r--Assets/Scripts/AbilitySystem/Actions/ActionTurn180.cs.meta11
-rw-r--r--Assets/Scripts/AbilitySystem/Actions/ActionUseGravity.cs8
-rw-r--r--Assets/Scripts/AbilitySystem/Conditions/ConditionAttkExpireTime.cs21
-rw-r--r--Assets/Scripts/AbilitySystem/Conditions/ConditionAttkExpireTime.cs.meta11
-rw-r--r--Assets/Scripts/AbilitySystem/Conditions/ConditionBase.cs19
-rw-r--r--Assets/Scripts/AbilitySystem/Conditions/ConditionTowardLeft.cs19
-rw-r--r--Assets/Scripts/AbilitySystem/Conditions/ConditionTowardLeft.cs.meta11
-rw-r--r--Assets/Scripts/AbilitySystem/Conditions/ConditionTowardRight.cs18
-rw-r--r--Assets/Scripts/AbilitySystem/Conditions/ConditionTowardRight.cs.meta11
-rw-r--r--Assets/Scripts/Physics/PhysicsBody.cs4
-rw-r--r--Assets/Scripts/Physics/PhysicsWorld.cs2
-rw-r--r--Assets/Scripts/Test/SaionjiScript.cs2
-rw-r--r--Assets/Scripts/Test/SaionjiScript_Ability.cs84
-rw-r--r--Assets/Scripts/Test/SaionjiScript_Anim.cs2
25 files changed, 366 insertions, 40 deletions
diff --git a/Assets/Art/Controllers/Controller_Saionji.controller b/Assets/Art/Controllers/Controller_Saionji.controller
index dcddf24c..959e0150 100644
--- a/Assets/Art/Controllers/Controller_Saionji.controller
+++ b/Assets/Art/Controllers/Controller_Saionji.controller
@@ -78,6 +78,32 @@ AnimatorStateTransition:
m_InterruptionSource: 0
m_OrderedInterruption: 1
m_CanTransitionToSelf: 1
+--- !u!1102 &1102051101437624842
+AnimatorState:
+ serializedVersion: 5
+ m_ObjectHideFlags: 1
+ m_CorrespondingSourceObject: {fileID: 0}
+ m_PrefabInstance: {fileID: 0}
+ m_PrefabAsset: {fileID: 0}
+ m_Name: Idle_Fight
+ m_Speed: 1
+ m_CycleOffset: 0
+ m_Transitions: []
+ m_StateMachineBehaviours: []
+ m_Position: {x: 50, y: 50, z: 0}
+ m_IKOnFeet: 0
+ m_WriteDefaultValues: 1
+ m_Mirror: 0
+ m_SpeedParameterActive: 0
+ m_MirrorParameterActive: 0
+ m_CycleOffsetParameterActive: 0
+ m_TimeParameterActive: 0
+ m_Motion: {fileID: 7400000, guid: 5656b5a1f8ec93c40b45feab20055d27, type: 2}
+ m_Tag:
+ m_SpeedParameter:
+ m_MirrorParameter:
+ m_CycleOffsetParameter:
+ m_TimeParameter:
--- !u!1102 &1102302620783243694
AnimatorState:
serializedVersion: 5
@@ -323,7 +349,7 @@ AnimatorStateMachine:
m_ChildStates:
- serializedVersion: 1
m_State: {fileID: 1102909890512155162}
- m_Position: {x: -240, y: 252, z: 0}
+ m_Position: {x: -240, y: 264, z: 0}
- serializedVersion: 1
m_State: {fileID: 1102851928622758184}
m_Position: {x: -240, y: 324, z: 0}
@@ -348,6 +374,9 @@ AnimatorStateMachine:
- serializedVersion: 1
m_State: {fileID: 1102589474158252204}
m_Position: {x: 300, y: 336, z: 0}
+ - serializedVersion: 1
+ m_State: {fileID: 1102051101437624842}
+ m_Position: {x: -240, y: 204, z: 0}
m_ChildStateMachines: []
m_AnyStateTransitions: []
m_EntryTransitions: []
diff --git a/Assets/Art/PostProcessing_setup.asset b/Assets/Art/PostProcessing_setup.asset
index 0b28577b..9f9dac7d 100644
--- a/Assets/Art/PostProcessing_setup.asset
+++ b/Assets/Art/PostProcessing_setup.asset
@@ -74,7 +74,7 @@ MonoBehaviour:
m_Script: {fileID: 11500000, guid: b94fcd11afffcb142908bfcb1e261fba, type: 3}
m_Name: MotionBlur
m_EditorClassIdentifier:
- active: 1
+ active: 0
enabled:
overrideState: 1
value: 1
diff --git a/Assets/Scenes/Demo/SaionjiShowOff.unity b/Assets/Scenes/Demo/SaionjiShowOff.unity
index 7f32ed56..1505b0a6 100644
--- a/Assets/Scenes/Demo/SaionjiShowOff.unity
+++ b/Assets/Scenes/Demo/SaionjiShowOff.unity
@@ -360,7 +360,7 @@ MonoBehaviour:
m_Script: {fileID: 11500000, guid: 0f7633c93f0364a418841eeb8b058634, type: 3}
m_Name:
m_EditorClassIdentifier:
- m_TrackedObjectOffset: {x: 0, y: 1.25, z: 0}
+ m_TrackedObjectOffset: {x: 0, y: 1.57, z: 0}
m_LookaheadTime: 0
m_LookaheadSmoothing: 0
m_LookaheadIgnoreY: 0
@@ -383,7 +383,7 @@ MonoBehaviour:
m_MaxDollyOut: 5000
m_MinimumDistance: 1
m_MaximumDistance: 5000
- m_MinimumFOV: 51.1
+ m_MinimumFOV: 65.3
m_MaximumFOV: 129.3
m_MinimumOrthoSize: 1
m_MaximumOrthoSize: 5000
@@ -400,7 +400,7 @@ MonoBehaviour:
m_Name:
m_EditorClassIdentifier:
m_BindingMode: 1
- m_FollowOffset: {x: -0.0033898354, y: 1.1222581, z: -7.104233}
+ m_FollowOffset: {x: -0.0033898354, y: 1.76, z: -6.0842323}
m_XDamping: 0
m_YDamping: 0
m_ZDamping: 0
@@ -5205,7 +5205,7 @@ Camera:
height: 1
near clip plane: 0.1
far clip plane: 100
- field of view: 51.1
+ field of view: 45
orthographic: 0
orthographic size: 5
m_Depth: -1
@@ -5230,8 +5230,8 @@ Transform:
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 534669902}
- m_LocalRotation: {x: -0.0089894505, y: 0.00024210886, z: 0.0000021765138, w: 0.9999596}
- m_LocalPosition: {x: 2.4494188, y: -1.81, z: -1.2200003}
+ m_LocalRotation: {x: 0.015608416, y: 0.00027854147, z: -0.00000434812, w: 0.99987817}
+ m_LocalPosition: {x: 2.4494188, y: -1.172258, z: -0.19999981}
m_LocalScale: {x: 1, y: 1, z: 1}
m_Children:
- {fileID: 1241327946}
@@ -5572,8 +5572,8 @@ Transform:
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 801756637}
- m_LocalRotation: {x: -0.0089894505, y: 0.00024210886, z: 0.0000021765138, w: 0.9999596}
- m_LocalPosition: {x: 2.4494188, y: -1.81, z: -1.2200003}
+ m_LocalRotation: {x: 0.015608416, y: 0.00027854147, z: -0.00000434812, w: 0.99987817}
+ m_LocalPosition: {x: 2.4494188, y: -1.172258, z: -0.19999981}
m_LocalScale: {x: 1, y: 1, z: 1}
m_Children:
- {fileID: 433912768}
@@ -9069,6 +9069,16 @@ PrefabInstance:
propertyPath: m_LocalEulerAnglesHint.z
value: 0
objectReference: {fileID: 0}
+ - target: {fileID: 6037765075253890941, guid: 83d445123a203b14298b7a7662a0a470,
+ type: 3}
+ propertyPath: m_Weight
+ value: 40
+ objectReference: {fileID: 0}
+ - target: {fileID: 6037765075253890941, guid: 83d445123a203b14298b7a7662a0a470,
+ type: 3}
+ propertyPath: m_UseGravity
+ value: 0
+ objectReference: {fileID: 0}
- target: {fileID: 6928613106012578342, guid: 83d445123a203b14298b7a7662a0a470,
type: 3}
propertyPath: m_Name
diff --git a/Assets/Scripts/AbilitySystem/Abilities/AttackAbility.cs b/Assets/Scripts/AbilitySystem/Abilities/AttackAbility.cs
index 067d49a8..a3cda9c9 100644
--- a/Assets/Scripts/AbilitySystem/Abilities/AttackAbility.cs
+++ b/Assets/Scripts/AbilitySystem/Abilities/AttackAbility.cs
@@ -12,6 +12,18 @@ public class AttackAbility : AbilityBase
/// </summary>
private List<Trigger> m_Triggers = new List<Trigger>();
+ /// <summary>
+ /// 从动画结束开始计时
+ /// </summary>
+ float m_TimeCount;
+ public float ExpireTime
+ {
+ get
+ {
+ return m_TimeCount;
+ }
+ }
+
public AttackAbility(Animator animator, int animation)
{
m_Animator = animator;
@@ -30,11 +42,13 @@ public class AttackAbility : AbilityBase
public override void OnEnter()
{
- m_Animator.CrossFade(m_AnimHash, 0);
+ m_TimeCount = 0;
+ m_Animator.CrossFade(m_AnimHash, 0f);
}
public override void OnExit()
{
+ m_TimeCount = 0;
}
public override void OnHit()
@@ -51,6 +65,11 @@ public class AttackAbility : AbilityBase
public override void OnUpdate()
{
+ AnimatorStateInfo info = m_Animator.GetCurrentAnimatorStateInfo(0);
+ if(info.shortNameHash == m_AnimHash && info.normalizedTime >= 0.99f)
+ {
+ m_TimeCount += Time.deltaTime;
+ }
foreach (var abilityTrigger in m_Triggers)
{
if (abilityTrigger.Update())
diff --git a/Assets/Scripts/AbilitySystem/Abilities/IdleAbility.cs b/Assets/Scripts/AbilitySystem/Abilities/IdleAbility.cs
index 8be58188..dfd9478d 100644
--- a/Assets/Scripts/AbilitySystem/Abilities/IdleAbility.cs
+++ b/Assets/Scripts/AbilitySystem/Abilities/IdleAbility.cs
@@ -23,9 +23,7 @@ public class IdleAbility : AbilityBase
public override void OnEnter()
{
- m_Animator.speed = 1;
m_Animator.CrossFade(m_AnimHash, 0.3f);
- m_Animator.speed = 0;
}
public override void OnInit()
diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionDontUseGravity.cs b/Assets/Scripts/AbilitySystem/Actions/ActionDontUseGravity.cs
index 1c27a487..82b176fd 100644
--- a/Assets/Scripts/AbilitySystem/Actions/ActionDontUseGravity.cs
+++ b/Assets/Scripts/AbilitySystem/Actions/ActionDontUseGravity.cs
@@ -2,17 +2,17 @@
using System.Collections.Generic;
using UnityEngine;
-public class ActionDontUseGravity : MonoBehaviour
+public class ActionDontUseGravity : ActionBase
{
- // Start is called before the first frame update
- void Start()
- {
-
- }
+ PhysicsBody m_Body;
- // Update is called once per frame
- void Update()
- {
-
- }
+ public ActionDontUseGravity(PhysicsBody body)
+ {
+ m_Body = body;
+ }
+
+ public override void Execute()
+ {
+ m_Body.UseGravity = false;
+ }
}
diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionTowardLeft.cs b/Assets/Scripts/AbilitySystem/Actions/ActionTowardLeft.cs
new file mode 100644
index 00000000..8d888d30
--- /dev/null
+++ b/Assets/Scripts/AbilitySystem/Actions/ActionTowardLeft.cs
@@ -0,0 +1,19 @@
+using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+public class ActionTowardLeft : ActionBase
+{
+ Transform m_Obj;
+ Vector3 m_Angel = new Vector3(0, -90, 0);
+
+ public ActionTowardLeft(Transform obj)
+ {
+ m_Obj = obj;
+ }
+
+ public override void Execute()
+ {
+ m_Obj.rotation = Quaternion.Euler(m_Angel);
+ }
+}
diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionTowardLeft.cs.meta b/Assets/Scripts/AbilitySystem/Actions/ActionTowardLeft.cs.meta
new file mode 100644
index 00000000..313b4775
--- /dev/null
+++ b/Assets/Scripts/AbilitySystem/Actions/ActionTowardLeft.cs.meta
@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: 44aaf2eda01524845942fae69a26b5e1
+MonoImporter:
+ externalObjects: {}
+ serializedVersion: 2
+ defaultReferences: []
+ executionOrder: 0
+ icon: {instanceID: 0}
+ userData:
+ assetBundleName:
+ assetBundleVariant:
diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionTowardRight.cs b/Assets/Scripts/AbilitySystem/Actions/ActionTowardRight.cs
new file mode 100644
index 00000000..b7dadf3a
--- /dev/null
+++ b/Assets/Scripts/AbilitySystem/Actions/ActionTowardRight.cs
@@ -0,0 +1,19 @@
+using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+public class ActionTowardRight : ActionBase
+{
+ Transform m_Obj;
+ Vector3 m_Angel = new Vector3(0, 90, 0);
+
+ public ActionTowardRight(Transform obj)
+ {
+ m_Obj = obj;
+ }
+
+ public override void Execute()
+ {
+ m_Obj.rotation = Quaternion.Euler(m_Angel);
+ }
+}
diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionTowardRight.cs.meta b/Assets/Scripts/AbilitySystem/Actions/ActionTowardRight.cs.meta
new file mode 100644
index 00000000..1477951b
--- /dev/null
+++ b/Assets/Scripts/AbilitySystem/Actions/ActionTowardRight.cs.meta
@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: a2b93c99bf228014392dcff8416c8fe0
+MonoImporter:
+ externalObjects: {}
+ serializedVersion: 2
+ defaultReferences: []
+ executionOrder: 0
+ icon: {instanceID: 0}
+ userData:
+ assetBundleName:
+ assetBundleVariant:
diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionTurn180.cs b/Assets/Scripts/AbilitySystem/Actions/ActionTurn180.cs
new file mode 100644
index 00000000..325a3e88
--- /dev/null
+++ b/Assets/Scripts/AbilitySystem/Actions/ActionTurn180.cs
@@ -0,0 +1,19 @@
+using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+public class ActionTurn180 : ActionBase
+{
+ Transform m_Obj;
+ Vector3 m_Angel = new Vector3(0, 180, 0);
+
+ public ActionTurn180(Transform obj)
+ {
+ m_Obj = obj;
+ }
+
+ public override void Execute()
+ {
+ m_Obj.Rotate(m_Angel);
+ }
+}
diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionTurn180.cs.meta b/Assets/Scripts/AbilitySystem/Actions/ActionTurn180.cs.meta
new file mode 100644
index 00000000..ee218a48
--- /dev/null
+++ b/Assets/Scripts/AbilitySystem/Actions/ActionTurn180.cs.meta
@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: fcc6f64fbe0e7cb48a2db882fe5611c7
+MonoImporter:
+ externalObjects: {}
+ serializedVersion: 2
+ defaultReferences: []
+ executionOrder: 0
+ icon: {instanceID: 0}
+ userData:
+ assetBundleName:
+ assetBundleVariant:
diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionUseGravity.cs b/Assets/Scripts/AbilitySystem/Actions/ActionUseGravity.cs
index da83d163..92cf3261 100644
--- a/Assets/Scripts/AbilitySystem/Actions/ActionUseGravity.cs
+++ b/Assets/Scripts/AbilitySystem/Actions/ActionUseGravity.cs
@@ -4,7 +4,15 @@ using UnityEngine;
public class ActionUseGravity : ActionBase
{
+ PhysicsBody m_Body;
+
+ public ActionUseGravity(PhysicsBody body)
+ {
+ m_Body = body;
+ }
+
public override void Execute()
{
+ m_Body.UseGravity = true;
}
}
diff --git a/Assets/Scripts/AbilitySystem/Conditions/ConditionAttkExpireTime.cs b/Assets/Scripts/AbilitySystem/Conditions/ConditionAttkExpireTime.cs
new file mode 100644
index 00000000..a3944600
--- /dev/null
+++ b/Assets/Scripts/AbilitySystem/Conditions/ConditionAttkExpireTime.cs
@@ -0,0 +1,21 @@
+using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+public class ConditionAttkExpireTime : ConditionBase
+{
+ AttackAbility m_Ability;
+ float m_ExpireTime;
+
+ public ConditionAttkExpireTime(AttackAbility attack, float expireTime)
+ {
+ m_Ability = attack;
+ m_ExpireTime = expireTime;
+ }
+
+ public override bool Evaluate()
+ {
+ return m_Ability.ExpireTime > m_ExpireTime;
+ }
+}
+
diff --git a/Assets/Scripts/AbilitySystem/Conditions/ConditionAttkExpireTime.cs.meta b/Assets/Scripts/AbilitySystem/Conditions/ConditionAttkExpireTime.cs.meta
new file mode 100644
index 00000000..80b4d7a7
--- /dev/null
+++ b/Assets/Scripts/AbilitySystem/Conditions/ConditionAttkExpireTime.cs.meta
@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: 385e621dcc66179459c6f2a2b3b81319
+MonoImporter:
+ externalObjects: {}
+ serializedVersion: 2
+ defaultReferences: []
+ executionOrder: 0
+ icon: {instanceID: 0}
+ userData:
+ assetBundleName:
+ assetBundleVariant:
diff --git a/Assets/Scripts/AbilitySystem/Conditions/ConditionBase.cs b/Assets/Scripts/AbilitySystem/Conditions/ConditionBase.cs
index 38889278..73b9b380 100644
--- a/Assets/Scripts/AbilitySystem/Conditions/ConditionBase.cs
+++ b/Assets/Scripts/AbilitySystem/Conditions/ConditionBase.cs
@@ -16,6 +16,25 @@ public abstract class ConditionBase
}
+/// <summary>
+/// 两个condition都达成才会返回真
+/// </summary>
+public sealed class ConditionNot : ConditionBase
+{
+ ConditionBase m_Condition;
+
+
+ public ConditionNot(ConditionBase cond)
+ : base()
+ {
+ m_Condition = cond;
+ }
+
+ public override bool Evaluate()
+ {
+ return !m_Condition.Evaluate();
+ }
+}
/// <summary>
/// 总是满足
diff --git a/Assets/Scripts/AbilitySystem/Conditions/ConditionTowardLeft.cs b/Assets/Scripts/AbilitySystem/Conditions/ConditionTowardLeft.cs
new file mode 100644
index 00000000..36cbfd05
--- /dev/null
+++ b/Assets/Scripts/AbilitySystem/Conditions/ConditionTowardLeft.cs
@@ -0,0 +1,19 @@
+using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+public class ConditionTowardLeft : ConditionBase
+{
+ Transform m_Obj;
+
+ public ConditionTowardLeft(Transform obj)
+ {
+ m_Obj = obj;
+ }
+
+ public override bool Evaluate()
+ {
+ return Mathf.Approximately(m_Obj.rotation.eulerAngles.y, 270f)
+ || Mathf.Approximately(m_Obj.rotation.eulerAngles.y, -90f);
+ }
+}
diff --git a/Assets/Scripts/AbilitySystem/Conditions/ConditionTowardLeft.cs.meta b/Assets/Scripts/AbilitySystem/Conditions/ConditionTowardLeft.cs.meta
new file mode 100644
index 00000000..e3a399a6
--- /dev/null
+++ b/Assets/Scripts/AbilitySystem/Conditions/ConditionTowardLeft.cs.meta
@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: e2f90baa8b157234f93cdb949b43cd24
+MonoImporter:
+ externalObjects: {}
+ serializedVersion: 2
+ defaultReferences: []
+ executionOrder: 0
+ icon: {instanceID: 0}
+ userData:
+ assetBundleName:
+ assetBundleVariant:
diff --git a/Assets/Scripts/AbilitySystem/Conditions/ConditionTowardRight.cs b/Assets/Scripts/AbilitySystem/Conditions/ConditionTowardRight.cs
new file mode 100644
index 00000000..d26a1fd0
--- /dev/null
+++ b/Assets/Scripts/AbilitySystem/Conditions/ConditionTowardRight.cs
@@ -0,0 +1,18 @@
+using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+public class ConditionTowardRight : ConditionBase
+{
+ Transform m_Obj;
+
+ public ConditionTowardRight(Transform obj)
+ {
+ m_Obj = obj;
+ }
+
+ public override bool Evaluate()
+ {
+ return Mathf.Approximately(m_Obj.rotation.eulerAngles.y, 90f);
+ }
+}
diff --git a/Assets/Scripts/AbilitySystem/Conditions/ConditionTowardRight.cs.meta b/Assets/Scripts/AbilitySystem/Conditions/ConditionTowardRight.cs.meta
new file mode 100644
index 00000000..901efb57
--- /dev/null
+++ b/Assets/Scripts/AbilitySystem/Conditions/ConditionTowardRight.cs.meta
@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: ab6f3e1b40a1eff4196b069e4fd25469
+MonoImporter:
+ externalObjects: {}
+ serializedVersion: 2
+ defaultReferences: []
+ executionOrder: 0
+ icon: {instanceID: 0}
+ userData:
+ assetBundleName:
+ assetBundleVariant:
diff --git a/Assets/Scripts/Physics/PhysicsBody.cs b/Assets/Scripts/Physics/PhysicsBody.cs
index a4ef3aa5..ff5972b4 100644
--- a/Assets/Scripts/Physics/PhysicsBody.cs
+++ b/Assets/Scripts/Physics/PhysicsBody.cs
@@ -49,6 +49,10 @@ public sealed class PhysicsBody : MonoBehaviour
{
return m_UseGravity;
}
+ set
+ {
+ m_UseGravity = value;
+ }
}
[SerializeField]
diff --git a/Assets/Scripts/Physics/PhysicsWorld.cs b/Assets/Scripts/Physics/PhysicsWorld.cs
index 444fe392..c2397909 100644
--- a/Assets/Scripts/Physics/PhysicsWorld.cs
+++ b/Assets/Scripts/Physics/PhysicsWorld.cs
@@ -100,7 +100,7 @@ public class PhysicsWorld : Singleton<PhysicsWorld>
{
float deltaTime = 1f / m_UpdateRate;
// animator -> OnAnimatorMove() -> physics
- UpdateAnimator(deltaTime);
+ //UpdateAnimator(deltaTime);
UpdatePrimitives(deltaTime);
}
diff --git a/Assets/Scripts/Test/SaionjiScript.cs b/Assets/Scripts/Test/SaionjiScript.cs
index 871f155f..0ea5f003 100644
--- a/Assets/Scripts/Test/SaionjiScript.cs
+++ b/Assets/Scripts/Test/SaionjiScript.cs
@@ -20,7 +20,7 @@ public partial class SaionjiScript : MonoBehaviour
void Start()
{
animator = GetComponent<Animator>();
- animator.speed = 0;
+ //animator.speed = 0;
PhysicsWorld.Instance.AddAnimator(animator);
Go_PistolL.SetActive(UsePistol);
diff --git a/Assets/Scripts/Test/SaionjiScript_Ability.cs b/Assets/Scripts/Test/SaionjiScript_Ability.cs
index 1b248751..375dc631 100644
--- a/Assets/Scripts/Test/SaionjiScript_Ability.cs
+++ b/Assets/Scripts/Test/SaionjiScript_Ability.cs
@@ -9,6 +9,11 @@ public partial class SaionjiScript : MonoBehaviour
/// </summary>
AbilitySystem m_AbilitySystem = new AbilitySystem();
+ ConditionBase Not(ConditionBase cond)
+ {
+ return new ConditionNot(cond);
+ }
+
ConditionBase And(ConditionBase c1, ConditionBase c2)
{
return new ConditionAnd(c1, c2);
@@ -19,18 +24,25 @@ public partial class SaionjiScript : MonoBehaviour
return new ConditionOr(c1,c2);
}
- /// <summary>
- /// 设置abilities
- /// </summary>
- void SetupAbilities()
- {
+ /// <summary>
+ /// 设置abilities
+ /// </summary>
+ void SetupAbilities()
+ {
+ // abilities
IdleAbility idle = new IdleAbility(animator, Anim_Idle);
MoveAbility move = new MoveAbility(animator, Anim_Run);
- AttackAbility attk1 = new AttackAbility(animator, Anim_LightAttack1);
- AttackAbility attk2 = new AttackAbility(animator, Anim_LightAttack2);
- AttackAbility attk3 = new AttackAbility(animator, Anim_LightAttack3);
- AttackAbility attk4 = new AttackAbility(animator, Anim_LightAttack4);
- AttackAbility attk5 = new AttackAbility(animator, Anim_LightAttack5);
+ MoveAbility dash = new MoveAbility(animator, Anim_Run);
+ AttackAbility attk1 = new AttackAbility(animator, Anim_LightAttack1);
+ AttackAbility attk2 = new AttackAbility(animator, Anim_LightAttack2);
+ AttackAbility attk3 = new AttackAbility(animator, Anim_LightAttack3);
+ AttackAbility attk4 = new AttackAbility(animator, Anim_LightAttack4);
+ AttackAbility attk5 = new AttackAbility(animator, Anim_LightAttack5);
+
+ // actions
+ ActionTurn180 turn180 = new ActionTurn180(this.transform);
+ ActionTowardLeft towardLeft = new ActionTowardLeft(this.transform);
+ ActionTowardRight towardRight = new ActionTowardRight(this.transform);
ActionSwitchAbility switchToMove = new ActionSwitchAbility(m_AbilitySystem, move);
ActionSwitchAbility switchToIdle = new ActionSwitchAbility(m_AbilitySystem, idle);
@@ -40,41 +52,87 @@ public partial class SaionjiScript : MonoBehaviour
ActionSwitchAbility switchToAttk4 = new ActionSwitchAbility(m_AbilitySystem, attk4);
ActionSwitchAbility switchToAttk5 = new ActionSwitchAbility(m_AbilitySystem, attk5);
+ // conditions
+ ConditionCommand condLeftCmd = new ConditionCommand(GamepadButton.Left);
ConditionCommand condRightCmd = new ConditionCommand(GamepadButton.Right);
ConditionNoMoveButtonHold condNoMoveButtonHold = new ConditionNoMoveButtonHold();
+ ConditionButtonHold condRightButtonHold = new ConditionButtonHold(GamepadButton.Right);
+ ConditionButtonHold condLeftButtonHold = new ConditionButtonHold(GamepadButton.Left);
ConditionCommand condCircleCmd = new ConditionCommand(GamepadButton.Circle);
+ ConditionTowardLeft condTowardLeft = new ConditionTowardLeft(this.transform);
+ ConditionTowardRight condTowardRight = new ConditionTowardRight(this.transform);
- Trigger trigger = null;
+ // common triggers
+ Trigger triggerTurnRight = new Trigger(condRightCmd, towardRight);
+ Trigger triggerTurnLeft = new Trigger(condLeftCmd, towardLeft);
- trigger = new Trigger(condRightCmd, switchToMove);
+ Trigger trigger = null;
+
+ // idle ability
+ trigger = new Trigger(condRightCmd, new List<ActionBase> { switchToMove, towardRight});
+ idle.AddTrigger(trigger);
+ trigger = new Trigger(condLeftCmd, new List<ActionBase> { switchToMove, towardLeft});
idle.AddTrigger(trigger);
trigger = new Trigger(condCircleCmd, switchToAttk1);
idle.AddTrigger(trigger);
+ trigger = new Trigger(condLeftCmd, turn180);
+ idle.AddTrigger(trigger);
- trigger = new Trigger(condNoMoveButtonHold, switchToIdle);
+ // move ability
+ trigger = new Trigger(And(condTowardRight, Not(condRightButtonHold)), switchToIdle);
+ move.AddTrigger(trigger);
+ trigger = new Trigger(And(condTowardLeft, Not(condLeftButtonHold)), switchToIdle);
move.AddTrigger(trigger);
trigger = new Trigger(condCircleCmd, switchToAttk1);
move.AddTrigger(trigger);
+ // attack abilities
+ float expireTime = 0.3f;
+
ConditionAnimAtEnd condAttk1AtEnd = new ConditionAnimAtEnd(animator, Anim_LightAttack1);
trigger = new Trigger(And(condAttk1AtEnd, condCircleCmd), switchToAttk2);
attk1.AddTrigger(trigger);
+ ConditionAttkExpireTime condAttk1ExpireTime = new ConditionAttkExpireTime(attk1, expireTime);
+ trigger = new Trigger(condAttk1ExpireTime, switchToIdle);
+ attk1.AddTrigger(trigger);
+ attk1.AddTrigger(triggerTurnRight);
+ attk1.AddTrigger(triggerTurnLeft);
ConditionAnimAtEnd condAttk2AtEnd = new ConditionAnimAtEnd(animator, Anim_LightAttack2);
trigger = new Trigger(And(condAttk2AtEnd, condCircleCmd), switchToAttk3);
attk2.AddTrigger(trigger);
+ ConditionAttkExpireTime condAttk2ExpireTime = new ConditionAttkExpireTime(attk2, expireTime);
+ trigger = new Trigger(condAttk2ExpireTime, switchToIdle);
+ attk2.AddTrigger(trigger);
+ attk2.AddTrigger(triggerTurnRight);
+ attk2.AddTrigger(triggerTurnLeft);
ConditionAnimAtEnd condAttk3AtEnd = new ConditionAnimAtEnd(animator, Anim_LightAttack3);
trigger = new Trigger(And(condAttk3AtEnd, condCircleCmd), switchToAttk4);
attk3.AddTrigger(trigger);
+ ConditionAttkExpireTime condAttk3ExpireTime = new ConditionAttkExpireTime(attk3, expireTime);
+ trigger = new Trigger(condAttk3ExpireTime, switchToIdle);
+ attk3.AddTrigger(trigger);
+ attk3.AddTrigger(triggerTurnRight);
+ attk3.AddTrigger(triggerTurnLeft);
ConditionAnimAtEnd condAttk4AtEnd = new ConditionAnimAtEnd(animator, Anim_LightAttack4);
trigger = new Trigger(And(condAttk4AtEnd, condCircleCmd), switchToAttk5);
attk4.AddTrigger(trigger);
+ ConditionAttkExpireTime condAttk4ExpireTime = new ConditionAttkExpireTime(attk4, expireTime);
+ trigger = new Trigger(condAttk4ExpireTime, switchToIdle);
+ attk4.AddTrigger(trigger);
+ attk4.AddTrigger(triggerTurnRight);
+ attk4.AddTrigger(triggerTurnLeft);
ConditionAnimAtEnd condAttk5AtEnd = new ConditionAnimAtEnd(animator, Anim_LightAttack5);
trigger = new Trigger(condAttk5AtEnd, switchToIdle);
attk5.AddTrigger(trigger);
+ ConditionAttkExpireTime condAttk5ExpireTime = new ConditionAttkExpireTime(attk5, expireTime);
+ trigger = new Trigger(condAttk5ExpireTime, switchToIdle);
+ attk5.AddTrigger(trigger);
+ attk5.AddTrigger(triggerTurnRight);
+ attk5.AddTrigger(triggerTurnLeft);
m_AbilitySystem.ForceStart(idle);
}
diff --git a/Assets/Scripts/Test/SaionjiScript_Anim.cs b/Assets/Scripts/Test/SaionjiScript_Anim.cs
index 08322b61..c0ebb95f 100644
--- a/Assets/Scripts/Test/SaionjiScript_Anim.cs
+++ b/Assets/Scripts/Test/SaionjiScript_Anim.cs
@@ -15,7 +15,7 @@ public partial class SaionjiScript : MonoBehaviour
void GetAnimHash()
{
- Anim_Idle = Animator.StringToHash("Idle_Assassin");
+ Anim_Idle = Animator.StringToHash("Idle_Fight");
Anim_Run = Animator.StringToHash("Run_Sword_Fast");
Anim_LightAttack1 = Animator.StringToHash("Light_Attk_1");