本文整理汇总了C#中Axiom.Math.Quaternion.Dot方法的典型用法代码示例。如果您正苦于以下问题:C# Quaternion.Dot方法的具体用法?C# Quaternion.Dot怎么用?C# Quaternion.Dot使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Axiom.Math.Quaternion
的用法示例。
在下文中一共展示了Quaternion.Dot方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Nlerp
public static Quaternion Nlerp( Real fT, Quaternion rkP, Quaternion rkQ, bool shortestPath )
{
Quaternion result;
var fCos = rkP.Dot( rkQ );
if ( fCos < 0.0f && shortestPath )
{
result = rkP + fT*( ( -rkQ ) - rkP );
}
else
{
result = rkP + fT*( rkQ - rkP );
}
result.Normalize();
return result;
}
示例2: Slerp
/// <summary>
///
/// </summary>
/// <param name="time"></param>
/// <param name="quatA"></param>
/// <param name="quatB"></param>
/// <param name="useShortestPath"></param>
/// <returns></returns>
public static Quaternion Slerp( Real time, Quaternion quatA, Quaternion quatB, bool useShortestPath )
{
var cos = quatA.Dot( quatB );
var angle = (Real)Utility.ACos( cos );
if ( Utility.Abs( angle ) < EPSILON )
{
return quatA;
}
var sin = Utility.Sin( angle );
var inverseSin = 1.0f/sin;
var coeff0 = Utility.Sin( ( 1.0f - time )*angle )*inverseSin;
var coeff1 = Utility.Sin( time*angle )*inverseSin;
Quaternion result;
if ( cos < 0.0f && useShortestPath )
{
coeff0 = -coeff0;
// taking the complement requires renormalisation
var t = coeff0*quatA + coeff1*quatB;
t.Normalize();
result = t;
}
else
{
result = ( coeff0*quatA + coeff1*quatB );
}
return result;
}