Condividi tramite


struttura XMDECN4 (directxpackedvector.h)

Vettore 4D per l'archiviazione di valori firmati, normalizzati come componenti x,y e z con segno a 10 bit e un componente w-component con segno a 2 bit.

Per un elenco di funzionalità aggiuntive, ad esempio costruttori e operatori disponibili quando XMDECN4 si esegue la programmazione in C++, vedere XMDECN4 Extensions.

Nota Per informazioni sugli oggetti equivalenti D3DDECLTYPE, D3DFORMAT e DXGI_FORMAT, vedere Equivalenza dei tipi di libreria DirectXMath.
 

Sintassi

struct XMDECN4 {
  union {
    struct {
      int32_t x : 10;
      int32_t y : 10;
      int32_t z : 10;
      int32_t w : 2;
    };
             uint32_t v;
  };
  void      XMDECN4();
  void      XMDECN4(
    const XMDECN4 & unnamedParam1
  );
  XMDECN4 & operator=(
    const XMDECN4 & unnamedParam1
  );
  void      XMDECN4(
    XMDECN4 && unnamedParam1
  );
  XMDECN4 & operator=(
    XMDECN4 && unnamedParam1
  );
  void      XMDECN4(
    uint32_t Packed
  ) noexcept;
  void      XMDECN4(
    float _x,
    float _y,
    float _z,
    float _w
  ) noexcept;
  void      XMDECN4(
    const float *pArray
  ) noexcept;
  void      operator uint32_t() noexcept;
  XMDECN4 & operator=(
    uint32_t Packed
  ) noexcept;
};

Members

x

Valore intero con segno nell'intervallo [-511, 511] che descrive la coordinata x del vettore.

y

Valore intero con segno nell'intervallo [-511, 511] che descrive la coordinata y del vettore.

z

Valore intero con segno nell'intervallo [-511, 511] che descrive la coordinata z del vettore.

w

Valore intero con segno nell'intervallo [-1, 1] che descrive la coordinata w del vettore.

v

Intero senza segno a 32 bit che rappresenta il vettore 4D.

void XMDECN4()

Costruttore predefinito per XMDECN4.

Costruttore predefinito per XMDECN4 .

Nota Questo costruttore è disponibile solo in C++.
 

void XMDECN4( const XMDECN4 & unnamedParam1)

Costruttore per XMDECN4.

Costruttore per XMDECN4.

Nota Questo costruttore è disponibile solo in C++.

XMDECN4 & operator=( const XMDECN4 & unnamedParam1)

void XMDECN4( XMDECN4 && unnamedParam1)

Costruttore per XMDECN4.

Costruttore per XMDECN4.

Nota Questo costruttore è disponibile solo in C++.

XMDECN4 & operator=( XMDECN4 && unnamedParam1)

Assegna i dati del componente vettoriale da un'istanza di XMDECN4 all'istanza corrente di XMDECN4.

Questo operatore assegna i dati del componente vettoriale da un'istanza di XMDECN4 all'istanza corrente di XMDECN4.

Nota Questo operatore è disponibile solo in C++.

void XMDECN4( uint32_t Compresso) noexcept

Inizializza una nuova istanza di XMDECN4 da una uint32_t variabile contenente i dati del componente in un formato compresso.

Questo costruttore inizializza una nuova istanza di XMDECN4 da una uint32_t variabile contenente i dati del componente in un formato compresso.

Nota Questo costruttore è disponibile solo in C++.
 

void XMDECN4( float _x, float _y, float _z, float _w) noexcept

Inizializza una nuova istanza di XMDECN4 da quattro argomenti normalizzati float .

Questo costruttore inizializza una nuova istanza di XMDECN4 da quattro argomenti normalizzati float .

Nota Questo costruttore è disponibile solo in C++.
 

void XMDECN4( const float *pArray) noexcept

Inizializza una nuova istanza di XMDECN4 da un argomento di matrice di quattro elementi float .

Questo costruttore inizializza una nuova istanza di XMDECN4 da un argomento di matrice di quattro elementi float .

Nota Questo costruttore è disponibile solo in C++.

Operatore void uint32_t() noexcept

Restituisce un'istanza di uint32_t contenente i componenti dell'istanza XMDECN4 in un formato compresso.

Restituisce un'istanza di uint32_t contenente i componenti dell'istanza di XMDECN4 in un formato compresso.

Nota Questo operatore è disponibile solo in C++.
 

XMDECN4 & operator=( uint32_t Packed) noexcept

Questo operatore assegna i dati del componente vettoriale compressi in un'istanza di uint32_t all'istanza corrente di XMDECN4.

Nota Questo operatore è disponibile solo in C++.
 

Commenti

Tali XMDECN4 costruttori che usano argomenti a virgola mobile richiedono un input normalizzato, che deve trovarsi nell'intervallo di [-1.0.-1.0]. Durante la creazione di un'istanza, gli input che specificano i componenti x,y e z vengono quindi moltiplicati per 511.0f, i risultati vengono arrotondati e quindi assegnati ai membri appropriati di XMDECN4.

XMDECN4 può essere usato per caricare istanze di XMVECTOR da valori normalizzati, usando XMLoadDecN4, che divide i componenti x,y e z per 511,0f, arrotonda il risultato e quindi assegna i componenti a un'istanza XMVECTOR di .

XMVECTOR Le istanze contenenti valori normalizzati possono essere archiviate in XMDECN4 usando XMStoreDecN4, che moltiplica i componenti x, y e z per 511,0f, arrotondando il risultato, prima di assegnare i valori ai membri appropriati XMDECN4 .

Namespace: Usare DirectX::P ackedVector

Requisiti della piattaforma

Microsoft Visual Studio 2010 o Microsoft Visual Studio 2012 con il Windows SDK per Windows 8. Supportato per le app desktop Win32, le app di Windows Store e Windows Phone 8 app.

Requisiti

Requisito Valore
Intestazione directxpackedvector.h

Vedi anche

Strutture della libreria DirectXMath

estensioni XMDECN4