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.
o3de/Gems/StartingPointCamera/Code/Source/StartingPointCamera/StartingPointCameraUtilitie...

112 lines
3.7 KiB
C++

/*
* Copyright (c) Contributors to the Open 3D Engine Project.
* For complete copyright and license terms please see the LICENSE at the root of this distribution.
*
* SPDX-License-Identifier: Apache-2.0 OR MIT
*
*/
#include <StartingPointCamera/StartingPointCameraUtilities.h>
#include <AzCore/Component/ComponentApplicationBus.h>
#include <AzCore/Serialization/SerializeContext.h>
namespace Camera
{
const char* GetNameFromUuid(const AZ::Uuid& uuid)
{
AZ::SerializeContext* serializeContext = nullptr;
AZ::ComponentApplicationBus::BroadcastResult(serializeContext, &AZ::ComponentApplicationRequests::GetSerializeContext);
if (serializeContext)
{
if (const AZ::SerializeContext::ClassData* classData = serializeContext->FindClassData(uuid))
{
return classData->m_name;
}
}
return "";
}
void MaskComponentFromNormalizedVector(AZ::Vector3& v, bool ignoreX, bool ignoreY, bool ignoreZ)
{
if (ignoreX)
{
v.SetX(0.f);
}
if (ignoreY)
{
v.SetY(0.f);
}
if (ignoreZ)
{
v.SetZ(0.f);
}
if (v.IsZero())
{
AZ_Warning("StartingPointCameraUtilities", false, "MaskComponentFromNormalizedVector: trying to normalize zero vector.")
return;
}
v.Normalize();
}
float GetEulerAngleFromTransform(const AZ::Transform& rotation, EulerAngleType eulerAngleType)
{
AZ::Vector3 angles = rotation.GetEulerDegrees();
switch (eulerAngleType)
{
case Pitch:
return angles.GetX();
case Roll:
return angles.GetY();
case Yaw:
return angles.GetZ();
default:
AZ_Warning("StartingPointCameraUtilities", false, "GetEulerAngleFromRotation: eulerAngleType - value not supported");
return 0.f;
}
}
AZ::Transform CreateRotationFromEulerAngle(EulerAngleType rotationType, float radians)
{
switch (rotationType)
{
case Pitch:
return AZ::Transform::CreateRotationX(radians);
case Roll:
return AZ::Transform::CreateRotationY(radians);
case Yaw:
return AZ::Transform::CreateRotationZ(radians);
default:
AZ_Warning("StartingPointCameraUtilities", false, "CreateRotationFromEulerAngle: rotationType - value not supported");
return AZ::Transform::Identity();
}
}
AZ::Quaternion CreateQuaternionFromViewVector(const AZ::Vector3 lookVector)
{
float twoDimensionLength = AZ::Vector2(lookVector.GetX(), lookVector.GetY()).GetLength();
if (twoDimensionLength > AZ::Constants::FloatEpsilon)
{
AZ::Vector3 hv(lookVector.GetX() / twoDimensionLength, lookVector.GetY() / twoDimensionLength + 1.f, twoDimensionLength + 1.f);
float twoDimensionHVLength = AZ::Vector2(hv.GetX(), hv.GetY()).GetLength();
float twoDZLength = AZ::Vector2(hv.GetZ(), lookVector.GetZ()).GetLength();
float halfCosHV = 0.f;
float halfSinHV = -1.f;
if (twoDimensionHVLength > AZ::Constants::FloatEpsilon)
{
halfCosHV = hv.GetY() / twoDimensionHVLength;
halfSinHV = -hv.GetX() / twoDimensionHVLength;
}
float halfCosZ = hv.GetZ() / twoDZLength;
float halfSinZ = lookVector.GetZ() / twoDZLength;
return AZ::Quaternion(halfCosHV * halfSinZ, halfSinHV * halfSinZ, halfSinHV * halfCosZ, halfCosHV * halfCosZ);
}
return AZ::Quaternion::CreateIdentity();
}
} //namespace Camera