diff options
author | chai <chaifix@163.com> | 2020-10-26 21:33:09 +0800 |
---|---|---|
committer | chai <chaifix@163.com> | 2020-10-26 21:33:09 +0800 |
commit | 97b64a629a95980d9a2f6c9e37b4cb44acf33a59 (patch) | |
tree | 4eeea7d5e00048c2f9b83dc97401f8915608a9b6 /Assets/Scripts/AbilitySystem | |
parent | 3d3f0b7ede44569ecaab523350feede9fee383c3 (diff) |
*跳跃
Diffstat (limited to 'Assets/Scripts/AbilitySystem')
15 files changed, 379 insertions, 16 deletions
diff --git a/Assets/Scripts/AbilitySystem/Abilities/JumpAbility.cs b/Assets/Scripts/AbilitySystem/Abilities/JumpAbility.cs index 4b8e5381..b6615516 100644 --- a/Assets/Scripts/AbilitySystem/Abilities/JumpAbility.cs +++ b/Assets/Scripts/AbilitySystem/Abilities/JumpAbility.cs @@ -2,10 +2,226 @@ using System.Collections.Generic; using UnityEngine; +public struct JumpAbilityConfig
+{
+ public PhysicsBody body;
+ public PhysicsPrimitive collider;
+ public Animator animator;
+
+ public float neutralJumpSpeedY; // 垂直跳跃的基础速度
+ public float fowardJumpSpeedX; // 向前跳跃的水平速度
+ public float backwardJumpSpeedX; // 向后跳跃的水平速度(一般来说是负值)
+
+ public int animJump;
+ public int animNU;
+ public int animFU;
+ public int animBU;
+ public int animND;
+ public int animFD;
+ public int animBD;
+ public int animJumpEnd;
+} + public class JumpAbility : AbilityBase { - Animator m_Animator; + public enum Direction
+ {
+ Neutral,
+ Forward,
+ Backward
+ } + + private enum State
+ {
+ Ready,
+ Up,
+ Down,
+ End,
+ } + Direction m_Dir; + PhysicsBody m_Body; + PhysicsPrimitive m_Collider; + Animator m_Animator;
+
+ public float m_NeutralJumpSpeedY; // 垂直跳跃的基础速度
+ public float m_FowardJumpSpeedX; // 向前跳跃的水平速度
+ public float m_BackwardJumpSpeedX; // 向后跳跃的水平速度(一般来说是负值)
+
+ // jump motions
+ int m_AnimJumpStart; // on ground + int m_AnimJumpNeutralUpwards;
+ int m_AnimJumpNeutralDownwards;
+ int m_AnimJumpFwdUpwards;
+ int m_AnimJumpFwdDownwards;
+ int m_AnimJumpBackUpwards;
+ int m_AnimJumpBackDownwards;
+ int m_AnimJumpEnd; // on ground again
+
+ int m_CurAnim;
+ State m_CurState;
+
+ private List<Trigger> m_Triggers = new List<Trigger>();
+
+ public JumpAbility(JumpAbilityConfig config)
+ {
+ m_Body = config.body;
+ m_Collider = config.collider;
+ m_Animator = config.animator;
+ m_NeutralJumpSpeedY = config.neutralJumpSpeedY;
+ m_FowardJumpSpeedX = config.fowardJumpSpeedX;
+ m_BackwardJumpSpeedX = config.backwardJumpSpeedX;
+ m_AnimJumpStart = config.animJump;
+ m_AnimJumpNeutralUpwards = config.animNU;
+ m_AnimJumpNeutralDownwards = config.animND;
+ m_AnimJumpFwdUpwards = config.animFU;
+ m_AnimJumpFwdDownwards = config.animFD;
+ m_AnimJumpBackUpwards = config.animBU;
+ m_AnimJumpBackDownwards = config.animBD;
+ m_AnimJumpEnd = config.animJumpEnd; // on ground again
+ }
+
+ public void SetDir(Direction dir)
+ {
+ m_Dir = dir;
+ }
+
+ public override void OnEnter()
+ {
+ base.OnEnter();
+
+ m_CurAnim = 0;
+ OnUpdate();
+ }
+
+ public override void OnUpdate()
+ {
+
+ AnimatorStateInfo state = m_Animator.GetCurrentAnimatorStateInfo(0);
+
+ bool onGround = m_Collider.IsOnGround;
+
+ float fadeDuration = 0.2f;
+
+ if (onGround && m_CurAnim == m_AnimJumpNeutralDownwards && m_CurAnim != m_AnimJumpEnd)
+ {
+ m_Animator.CrossFade(m_AnimJumpEnd, 0);
+ m_CurAnim = m_AnimJumpEnd;
+ }
+
+ foreach (var abilityTrigger in m_Triggers)
+ {
+ if (abilityTrigger.Update() && abilityTrigger.Swallow)
+ return ;
+ }
+
+ if(onGround && m_CurAnim != m_AnimJumpStart && m_CurAnim != m_AnimJumpEnd)
+ {
+ m_Animator.CrossFade(m_AnimJumpStart, 0.1f);
+ m_CurAnim = m_AnimJumpStart;
+ return;
+ }
+
+ if(onGround && m_CurAnim == m_AnimJumpStart && state.normalizedTime >= 1f)
+ {
+ if (m_Dir == Direction.Neutral)
+ m_Body.LocalVelocity = new Vector3(0, m_NeutralJumpSpeedY,0);
+ else if(m_Dir == Direction.Forward)
+ m_Body.LocalVelocity = new Vector3(m_FowardJumpSpeedX, m_NeutralJumpSpeedY, 0);
+ else if(m_Dir == Direction.Backward)
+ m_Body.LocalVelocity = new Vector3(m_BackwardJumpSpeedX, m_NeutralJumpSpeedY, 0);
+ }
+
+ bool neutral = Mathf.Approximately(m_Body.LocalVelocity.x, 0);
+ //bool forward = m_Body.LocalVelocity.x > 0;
+ //bool backward = m_Body.LocalVelocity.x < 0;
+ bool forward = m_Dir == Direction.Forward;
+ bool backward = m_Dir == Direction.Backward;
+
+ bool upward = m_Body.LocalVelocity.y > 0;
+ bool downward = m_Body.LocalVelocity.y < 0;
+
+ if (neutral && upward && m_CurAnim != m_AnimJumpNeutralUpwards)
+ {
+ m_Animator.CrossFade(m_AnimJumpNeutralUpwards, fadeDuration);
+ m_CurAnim = m_AnimJumpNeutralUpwards;
+ }
+ else if (forward && upward && m_CurAnim != m_AnimJumpFwdUpwards)
+ {
+ m_Animator.CrossFade(m_AnimJumpFwdUpwards, fadeDuration);
+ m_CurAnim = m_AnimJumpFwdUpwards;
+ }
+ else if (backward && upward && m_CurAnim != m_AnimJumpBackUpwards)
+ {
+ m_Animator.CrossFade(m_AnimJumpBackUpwards, fadeDuration);
+ m_CurAnim = m_AnimJumpBackUpwards;
+ }
+ else if (neutral && downward && m_CurAnim != m_AnimJumpNeutralDownwards)
+ {
+ m_Animator.CrossFade(m_AnimJumpNeutralDownwards, fadeDuration);
+ m_CurAnim = m_AnimJumpNeutralDownwards;
+ }
+ else if (forward && downward && m_CurAnim != m_AnimJumpFwdDownwards)
+ {
+ m_Animator.CrossFade(m_AnimJumpFwdDownwards, fadeDuration);
+ m_CurAnim = m_AnimJumpFwdDownwards;
+ }
+ else if (backward && downward && m_CurAnim != m_AnimJumpBackDownwards)
+ {
+ m_Animator.CrossFade(m_AnimJumpBackDownwards, fadeDuration);
+ m_CurAnim = m_AnimJumpBackDownwards;
+ }
+
+ }
+
+ public override void OnLateUpdate()
+ {
+ base.OnLateUpdate();
+ }
+
+ /// <summary>
+ /// 跳跃准备动作已经完毕
+ /// </summary>
+ /// <returns></returns>
+ public bool IsJumpReady()
+ {
+ if (m_CurAnim != m_AnimJumpStart)
+ return false;
+
+ AnimatorStateInfo state = m_Animator.GetCurrentAnimatorStateInfo(0);
+ if (state.shortNameHash == m_CurAnim && state.normalizedTime >= 1f)
+ return true;
+
+ return false;
+ }
+
+ /// <summary>
+ /// 着地
+ /// </summary>
+ /// <returns></returns>
+ public bool IsJumpDone()
+ {
+ bool onGround = m_Collider.IsOnGround;
+ if (!onGround)
+ return false;
+
+ if (m_CurAnim == m_AnimJumpEnd)
+ {
+ AnimatorStateInfo state = m_Animator.GetCurrentAnimatorStateInfo(0);
+ return state.shortNameHash == m_AnimJumpEnd && state.normalizedTime >= 1f;
+ }
+
+ return false;
+ }
+
+ public void AddTrigger(Trigger trigger)
+ {
+ if (trigger == null || m_Triggers.Contains(trigger))
+ return;
+ m_Triggers.Add(trigger);
+ }
+
+
}
\ No newline at end of file diff --git a/Assets/Scripts/AbilitySystem/Conditions/Camera.meta b/Assets/Scripts/AbilitySystem/Actions/ActionEffects.meta index bfa55719..17a426dd 100644 --- a/Assets/Scripts/AbilitySystem/Conditions/Camera.meta +++ b/Assets/Scripts/AbilitySystem/Actions/ActionEffects.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 8d7f28027add89c448243fbe5ea14144 +guid: 0b5ccfefc2e6b104a8566f4da9a16c5f folderAsset: yes DefaultImporter: externalObjects: {} diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionJump.cs b/Assets/Scripts/AbilitySystem/Actions/ActionJump.cs new file mode 100644 index 00000000..cb3da106 --- /dev/null +++ b/Assets/Scripts/AbilitySystem/Actions/ActionJump.cs @@ -0,0 +1,21 @@ +using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+// 垂直跳跃,切换到jump ability
+public class ActionJump : ActionSwitchAbility
+{
+ private JumpAbility m_JumpAbility;
+
+ public ActionJump(AbilitySystem system, JumpAbility jumpAbility)
+ : base(system, jumpAbility)
+ {
+ m_JumpAbility = jumpAbility;
+ }
+
+ public override void Execute()
+ {
+ m_JumpAbility.SetDir(JumpAbility.Direction.Neutral);
+ base.Execute(); // switch to jump ability
+ }
+}
diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionJump.cs.meta b/Assets/Scripts/AbilitySystem/Actions/ActionJump.cs.meta new file mode 100644 index 00000000..8c48a0a7 --- /dev/null +++ b/Assets/Scripts/AbilitySystem/Actions/ActionJump.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: 987cd3139a86b4c4fa0acdbb621e9e14 +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionJumpBackward.cs b/Assets/Scripts/AbilitySystem/Actions/ActionJumpBackward.cs new file mode 100644 index 00000000..0751d659 --- /dev/null +++ b/Assets/Scripts/AbilitySystem/Actions/ActionJumpBackward.cs @@ -0,0 +1,18 @@ +using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+public class ActionJumpBackward : MonoBehaviour
+{
+ // Start is called before the first frame update
+ void Start()
+ {
+
+ }
+
+ // Update is called once per frame
+ void Update()
+ {
+
+ }
+}
diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionJumpBackward.cs.meta b/Assets/Scripts/AbilitySystem/Actions/ActionJumpBackward.cs.meta new file mode 100644 index 00000000..99c729b3 --- /dev/null +++ b/Assets/Scripts/AbilitySystem/Actions/ActionJumpBackward.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: 635bcce72805fc14ebc1cb057db4e1b2 +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionJumpForward.cs b/Assets/Scripts/AbilitySystem/Actions/ActionJumpForward.cs new file mode 100644 index 00000000..3b1de41d --- /dev/null +++ b/Assets/Scripts/AbilitySystem/Actions/ActionJumpForward.cs @@ -0,0 +1,18 @@ +using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+public class ActionJumpForward : MonoBehaviour
+{
+ // Start is called before the first frame update
+ void Start()
+ {
+
+ }
+
+ // Update is called once per frame
+ void Update()
+ {
+
+ }
+}
diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionJumpForward.cs.meta b/Assets/Scripts/AbilitySystem/Actions/ActionJumpForward.cs.meta new file mode 100644 index 00000000..27f6ba43 --- /dev/null +++ b/Assets/Scripts/AbilitySystem/Actions/ActionJumpForward.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: 0c97763c6fe099c43bab267ccc3888a9 +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Assets/Scripts/AbilitySystem/Actions/ActionSwitchAbility.cs b/Assets/Scripts/AbilitySystem/Actions/ActionSwitchAbility.cs index 69c7f179..1e214d72 100644 --- a/Assets/Scripts/AbilitySystem/Actions/ActionSwitchAbility.cs +++ b/Assets/Scripts/AbilitySystem/Actions/ActionSwitchAbility.cs @@ -2,6 +2,7 @@ using System.Collections.Generic; using UnityEngine; +// 基础的切换 ability public class ActionSwitchAbility : ActionBase { AbilitySystem m_AbilitySystem; diff --git a/Assets/Scripts/AbilitySystem/Actions/CameraActions/ActionMoveCamera.cs b/Assets/Scripts/AbilitySystem/Actions/CameraActions/ActionMoveCamera.cs index e35d43ad..607473c2 100644 --- a/Assets/Scripts/AbilitySystem/Actions/CameraActions/ActionMoveCamera.cs +++ b/Assets/Scripts/AbilitySystem/Actions/CameraActions/ActionMoveCamera.cs @@ -2,17 +2,15 @@ using System.Collections.Generic; using UnityEngine; -public class ActionMoveCamera : MonoBehaviour -{ - // Start is called before the first frame update - void Start() - { - - } - - // Update is called once per frame - void Update() - { - - } +public class ActionMoveCamera : ActionBase +{
+ public ActionMoveCamera()
+ {
+
+ }
+
+ public override void Execute()
+ {
+ throw new System.NotImplementedException();
+ }
} diff --git a/Assets/Scripts/AbilitySystem/Actions/EffectActions.meta b/Assets/Scripts/AbilitySystem/Actions/EffectActions.meta index 17a426dd..8b300c5b 100644 --- a/Assets/Scripts/AbilitySystem/Actions/EffectActions.meta +++ b/Assets/Scripts/AbilitySystem/Actions/EffectActions.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 0b5ccfefc2e6b104a8566f4da9a16c5f +guid: c8aea8ed2489dde4fba46dde6f2a8d09 folderAsset: yes DefaultImporter: externalObjects: {} diff --git a/Assets/Scripts/AbilitySystem/Conditions/ConditionJumpDone.cs b/Assets/Scripts/AbilitySystem/Conditions/ConditionJumpDone.cs new file mode 100644 index 00000000..8d900348 --- /dev/null +++ b/Assets/Scripts/AbilitySystem/Conditions/ConditionJumpDone.cs @@ -0,0 +1,18 @@ +using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+public class ConditionJumpDone : ConditionBase
+{
+ JumpAbility m_Jump;
+
+ public ConditionJumpDone(JumpAbility jump)
+ {
+ m_Jump = jump;
+ }
+
+ public override bool Evaluate()
+ {
+ return m_Jump.IsJumpDone();
+ }
+}
diff --git a/Assets/Scripts/AbilitySystem/Conditions/ConditionJumpDone.cs.meta b/Assets/Scripts/AbilitySystem/Conditions/ConditionJumpDone.cs.meta new file mode 100644 index 00000000..34a9de96 --- /dev/null +++ b/Assets/Scripts/AbilitySystem/Conditions/ConditionJumpDone.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: 734f6d264357f2c43b13f8203f7ecd41 +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Assets/Scripts/AbilitySystem/Conditions/ConditionJumpReady.cs b/Assets/Scripts/AbilitySystem/Conditions/ConditionJumpReady.cs new file mode 100644 index 00000000..a6bd96c0 --- /dev/null +++ b/Assets/Scripts/AbilitySystem/Conditions/ConditionJumpReady.cs @@ -0,0 +1,18 @@ +using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+public class ConditionJumpReady : MonoBehaviour
+{
+ // Start is called before the first frame update
+ void Start()
+ {
+
+ }
+
+ // Update is called once per frame
+ void Update()
+ {
+
+ }
+}
diff --git a/Assets/Scripts/AbilitySystem/Conditions/ConditionJumpReady.cs.meta b/Assets/Scripts/AbilitySystem/Conditions/ConditionJumpReady.cs.meta new file mode 100644 index 00000000..d947e116 --- /dev/null +++ b/Assets/Scripts/AbilitySystem/Conditions/ConditionJumpReady.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: 300b4929ffe151c43bfce427115a05a9 +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: |