Função XMStoreU555 (directxpackedvector.h)
Armazena um XMVECTOR em um XMU555.
Sintaxe
void XM_CALLCONV XMStoreU555(
[out] XMU555 *pDestination,
[in] FXMVECTOR V
) noexcept;
Parâmetros
[out] pDestination
Endereço no qual armazenar os dados.
[in] V
Vetor que contém os dados a serem armazenados.
Valor retornado
Nenhum.
Comentários
O pseudocódigo a seguir demonstra a operação da função .
XMVECTOR N;
static const XMVECTOR Max = {31.f, 31.f, 31.f, 1.0f };
N = XMVectorClamp(V, XMVectorZero, Max);
N = XMVectorRound(N);
pDestination->x = (int8_t)N.v[0];
pDestination->y = (int8_t)N.v[1];
pDestination->z = (int8_t)N.v[2];
pDestination->w = (int8_t)N.v[3];
Observe que esses valores não são normalizados. Para converter no formato RGBA 5/5/5/1, você deve dimensionar o vetor de entrada em (31.f, 31.f, 31.f, 1.f)
.
Além disso, você provavelmente precisará girar o valor padrão .x = RED, .y = GREEN, .z = BLUE, .w = valor .x e .z do vetor de cor ALFA, já que o formato GPU é BGR (não RGB).
Requisitos de plataforma
Microsoft Visual Studio 2010 ou Microsoft Visual Studio 2012 com o SDK do Windows para Windows 8. Com suporte para aplicativos da área de trabalho Win32, aplicativos da Windows Store e aplicativos Windows Phone 8.Requisitos
Plataforma de Destino | Windows |
Cabeçalho | directxpackedvector.h (inclua DirectXPackedVector.h) |