2024-03-03 16:34:48 +08:00
|
|
|
|
#region
|
|
|
|
|
|
|
|
|
|
using System.Runtime.CompilerServices;
|
2023-09-24 15:59:43 +08:00
|
|
|
|
using Unity.Burst;
|
2024-03-03 16:34:48 +08:00
|
|
|
|
using UnityEditor;
|
2023-09-24 15:59:43 +08:00
|
|
|
|
using UnityEngine;
|
|
|
|
|
|
2024-03-03 16:34:48 +08:00
|
|
|
|
#endregion
|
|
|
|
|
|
2023-09-24 15:59:43 +08:00
|
|
|
|
namespace nadena.dev.modular_avatar.core.armature_lock
|
|
|
|
|
{
|
|
|
|
|
internal struct TransformState
|
|
|
|
|
{
|
|
|
|
|
private const float POS_EPSILON = 0.00001f;
|
|
|
|
|
private const float ROT_EPSILON = 0.00001f;
|
|
|
|
|
private const float SCALE_EPSILON = 0.00001f;
|
|
|
|
|
|
|
|
|
|
public Vector3 localPosition;
|
|
|
|
|
public Quaternion localRotation;
|
|
|
|
|
public Vector3 localScale;
|
|
|
|
|
|
2024-03-03 16:34:48 +08:00
|
|
|
|
internal static TransformState FromTransform(Transform mergeBone)
|
2023-09-24 15:59:43 +08:00
|
|
|
|
{
|
|
|
|
|
return new TransformState
|
|
|
|
|
{
|
|
|
|
|
localPosition = mergeBone.localPosition,
|
|
|
|
|
localRotation = mergeBone.localRotation,
|
|
|
|
|
localScale = mergeBone.localScale
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-03 16:34:48 +08:00
|
|
|
|
internal void ToTransform(Transform bone)
|
2023-09-24 15:59:43 +08:00
|
|
|
|
{
|
2023-09-25 21:57:45 +08:00
|
|
|
|
#if UNITY_EDITOR
|
2024-03-03 16:34:48 +08:00
|
|
|
|
Undo.RecordObject(bone, Undo.GetCurrentGroupName());
|
2023-09-25 21:57:45 +08:00
|
|
|
|
#endif
|
2023-09-24 15:59:43 +08:00
|
|
|
|
bone.localPosition = localPosition;
|
|
|
|
|
bone.localRotation = localRotation;
|
|
|
|
|
bone.localScale = localScale;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[BurstCompile]
|
|
|
|
|
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
2024-03-03 16:34:48 +08:00
|
|
|
|
internal static bool Differs(TransformState self, TransformState other)
|
2023-09-24 15:59:43 +08:00
|
|
|
|
{
|
|
|
|
|
var deltaMergePos = (self.localPosition - other.localPosition).sqrMagnitude;
|
|
|
|
|
var deltaMergeRot = self.localRotation * Quaternion.Inverse(other.localRotation);
|
|
|
|
|
var deltaMergeScale = (self.localScale - other.localScale).sqrMagnitude;
|
|
|
|
|
|
|
|
|
|
return (deltaMergePos > POS_EPSILON
|
|
|
|
|
|| Quaternion.Angle(deltaMergeRot, Quaternion.identity) > ROT_EPSILON
|
|
|
|
|
|| deltaMergeScale > SCALE_EPSILON);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|