diff options
author | chai <215380520@qq.com> | 2024-03-13 11:02:11 +0800 |
---|---|---|
committer | chai <215380520@qq.com> | 2024-03-13 11:02:11 +0800 |
commit | 63546b0dc7b142b30b090257f523bc9a9e13b36b (patch) | |
tree | a86b65e3bbd9a919b1df69e86b2f0183694c7d9f /ActiveRagdoll/Assets/TABG/Scripts | |
parent | 795a1ed126a8992b072c81a4d6dea307d07b7747 (diff) |
+ model
Diffstat (limited to 'ActiveRagdoll/Assets/TABG/Scripts')
8 files changed, 145 insertions, 0 deletions
diff --git a/ActiveRagdoll/Assets/TABG/Scripts/FollowRig.cs b/ActiveRagdoll/Assets/TABG/Scripts/FollowRig.cs new file mode 100644 index 0000000..9569f28 --- /dev/null +++ b/ActiveRagdoll/Assets/TABG/Scripts/FollowRig.cs @@ -0,0 +1,32 @@ +using UnityEngine; + +//Player <FollowRig> 相当于模型关节是rig的子节点。相对位置和旋转不变 +public class FollowRig : MonoBehaviour +{ + public Transform target; + + private Vector3 startRot; + + private Vector3 startRotUp; + + private Vector3 startPos; + + private void Awake() + { + if (target != null) + { + startPos = target.InverseTransformPoint(base.transform.position); + startRot = target.InverseTransformDirection(base.transform.forward); + startRotUp = target.InverseTransformDirection(base.transform.up); + } + } + + private void LateUpdate() + { + if (target != null) + { + base.transform.position = target.TransformPoint(startPos); + base.transform.rotation = Quaternion.LookRotation(target.TransformDirection(startRot), target.TransformDirection(startRotUp)); + } + } +} diff --git a/ActiveRagdoll/Assets/TABG/Scripts/FollowRig.cs.meta b/ActiveRagdoll/Assets/TABG/Scripts/FollowRig.cs.meta new file mode 100644 index 0000000..ba3b262 --- /dev/null +++ b/ActiveRagdoll/Assets/TABG/Scripts/FollowRig.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: 5779dac9f52cace4b941214ea8462533 +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: diff --git a/ActiveRagdoll/Assets/TABG/Scripts/Utils.meta b/ActiveRagdoll/Assets/TABG/Scripts/Utils.meta new file mode 100644 index 0000000..ccffdbb --- /dev/null +++ b/ActiveRagdoll/Assets/TABG/Scripts/Utils.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: 797b62151fe6f624b91c2519f11a860d +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/ActiveRagdoll/Assets/TABG/Scripts/Utils/DisplayAllJoints.cs b/ActiveRagdoll/Assets/TABG/Scripts/Utils/DisplayAllJoints.cs new file mode 100644 index 0000000..6815ea7 --- /dev/null +++ b/ActiveRagdoll/Assets/TABG/Scripts/Utils/DisplayAllJoints.cs @@ -0,0 +1,14 @@ +using System.Collections; +using System.Collections.Generic; +using System.Drawing; +using UnityEditor; +using UnityEngine; +using static UnityEngine.GraphicsBuffer; + +public class DisplayAllJoints : MonoBehaviour +{ + + public float size = 1f; + + +} diff --git a/ActiveRagdoll/Assets/TABG/Scripts/Utils/DisplayAllJoints.cs.meta b/ActiveRagdoll/Assets/TABG/Scripts/Utils/DisplayAllJoints.cs.meta new file mode 100644 index 0000000..8dea3eb --- /dev/null +++ b/ActiveRagdoll/Assets/TABG/Scripts/Utils/DisplayAllJoints.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: b9f83568255111e41a950337a6f512b5 +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: diff --git a/ActiveRagdoll/Assets/TABG/Scripts/Utils/Editor.meta b/ActiveRagdoll/Assets/TABG/Scripts/Utils/Editor.meta new file mode 100644 index 0000000..cd038ce --- /dev/null +++ b/ActiveRagdoll/Assets/TABG/Scripts/Utils/Editor.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: 0ac6fba188850ec48ac1fc5f2e30f4c2 +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/ActiveRagdoll/Assets/TABG/Scripts/Utils/Editor/DisplayAllJointsEditor.cs b/ActiveRagdoll/Assets/TABG/Scripts/Utils/Editor/DisplayAllJointsEditor.cs new file mode 100644 index 0000000..a8be3d6 --- /dev/null +++ b/ActiveRagdoll/Assets/TABG/Scripts/Utils/Editor/DisplayAllJointsEditor.cs @@ -0,0 +1,50 @@ +using System.Collections; +using System.Collections.Generic; +using UnityEditor; +using UnityEngine; + +[CustomEditor(typeof(DisplayAllJoints))] +public class DisplayAllJointsEditor : Editor +{ + + protected void OnSceneGUI() + { + DisplayAllJoints display = (DisplayAllJoints)target; + + Transform[] childrens = display.gameObject.GetComponentsInChildren<Transform>(); + + for (int i = 0; i < childrens.Length; ++i) + { + Transform child = childrens[i]; + if (child == display.transform) + { + continue; + } + Transform transform = child.transform; + Handles.color = Handles.xAxisColor; + Handles.ArrowHandleCap( + 0, + transform.position, + transform.rotation * Quaternion.LookRotation(Vector3.right), + display.size, + EventType.Repaint + ); + Handles.color = Handles.yAxisColor; + Handles.ArrowHandleCap( + 0, + transform.position, + transform.rotation * Quaternion.LookRotation(Vector3.up), + display.size, + EventType.Repaint + ); + Handles.color = Handles.zAxisColor; + Handles.ArrowHandleCap( + 0, + transform.position, + transform.rotation * Quaternion.LookRotation(Vector3.forward), + display.size, + EventType.Repaint + ); + } + } +} diff --git a/ActiveRagdoll/Assets/TABG/Scripts/Utils/Editor/DisplayAllJointsEditor.cs.meta b/ActiveRagdoll/Assets/TABG/Scripts/Utils/Editor/DisplayAllJointsEditor.cs.meta new file mode 100644 index 0000000..58fed4e --- /dev/null +++ b/ActiveRagdoll/Assets/TABG/Scripts/Utils/Editor/DisplayAllJointsEditor.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: 0191ef8025a8fad4ab181ee35bfdde22 +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: |