summaryrefslogtreecommitdiff
path: root/Assets/Scripts/AbilitySystem
diff options
context:
space:
mode:
Diffstat (limited to 'Assets/Scripts/AbilitySystem')
-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
17 files changed, 239 insertions, 14 deletions
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: