Compartir a través de


Función XMStoreShort2 (directxpackedvector.h)

Almacena un XMVECTOR en un XMSHORT2.

Sintaxis

void XM_CALLCONV XMStoreShort2(
  [out] XMSHORT2  *pDestination,
  [in]  FXMVECTOR V
) noexcept;

Parámetros

[out] pDestination

Dirección en la que se almacenarán los datos.

[in] V

Vector que contiene los datos que se van a almacenar.

Valor devuelto

Ninguno.

Comentarios

Esta función toma un vector, lo sujeta al intervalo -32767.0f a 32767.0f, convierte los dos componentes más significativos en un formato entero con signo normalizado y escribe los resultados en dos valores enteros cortos en la dirección especificada. El componente más significativo se escribe en los dos primeros bytes de la dirección y el siguiente componente más significativo se escribe en los dos bytes siguientes de la dirección.

El pseudocódigo siguiente muestra la operación de la función .

static const XMVECTOR  Min = {-32767.0f, -32767.0f, -32767.0f, -32767.0f};
static const XMVECTOR  Max = {32767.0f, 32767.0f, 32767.0f, 32767.0f};
XMVECTOR               N;
N = XMVectorClamp(V, Min, Max);
N = XMVectorRound(N);

pDestination->x = (int16_t)N.x; // 2 bytes to address pDestination
pDestination->y = (int16_t)N.y; // 2 bytes to address (uint8_t*)pDestination + 2

Requisitos de la plataforma

Microsoft Visual Studio 2010 o Microsoft Visual Studio 2012 con Windows SDK para Windows 8. Compatible con aplicaciones de escritorio Win32, aplicaciones de la Tienda Windows y Windows Phone 8 aplicaciones.

Requisitos

Requisito Value
Plataforma de destino Windows
Encabezado directxpackedvector.h (incluya DirectXPackedVector.h)

Consulte también

Funciones del almacén de vectores de la biblioteca DirectXMath