You've already forked UnrealEngineUWP
mirror of
https://github.com/izzy2lost/UnrealEngineUWP.git
synced 2026-03-26 18:15:20 -07:00
#rnx #rb none #ROBOMERGE-OWNER: ryan.durand #ROBOMERGE-AUTHOR: ryan.durand #ROBOMERGE-SOURCE: CL 10869210 via CL 10869511 via CL 10869900 #ROBOMERGE-BOT: (v613-10869866) [CL 10870549 by ryan durand in Main branch]
25 lines
970 B
C++
25 lines
970 B
C++
// Copyright Epic Games, Inc. All Rights Reserved.
|
|
|
|
#include "AngularLimit.h"
|
|
|
|
namespace AnimationCore
|
|
{
|
|
bool ConstrainAngularRangeUsingEuler(FQuat& InOutQuatRotation, const FQuat& InRefRotation, const FVector& InLimitMinDegrees, const FVector& InLimitMaxDegrees)
|
|
{
|
|
// Simple clamping of euler angles. This might be better off refactored to use switch/twist decomposition and maybe an ellipsoid clamp
|
|
FQuat DeltaQuat = InRefRotation * InOutQuatRotation.Inverse();
|
|
FRotator DeltaRotator = DeltaQuat.Rotator();
|
|
FRotator NewRotator;
|
|
NewRotator.Pitch = FMath::Clamp(DeltaRotator.Pitch, InLimitMinDegrees.Y, InLimitMaxDegrees.Y);
|
|
NewRotator.Yaw = FMath::Clamp(DeltaRotator.Yaw, InLimitMinDegrees.X, InLimitMaxDegrees.X);
|
|
NewRotator.Roll = FMath::Clamp(DeltaRotator.Roll, InLimitMinDegrees.Z, InLimitMaxDegrees.Z);
|
|
DeltaQuat = FQuat(NewRotator);
|
|
|
|
InOutQuatRotation = DeltaQuat.Inverse() * InRefRotation;
|
|
|
|
return !NewRotator.Equals(DeltaRotator);
|
|
}
|
|
|
|
}
|
|
|