summaryrefslogtreecommitdiff
path: root/_ActiveRagdoll/Handlers/HeadCollisionHandler.cs
diff options
context:
space:
mode:
authorchai <215380520@qq.com>2024-03-18 10:03:48 +0800
committerchai <215380520@qq.com>2024-03-18 10:03:48 +0800
commitc9fc4fbbe205ff69fa20ded822b2214847b59726 (patch)
treec9bcce93d3a887b0070aeeee5c1db80b7b112043 /_ActiveRagdoll/Handlers/HeadCollisionHandler.cs
parent793c4eae324d394f19a8bac66a803bf03a67ae9d (diff)
Diffstat (limited to '_ActiveRagdoll/Handlers/HeadCollisionHandler.cs')
-rw-r--r--_ActiveRagdoll/Handlers/HeadCollisionHandler.cs31
1 files changed, 31 insertions, 0 deletions
diff --git a/_ActiveRagdoll/Handlers/HeadCollisionHandler.cs b/_ActiveRagdoll/Handlers/HeadCollisionHandler.cs
new file mode 100644
index 0000000..c929f0e
--- /dev/null
+++ b/_ActiveRagdoll/Handlers/HeadCollisionHandler.cs
@@ -0,0 +1,31 @@
+using UnityEngine;
+
+public class HeadCollisionHandler : MonoBehaviour
+{
+ public float collisionValue;
+
+ private void Start()
+ {
+ }
+
+ private void Update()
+ {
+ collisionValue = Mathf.Lerp(collisionValue, 0f, Time.deltaTime * 6f);
+ }
+
+ private void OnCollisionEnter(Collision collision)
+ {
+ if (!(collision.transform.root == base.transform.root))
+ {
+ collisionValue += collision.relativeVelocity.magnitude * 0.5f;
+ }
+ }
+
+ private void OnCollisionStay(Collision collision)
+ {
+ if (!(collision.transform.root == base.transform.root))
+ {
+ collisionValue += collision.relativeVelocity.magnitude * 0.1f;
+ }
+ }
+}