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


Функция XMDECN4::XMDECN4(constfloat*) (directxpackedvector.h)

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

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

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

Синтаксис

void XMDECN4(
  const float *pArray
) noexcept;

Параметры

pArray

Массив с плавающей запятой четырех элементов, содержащий значения, используемые для инициализации четырех компонентов нового экземпляра XMDECN4.

Возвращаемое значение

None

Remarks

Элементы массива сопоставляются с компонентами вектора нового экземпляра XMDECN4 следующим образом:

Компонент вектора Элемент Array Диапазон Описание
x pArray[0] -1.0, 1.0 Во время создания экземпляра pArray[0] зажимается между -1 и 1, умножается на 511,0f и присваивается x.
y pArray[1] -1.0, 1.0 Во время создания экземпляра pArray[1] зажимается между -1 и 1, умножается на 511,0f, а затем присваивается y.
z pArray[2] -1.0, 1.0 Во время создания экземпляра pArray[2] зажимается в диапазоне от -1 до 1, умножается на 511,0f, а затем присваивается z.
w pArray[3] -1.0, 1.0 Во время создания экземпляра pArray[3] зажимается между -1 и 1, а затем назначается w.
XMDECN4 instance;
_x1=min( max( pArray[0], -1.0 ), 1.0 );
_y1=min( max( pArray[1], -1.0 ), 1.0 );
_z1=min( max( pArray[2], -1.0 ), 1.0 );
_w1=min( max( pArray[3], -1.0 ), 1.0 );
_x1 = round( _x1 *  511.0f);
_y1 = round( _y1 *  511.0f);
_z1 = round( _z1 *  511.0f);

instance.v =  ( (int32_t)_w1 << 30) |
              (((int32_t)_z1 & 0x3FF) << 20) |
              (((int32_t)_y1 & 0x3FF) << 10) |
              (((int32_t)_x1 & 0x3FF));

Требования

Требование Значение
Целевая платформа Windows
Header directxpackedvector.h

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

XMDECN4

Конструкторы XMDECN4