mirror of
https://github.com/EsotericSoftware/spine-runtimes.git
synced 2026-03-26 22:49:01 +08:00
[Unity] Update BoneFollower
This commit is contained in:
parent
16011c2eb1
commit
21b8a03ccd
@ -62,8 +62,7 @@ namespace Spine.Unity {
|
|||||||
Transform skeletonTransform;
|
Transform skeletonTransform;
|
||||||
|
|
||||||
public void Awake () {
|
public void Awake () {
|
||||||
if (initializeOnAwake)
|
if (initializeOnAwake) Initialize();
|
||||||
Initialize();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void HandleRebuildRenderer (SkeletonRenderer skeletonRenderer) {
|
public void HandleRebuildRenderer (SkeletonRenderer skeletonRenderer) {
|
||||||
@ -73,7 +72,6 @@ namespace Spine.Unity {
|
|||||||
public void Initialize () {
|
public void Initialize () {
|
||||||
bone = null;
|
bone = null;
|
||||||
valid = skeletonRenderer != null && skeletonRenderer.valid;
|
valid = skeletonRenderer != null && skeletonRenderer.valid;
|
||||||
|
|
||||||
if (!valid) return;
|
if (!valid) return;
|
||||||
|
|
||||||
skeletonTransform = skeletonRenderer.transform;
|
skeletonTransform = skeletonRenderer.transform;
|
||||||
@ -98,8 +96,7 @@ namespace Spine.Unity {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (bone == null) {
|
if (bone == null) {
|
||||||
if (string.IsNullOrEmpty(boneName))
|
if (string.IsNullOrEmpty(boneName)) return;
|
||||||
return;
|
|
||||||
|
|
||||||
bone = skeletonRenderer.skeleton.FindBone(boneName);
|
bone = skeletonRenderer.skeleton.FindBone(boneName);
|
||||||
if (bone == null) {
|
if (bone == null) {
|
||||||
@ -108,32 +105,21 @@ namespace Spine.Unity {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Flip rotation
|
|
||||||
float boneRotation = bone.WorldRotationX;
|
|
||||||
{
|
|
||||||
Skeleton skeleton = skeletonRenderer.skeleton;
|
|
||||||
bool flipX = skeleton.flipX;
|
|
||||||
if (flipX ^ skeleton.flipY) boneRotation *= -1f;
|
|
||||||
if (flipX) boneRotation += 180f;
|
|
||||||
}
|
|
||||||
|
|
||||||
Transform thisTransform = this.transform;
|
Transform thisTransform = this.transform;
|
||||||
// Recommended setup: Use local transform properties if Spine GameObject is parent
|
|
||||||
if (thisTransform.parent == skeletonTransform) {
|
if (thisTransform.parent == skeletonTransform) {
|
||||||
|
// Recommended setup: Use local transform properties if Spine GameObject is the immediate parent
|
||||||
thisTransform.localPosition = new Vector3(bone.worldX, bone.worldY, followZPosition ? 0f : thisTransform.localPosition.z);
|
thisTransform.localPosition = new Vector3(bone.worldX, bone.worldY, followZPosition ? 0f : thisTransform.localPosition.z);
|
||||||
if (followBoneRotation)
|
if (followBoneRotation) thisTransform.localRotation = Quaternion.Euler(0f, 0f, bone.WorldRotationX);
|
||||||
thisTransform.localRotation = Quaternion.Euler(0f, 0f, boneRotation);
|
|
||||||
|
|
||||||
// For special cases: Use transform world properties if transform relationship is complicated
|
|
||||||
} else {
|
} else {
|
||||||
|
// For special cases: Use transform world properties if transform relationship is complicated
|
||||||
Vector3 targetWorldPosition = skeletonTransform.TransformPoint(new Vector3(bone.worldX, bone.worldY, 0f));
|
Vector3 targetWorldPosition = skeletonTransform.TransformPoint(new Vector3(bone.worldX, bone.worldY, 0f));
|
||||||
if (!followZPosition)
|
if (!followZPosition) targetWorldPosition.z = thisTransform.position.z;
|
||||||
targetWorldPosition.z = thisTransform.position.z;
|
|
||||||
|
|
||||||
thisTransform.position = targetWorldPosition;
|
thisTransform.position = targetWorldPosition;
|
||||||
|
|
||||||
if (followBoneRotation) {
|
if (followBoneRotation) {
|
||||||
Vector3 worldRotation = skeletonTransform.rotation.eulerAngles;
|
Vector3 worldRotation = skeletonTransform.rotation.eulerAngles;
|
||||||
thisTransform.rotation = Quaternion.Euler(worldRotation.x, worldRotation.y, skeletonTransform.rotation.eulerAngles.z + boneRotation);
|
thisTransform.rotation = Quaternion.Euler(worldRotation.x, worldRotation.y, skeletonTransform.rotation.eulerAngles.z + bone.WorldRotationX);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user