You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
85 lines
2.8 KiB
C#
85 lines
2.8 KiB
C#
using UnityEngine;
|
|
using System.Collections;
|
|
|
|
namespace RootMotion.FinalIK {
|
|
|
|
/// <summary>
|
|
/// The hinge rotation limit limits the rotation to 1 degree of freedom around Axis. This rotation limit is additive which means the limits can exceed 360 degrees.
|
|
/// </summary>
|
|
[HelpURL("http://www.root-motion.com/finalikdox/html/page14.html")]
|
|
[AddComponentMenu("Scripts/RootMotion.FinalIK/Rotation Limits/Rotation Limit Hinge")]
|
|
public class RotationLimitHinge : RotationLimit {
|
|
|
|
// Open the User Manual URL
|
|
[ContextMenu("User Manual")]
|
|
private void OpenUserManual() {
|
|
Application.OpenURL("http://www.root-motion.com/finalikdox/html/page14.html");
|
|
}
|
|
|
|
// Open the Script Reference URL
|
|
[ContextMenu("Scrpt Reference")]
|
|
private void OpenScriptReference() {
|
|
Application.OpenURL("http://www.root-motion.com/finalikdox/html/class_root_motion_1_1_final_i_k_1_1_rotation_limit_hinge.html");
|
|
}
|
|
|
|
// Link to the Final IK Google Group
|
|
[ContextMenu("Support Group")]
|
|
void SupportGroup() {
|
|
Application.OpenURL("https://groups.google.com/forum/#!forum/final-ik");
|
|
}
|
|
|
|
// Link to the Final IK Asset Store thread in the Unity Community
|
|
[ContextMenu("Asset Store Thread")]
|
|
void ASThread() {
|
|
Application.OpenURL("http://forum.unity3d.com/threads/final-ik-full-body-ik-aim-look-at-fabrik-ccd-ik-1-0-released.222685/");
|
|
}
|
|
|
|
#region Main Interface
|
|
|
|
/// <summary>
|
|
/// Should the rotation be limited around the axis?
|
|
/// </summary>
|
|
public bool useLimits = true;
|
|
/// <summary>
|
|
/// The min limit around the axis.
|
|
/// </summary>
|
|
public float min = -45;
|
|
/// <summary>
|
|
/// The max limit around the axis.
|
|
/// </summary>
|
|
public float max = 90;
|
|
|
|
#endregion Main Interface
|
|
|
|
/*
|
|
* Limits the rotation in the local space of this instance's Transform.
|
|
* */
|
|
protected override Quaternion LimitRotation(Quaternion rotation) {
|
|
return LimitHinge(rotation);
|
|
}
|
|
|
|
[HideInInspector] public float zeroAxisDisplayOffset; // Angular offset of the scene view display of the Hinge rotation limit
|
|
|
|
private float lastAngle;
|
|
|
|
/*
|
|
* Apply the hinge rotation limit
|
|
* */
|
|
private Quaternion LimitHinge(Quaternion rotation) {
|
|
// If limit is zero return rotation fixed to axis
|
|
if (min == 0 && max == 0 && useLimits) return Quaternion.AngleAxis(0, axis);
|
|
|
|
// Get 1 degree of freedom rotation along axis
|
|
Quaternion free1DOF = Limit1DOF(rotation, axis);
|
|
if (!useLimits) return free1DOF;
|
|
|
|
Quaternion workingSpace = Quaternion.Inverse(Quaternion.AngleAxis(lastAngle, axis) * Quaternion.LookRotation(secondaryAxis, axis));
|
|
Vector3 d = workingSpace * free1DOF * secondaryAxis;
|
|
float deltaAngle = Mathf.Atan2(d.x, d.z) * Mathf.Rad2Deg;
|
|
|
|
lastAngle = Mathf.Clamp(lastAngle + deltaAngle, min, max);
|
|
return Quaternion.AngleAxis(lastAngle, axis);
|
|
}
|
|
}
|
|
}
|