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


Функция D3DXMatrixAffineTransformation (D3dx9math.h)

Примечание

Служебная библиотека D3DX устарела. Вместо этого рекомендуется использовать DirectXMath .

Создает матрицу трехмерного аффинного преобразования. Аргументы NULL обрабатываются как преобразования удостоверений.

Синтаксис

D3DXMATRIX* D3DXMatrixAffineTransformation(
  _Inout_       D3DXMATRIX     *pOut,
  _In_          FLOAT          Scaling,
  _In_    const D3DXVECTOR3    *pRotationCenter,
  _In_    const D3DXQUATERNION *pRotation,
  _In_    const D3DXVECTOR3    *pTranslation
);

Параметры

pOut [in, out]

Тип: D3DXMATRIX*

Указатель на структуру D3DXMATRIX , которая является результатом операции.

Масштабирование [в]

Тип: FLOAT

Коэффициент масштабирования.

pRotationCenter [in]

Тип: const D3DXVECTOR3*

Указатель на структуру D3DXVECTOR3 , точку, определяющую центр поворота. Если этот аргумент имеет значение NULL, к формуле в примечаниях применяется матрицаrc identity M.

pRotation [in]

Тип: const D3DXQUATERNION*

Указатель на структуру D3DXQUATERNION , указывающую поворот. Если этот аргумент имеет значение NULL, к формуле в примечаниях применяется матрица идентификатора Mr .

pTranslation [in]

Тип: const D3DXVECTOR3*

Указатель на структуру D3DXVECTOR3 , представляющую перевод. Если этот аргумент имеет значение NULL, к формуле в примечаниях применяется матрица удостоверений Mt.

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

Тип: D3DXMATRIX*

Указатель на структуру D3DXMATRIX , которая является матрицей аффинного преобразования.

Комментарии

Эта функция вычисляет матрицу аффинного преобразования с помощью следующей формулы, при этом объединение матриц вычисляется в порядке слева направо:

Mout = Ms * (Mrc)⁻¹ * Mr * Mrc * Mt

где:

Mout = матрица вывода (pOut)

Ms = матрица масштабирования (масштабирование)

Mrc = центр матрицы поворота (pRotationCenter)

Mr = матрица поворота (pRotation)

Mt = матрица перевода (pTranslation)

Возвращаемое значение для этой функции совпадает с значением, возвращаемым в параметре pOut. Таким образом, функцию D3DXMatrixAffineTransformation можно использовать в качестве параметра для другой функции.

Для двухмерных аффинных преобразований используйте D3DXMatrixAffineTransformation2D.

Требования

Требование Значение
Заголовок
D3dx9math.h
Библиотека
D3dx9.lib

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

Математические функции

D3DXMatrixTransformation

Преобразования (Direct3D 9)