XMMatrixPerspectiveFovLH function (directxmath.h)
Builds a left-handed perspective projection matrix based on a field of view.
Syntax
XMMATRIX XM_CALLCONV XMMatrixPerspectiveFovLH(
[in] float FovAngleY,
[in] float AspectRatio,
[in] float NearZ,
[in] float FarZ
) noexcept;
Parameters
[in] FovAngleY
Top-down field-of-view angle in radians.
[in] AspectRatio
Aspect ratio of view-space X:Y.
[in] NearZ
Distance to the near clipping plane. Must be greater than zero.
[in] FarZ
Distance to the far clipping plane. Must be greater than zero.
Return value
Returns the perspective projection matrix.
Remarks
For typical usage, NearZ is less than FarZ. However, if you flip these values so FarZ is less than NearZ, the result is an inverted z buffer (also known as a "reverse z buffer") which can provide increased floating-point precision.
NearZ and FarZ cannot be the same value and must be greater than 0.
The default AspectRatio axis is horizontal, but recalculating FovAngleY with AspectRatio controls the view scale direction: 2.0 * atan(tan(FovAngleY * 0.5) / AspectRatio).
Platform Requirements
Microsoft Visual Studio 2010 or Microsoft Visual Studio 2012 with the Windows SDK for Windows 8. Supported for Win32 desktop apps, Windows Store apps, and Windows Phone 8 apps.Requirements
Requirement | Value |
---|---|
Target Platform | Windows |
Header | directxmath.h |