Funzione D3DXMatrixPerspectiveFovRH (D3dx9math.h)
Nota
La libreria di utilità D3DX è deprecata. È consigliabile usare invece DirectXMath .
Crea una matrice di proiezione prospettica destrorsa basata su un campo visivo.
Sintassi
D3DXMATRIX* D3DXMatrixPerspectiveFovRH(
_Inout_ D3DXMATRIX *pOut,
_In_ FLOAT fovy,
_In_ FLOAT Aspect,
_In_ FLOAT zn,
_In_ FLOAT zf
);
Parametri
-
pOut [in, out]
-
Tipo: D3DXMATRIX*
Puntatore alla struttura D3DXMATRIX risultante dall'operazione.
-
fovy [in]
-
Tipo: FLOAT
Campo di visualizzazione nella direzione y, in radianti.
-
Aspetto [in]
-
Tipo: FLOAT
Proporzioni, definite come larghezza dello spazio di visualizzazione diviso per altezza.
-
zn [in]
-
Tipo: FLOAT
Valore Z del piano di visualizzazione vicino.
-
zf [in]
-
Tipo: FLOAT
Valore Z del piano di visualizzazione lontano.
Valore restituito
Tipo: D3DXMATRIX*
Puntatore a una struttura D3DXMATRIX che è una matrice di proiezione prospettica destra.
Commenti
Il valore restituito per questa funzione è lo stesso valore restituito nel parametro pOut . In questo modo, la funzione D3DXMatrixPerspectiveFovRH può essere usata come parametro per un'altra funzione.
Per modificare l'asse delle proporzioni, usare la formula di calcolo: fovy = 2 * math.atan(math.tan(fovy * 0,5) / aspetto). In alternativa, aggiungere variabili delle proporzioni X e Y nella struttura per ridimensionare lo spazio di visualizzazione verticale: fovy = 2 * math.atan(math.tan(fovy * 0,5) / aspectY), aspect = aspectX * aspetto Y.
Questa funzione calcola la matrice restituita come illustrato.
xScale 0 0 0
0 yScale 0 0
0 0 zf/(zn-zf) -1
0 0 zn*zf/(zn-zf) 0
where:
yScale = cot(fovY/2)
xScale = yScale / aspect ratio
Requisiti
Requisito | Valore |
---|---|
Intestazione |
|
Libreria |
|
Vedi anche