Поделиться через


структура XMBYTEN2 (directxpackedvector.h)

Двухd-вектор для хранения со знаком нормализованных значений в виде 8-разрядных (1-байтовых) целых чисел со знаком.

Список дополнительных функций, таких как конструкторы и операторы, доступные при XMBYTEN2 программировании на C++, см. в разделе XMBYTEN2 Extensions.

Примечание Сведения об эквивалентных объектах D3DDECLTYPE, D3DFORMAT и DXGI_FORMAT см. в статье Эквивалентность типов библиотеки DirectXMath.
 

Синтаксис

struct XMBYTEN2 {
  union {
    struct {
      int8_t x;
      int8_t y;
    };
    uint16_t v;
  };
  void       XMBYTEN2();
  void       XMBYTEN2(
    const XMBYTEN2 & unnamedParam1
  );
  XMBYTEN2 & operator=(
    const XMBYTEN2 & unnamedParam1
  );
  void       XMBYTEN2(
    XMBYTEN2 && unnamedParam1
  );
  XMBYTEN2 & operator=(
    XMBYTEN2 && unnamedParam1
  );
  void       XMBYTEN2(
    uint16_t Packed
  ) noexcept;
  void       XMBYTEN2(
    int8_t _x,
    int8_t _y
  ) noexcept;
  void       XMBYTEN2(
    const int8_t *pArray
  ) noexcept;
  void       XMBYTEN2(
    float _x,
    float _y
  ) noexcept;
  void       XMBYTEN2(
    const float *pArray
  ) noexcept;
  XMBYTEN2 & operator=(
    uint16_t Packed
  ) noexcept;
};

Члены

x

Со знаком 8-битовое целочисленное значение в диапазоне [-127, 127], описывающее X-координату вектора.

y

Со знаком 8-битовое целочисленное значение в диапазоне [-127, 127], описывающее координату Y вектора.

v

void XMBYTEN2()

Конструктор по умолчанию для XMBYTEN2

Конструктор по умолчанию для XMBYTEN2.

Примечание Этот конструктор доступен только в C++.
 

void XMBYTEN2( const XMBYTEN2 & unnamedParam1)

Конструктор для XMBYTEN2

Конструктор для XMBYTEN2.

Примечание Этот конструктор доступен только в C++.

XMBYTEN2 & operator=( const XMBYTEN2 & unnamedParam1)

Назначает данные компонента вектора из одного экземпляра XMBYTEN2 текущему экземпляру XMBYTEN2.

Этот оператор назначает данные компонента вектора из одного экземпляра XMBYTEN2 текущему экземпляру XMBYTEN2.

Примечание Этот оператор доступен только в C++.

void XMBYTEN2( XMBYTEN2 && без имениParam1)

Конструктор для XMBYTEN2

Конструктор для XMBYTEN2.

Примечание Этот конструктор доступен только в C++.

XMBYTEN2 & operator=( XMBYTEN2 && unnamedParam1)

void XMBYTEN2( uint16_t Упаковано) noexcept

Конструктор для XMBYTEN2

Конструктор для XMBYTEN2.

Примечание Этот конструктор доступен только в C++.

void XMBYTEN2( int8_t _x, int8_t _y) noexcept

Инициализирует новый экземпляр из XMBYTEN2 двух int8_t аргументов.

Этот конструктор инициализирует новый экземпляр XMBYTEN2 из двух int8_t аргументов.

Примечание Этот конструктор доступен только в C++.
 

void XMBYTEN2( const int8_t *pArray) noexcept

Инициализирует новый экземпляр XMBYTEN2 из аргумента массива из двух элементов int8_t .

Этот конструктор инициализирует новый экземпляр XMBYTEN2 из аргумента массива из двух элементов int8_t .

Примечание Этот конструктор доступен только в C++.

void XMBYTEN2( float _x, float _y) noexcept

Инициализирует новый экземпляр из XMBYTEN2 двух float аргументов.

Этот конструктор инициализирует новый экземпляр XMBYTEN2 из двух float аргументов.

Примечание Этот конструктор доступен только в C++.
 

void XMBYTEN2( const float *pArray) noexcept

Инициализирует новый экземпляр XMBYTEN2 из аргумента массива из двух элементов float .

Этот конструктор инициализирует новый экземпляр XMBYTEN2 из аргумента массива из двух элементов float .

Примечание Этот конструктор доступен только в C++.

XMBYTEN2 & operator=( uint16_t Packed) noexcept

Комментарии

Эти XMBYTEN2 конструкторы, использующие аргументы с плавающей запятой, требуют нормализованных входных данных, которые должны находиться в диапазоне [0.0.-1.0]. Во время создания экземпляра эти данные умножаются на 127,0f, результаты округляются, а затем присваиваются соответствующим членам XMBYTEN2.

XMBYTEN2 можно использовать для загрузки экземпляров XMVECTOR из нормализованных значений с помощью XMLoadByteN2, который делит каждый компонент 127.0f, округляет результат, а затем назначает компоненты экземпляру XMVECTOR .

XMVECTOR Экземпляры, содержащие нормализованные значения, можно сохранить в XMBYTEN2 с помощью XMStoreByteN2, который умножает каждый компонент на 127,0f, округляя результат перед назначением значений соответствующим XMBYTEN2 членам.

Пространства имен: Использование DirectX::P ackedVector

Требования к платформе

Microsoft Visual Studio 2010 или Microsoft Visual Studio 2012 с windows SDK для Windows 8. Поддерживается для классических приложений Win32, приложений Магазина Windows и Windows Phone 8 приложений.

Требования

   
Верхняя часть directxpackedvector.h

См. также раздел

Структуры библиотек DirectXMath

Расширения XMBYTEN2