XMStoreFloat3SE 関数 (directxpackedvector.h)
XMVECTOR をXMFLOAT3SEに格納します。
構文
void XM_CALLCONV XMStoreFloat3SE(
[out] XMFLOAT3SE *pDestination,
[in] FXMVECTOR V
) noexcept;
パラメーター
[out] pDestination
データを格納するアドレス。
[in] V
格納するデータを含むベクター。
戻り値
[なし] :
解説
次の擬似コードは、 関数の操作を示しています。
XMVECTOR N;
static const XMVECTOR Max = { 65472.f, 65427.f, 65427.f, 0 };
N = XMVectorClamp(V, XMVectorZero(), Max);
uint32_t m[3], e[3];
ConvertToFloat14( N.x, &m[0], &e[0]);
ConvertToFloat14( N.y, &m[1], &e[1]);
ConvertToFloat14( N.z, &m[2], &e[2]);
uint32_t T = XMMax( e[0], XMMax( e[1], e[2] ) );
pDestination->xm = m[0] >> (T - e[0]);
PDestination->ym = m[1] >> (T - e[1]);
pDestination->zm = m[2] >> (T - e[2]);
pDestination->e = T;
3 つのコンポーネントが互いに大きく近くない場合、最大値によって指数が設定され、他のコンポーネントは 0 にシフトされます。
プラットフォームの要件
Microsoft Visual Studio 2010 または Microsoft Visual Studio 2012 と Windows SDK for Windows 8。 Win32 デスクトップ アプリ、Windows ストア アプリ、Windows Phone 8 アプリでサポートされます。要件
要件 | 値 |
---|---|
対象プラットフォーム | Windows |
ヘッダー | directxpackedvector.h (DirectXPackedVector.h を含む) |