青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

DirectX 9的坐標系統變換

 

世界坐標系到攝影坐標系的變換

攝影坐標系的原點為世界坐標系中的觀察位置eye點,z軸與觀察方向(從eye點出發到at點的向量)一致。
由于僅由一個坐標原點的位置和一個z坐標軸的方向不足以完全確定一個坐標系,因此,還需要指定一個up向量來定位攝影坐標系的y軸方向。這個在世界坐標系中給出的up向量是不必與觀察方向垂直的,只是指明攝影坐標系應該以向上的方向還是以向下的方向作為y軸。

Builds a left-handed, look-at matrix.

D3DXMATRIX * D3DXMatrixLookAtLH(
D3DXMATRIX * pOut,
CONST D3DXVECTOR3 * pEye,
CONST D3DXVECTOR3 * pAt,
CONST D3DXVECTOR3 * pUp
);

Parameters

pOut
[in, out] Pointer to the D3DXMATRIX structure that is the result of the operation.
pEye
[in] Pointer to the D3DXVECTOR3 structure that defines the eye point. This value is used in translation.
pAt
[in] Pointer to the D3DXVECTOR3 structure that defines the camera look-at target.
pUp
[in] Pointer to the D3DXVECTOR3 structure that defines the current world's up, usually [0, 1, 0].

Return Values

Pointer to a D3DXMATRIX structure that is a left-handed, look-at matrix.

Remarks

The return value for this function is the same value returned in the pOut parameter. In this way, the D3DXMatrixLookAtLH function can be used as a parameter for another function.

This function uses the following formula to compute the returned matrix.

zaxis = normal(At - Eye)
xaxis = normal(cross(Up, zaxis))
yaxis = cross(zaxis, xaxis)

xaxis.x yaxis.x zaxis.x 0
xaxis.y yaxis.y zaxis.y 0
xaxis.z yaxis.z zaxis.z 0
-dot(xaxis, eye) -dot(yaxis, eye) -dot(zaxis, eye) 1


要正確運行以下的示例程序,需要在工程中包含d3dx9.lib,或者在main函數前加入
#pragma comment(lib, "d3dx9.lib")
以指示編譯器鏈接d3dx9.lib。

代碼示例:

#include <d3dx9math.h>
#include <stdio.h>

#pragma warning(disable : 4305)

int main()
{
    D3DXVECTOR3 p(3.0, 3.0, 3.0);       
// point with world coordinate
    D3DXVECTOR3 eye(1.0, 0.0, 0.0);     // camera position with world coordinate
    D3DXVECTOR3 at(0.0, 0.0, 0.0);      // look at target with world coordinate
    D3DXVECTOR3 up(0.0, 1.0, 0.0);      // define the current world's up

    D3DXMATRIX m;   
// transform matrix from world coordinate to camera coordinate

    // Builds a left-handed, look-at matrix.
    D3DXMatrixLookAtLH(&m, &eye, &at, &up);

    
// print out matrix
    printf("   |%f   %f    %f    %f|\n", m._11, m._12, m._13, m._14);
    printf("   |%f   %f    %f    %f|\n", m._21, m._22, m._23, m._24);
    printf("m =|%f   %f    %f    %f|\n", m._31, m._32, m._33, m._34);
    printf("   |%f   %f    %f    %f|\n", m._41, m._42, m._43, m._44);

    printf("\n\n\n");

    D3DXVec3TransformCoord(&p, &p, &m);

    printf("p(%f, %f, %f)", p.x, p.y, p.z);
    printf("\n\n\n");

    
return 0;
}

輸出:

       |0.000000   0.000000    -1.000000    0.000000|
       |-0.000000   1.000000    0.000000    0.000000|
m = |1.000000   0.000000    0.000000    0.000000|
       |-0.000000   -0.000000    1.000000    1.000000|

p(3.000000, 3.000000, -2.000000)



透視投影變換

為了顯示三維物體,必須將三維物體透視投影到平面上,以獲得一個二維的平面圖象,同時還要保存物體的深度信息(z軸上的位置信息)。

Builds a left-handed perspective projection matrix based on a field of view.

D3DXMATRIX * D3DXMatrixPerspectiveFovLH(
D3DXMATRIX * pOut,
FLOAT fovy,
FLOAT Aspect,
FLOAT zn,
FLOAT zf
);

Parameters

pOut
[in, out] Pointer to the D3DXMATRIX structure that is the result of the operation.
fovy
[in] Field of view in the y direction, in radians.
Aspect
[in] Aspect ratio, defined as view space width divided by height.
zn
[in] Z-value of the near view-plane.
zf
[in] Z-value of the far view-plane.

Return Values

Pointer to a D3DXMATRIX structure that is a left-handed perspective projection matrix.

Remarks

The return value for this function is the same value returned in the pOut parameter. In this way, the D3DXMatrixPerspectiveFovLH function can be used as a parameter for another function.

This function computes the returned matrix as shown:

xScale     0          0               0
0 yScale 0 0
0 0 zf/(zf-zn) 1
0 0 -zn*zf/(zf-zn) 0

where:
yScale = cot(fovY/2)

xScale = yScale / aspect ratio


視截體的平面計算

在世界坐標系中選擇觀察者位置,并確定視角的方向和視線的遠近距離,視截體的6個側面也就決定下來,由于三維物體一開始是在世界坐標系中給出的,因此視截體在世界坐標系中的6個平面的計算就顯得相當重要,因為可由這6個視截體的平面法向量計算出世界空間中的哪些三維物體應該顯示出來。

完全可以根據觀察者的坐標位置、觀察視角的大小和遠近平面的方位,直接計算出6個視截體平面在世界坐標系中的方程。不過,DirectX并沒有直接提供一個函數來計算這些平面的方程,但可以根據攝影變換和透視投影變換矩陣,反向計算出視截體的各個平面在世界坐標系中的方程。

世界空間中的視截體在攝影變換和透視投影變換后,變成攝影空間中的立方體[-1, 1] x [-1, 1] x [0, 1],即6個視截體平面的方程分別為x=-1,x=1,y=-1,y=1,z=0和z=1。

代碼示例:

#include <d3dx9math.h>
#include <stdio.h>

#pragma warning(disable : 4305)

int main()
{
    
// build camera reference frame
    D3DXVECTOR3 eye(0.0, 0.0, 3.0); // camera position with world coordinate
    D3DXVECTOR3 at(0.0, 0.0, 30.0); // look at target with world coordinate
    D3DXVECTOR3 up(0.0, 1.0, 3.0);  // define the current world's up

    D3DXMATRIX view_matrix; 
// transform matrix from world coordinate to camera coordinate

    // Builds a left-handed, look-at matrix.
    D3DXMatrixLookAtLH(&view_matrix, &eye, &at, &up);

    D3DXMATRIX proj_matrix;
    
// Builds a left-handed perspective projection matrix based on a field of view.
    D3DXMatrixPerspectiveFovLH(&proj_matrix, D3DX_PI/3, 2.0, 2.0, 8.0);

    printf("calculate frustum plane equation in world reference frame:\n\n");

    D3DXMATRIX M = view_matrix * proj_matrix;

    D3DXPLANE plane[6];

    plane[0].a = M._11 + M._14;
    plane[0].b = M._21 + M._24;
    plane[0].c = M._31 + M._34;
    plane[0].d = M._41 + M._44;

    D3DXPlaneNormalize(&plane[0], &plane[0]);
    printf("left plane equation: a=%f, b=%f, c=%f, d=%f\n\n", plane[0].a, plane[0].b, plane[0].c, plane[0].d);

    plane[1].a = M._14 - M._11;
    plane[1].b = M._24 - M._21;
    plane[1].c = M._34 - M._31;
    plane[1].d = M._44 - M._41; 

    D3DXPlaneNormalize(&plane[1], &plane[1]);
    printf("right plane equation: a=%f, b=%f, c=%f, d=%f\n\n", plane[1].a, plane[1].b, plane[1].c, plane[1].d);

    plane[2].a = M._14 - M._12;
    plane[2].b = M._24 - M._22;
    plane[2].c = M._34 - M._32;
    plane[2].d = M._44 - M._42;

    D3DXPlaneNormalize(&plane[2], &plane[2]);
    printf("top plane equation: a=%f, b=%f, c=%f, d=%f\n\n", plane[2].a, plane[2].b, plane[2].c, plane[2].d);

    plane[3].a = M._12 + M._14;
    plane[3].b = M._22 + M._24;
    plane[3].c = M._32 + M._34;
    plane[3].d = M._42 + M._44;

    D3DXPlaneNormalize(&plane[3], &plane[3]);
    printf("bottom plane equation: a=%f, b=%f, c=%f, d=%f\n\n", plane[3].a, plane[3].b, plane[3].c, plane[3].d);

    plane[4].a = M._13;
    plane[4].b = M._23;
    plane[4].c = M._33;
    plane[4].d = M._43;

    D3DXPlaneNormalize(&plane[4], &plane[4]);
    printf("near plane equation: a=%f, b=%f, c=%f, d=%f\n\n", plane[4].a, plane[4].b, plane[4].c, plane[4].d);

    plane[5].a = M._14 - M._13;
    plane[5].b = M._24 - M._23;
    plane[5].c = M._34 - M._33;
    plane[5].d = M._44 - M._43;

    D3DXPlaneNormalize(&plane[5], &plane[5]);
    printf("far plane equation: a=%f, b=%f, c=%f, d=%f\n\n\n\n", plane[5].a, plane[5].b, plane[5].c, plane[5].d);

    
return 0;
}

輸出:

calculate frustum plane equation in world reference frame:

left plane equation: a=0.654654, b=0.000000, c=0.755929, d=-2.267787

right plane equation: a=-0.654654, b=0.000000, c=0.755929, d=-2.267787

top plane equation: a=0.000000, b=-0.866025, c=0.500000, d=-1.500000

bottom plane equation: a=0.000000, b=0.866025, c=0.500000, d=-1.500000

near plane equation: a=0.000000, b=0.000000, c=1.000000, d=-5.000000

far plane equation: a=0.000000, b=0.000000, c=-1.000000, d=11.000000

透視投影空間到屏幕視口的變換

視截體透視投影到[-1, -1] x [-1, 1] x [0, 1]立方體后,就需要將xy平面中的二維圖像變換到計算機的屏幕視口中進行顯示,同時還將z軸[0, 1]變換為[min_z, max_z],這就是透視投影空間到視口的坐標變換。對于DirectX來說,通常取min_z = 0和max_z = 1,即維持z軸的坐標值不變。

在三維游戲開發中,一般使用D3DVIEWPORT9結構體和 IDirect3DDevice9::SetViewport Method設置視口的區域。

posted on 2008-04-16 09:45 RedLight 閱讀(690) 評論(0)  編輯 收藏 引用 所屬分類: 3D渲染技術

<2008年4月>
303112345
6789101112
13141516171819
20212223242526
27282930123
45678910

導航

統計

公告


Name: Galen
QQ: 88104725

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

相冊

My Friend

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美国产日本在线| 一区二区三区日韩欧美| 国产精品日日摸夜夜摸av| 中国成人在线视频| 一区二区三区四区五区视频| 美日韩精品免费| 久久亚洲午夜电影| 欧美99久久| 蜜桃av一区二区在线观看| 久久久久一区| 久久国产精品久久久久久| 亚洲视频一二| 久久不射中文字幕| 久久综合色一综合色88| 久久久人成影片一区二区三区| 午夜视频一区二区| 久久精品综合网| 91久久久久久国产精品| 亚洲国产欧美一区二区三区久久| 欧美成ee人免费视频| 亚洲破处大片| 欧美在线啊v一区| 欧美日本三区| 国产自产女人91一区在线观看| 激情视频一区二区三区| 中文国产一区| 欧美18av| 久久午夜羞羞影院免费观看| 欧美激情在线观看| 欧美午夜不卡在线观看免费| 国内伊人久久久久久网站视频| 亚洲国产小视频| 久久亚洲捆绑美女| 亚洲欧美一区二区精品久久久| 久久蜜桃精品| 这里只有视频精品| 欧美高清视频一二三区| 韩国三级在线一区| 欧美影院久久久| 亚洲欧美日韩中文播放| 欧美日韩免费在线视频| 亚洲午夜av| 亚洲天堂视频在线观看| 国产精品大片wwwwww| 国产精品99久久99久久久二8 | 欧美一级成年大片在线观看| 久久精品一区二区三区不卡牛牛| 国产精品高潮呻吟久久| 一区二区av在线| 亚洲午夜高清视频| 国产日产亚洲精品系列| 看片网站欧美日韩| 国产午夜精品理论片a级大结局| 亚洲一级黄色| 欧美日韩精品伦理作品在线免费观看| 狠狠爱成人网| 亚洲欧洲日本mm| 国产精品私拍pans大尺度在线| 欧美一级夜夜爽| 女生裸体视频一区二区三区| 亚洲国产小视频| 亚洲每日更新| 在线观看亚洲一区| 99亚洲视频| 亚洲乱码精品一二三四区日韩在线| 欧美日韩在线播放一区| 久久婷婷丁香| 国产精一区二区三区| 91久久精品一区二区别| 在线精品视频一区二区| 亚洲在线一区二区| 亚洲午夜女主播在线直播| 久久精品一本| 久久国产99| 国产精品一级二级三级| 日韩一级精品视频在线观看| 亚洲国产一区二区三区在线播 | 亚洲缚视频在线观看| 中文国产一区| 亚洲一区在线直播| 欧美日韩在线另类| 亚洲一区国产视频| 先锋影音久久久| 国产精品一区视频网站| 午夜精品区一区二区三| 性xx色xx综合久久久xx| 国产女人精品视频| 久久精品欧洲| 亚洲精品乱码久久久久| avtt综合网| 国产精品乱码一区二区三区| 亚洲一区二区免费| 久久精品成人| 亚洲精品日韩一| 国产精品电影网站| 久久九九全国免费精品观看| 欧美fxxxxxx另类| 亚洲欧美日韩国产| 很黄很黄激情成人| 国产精品久久久久久久久免费 | 一区在线免费观看| 欧美日韩高清在线| 欧美在线观看日本一区| 欧美激情四色| 久久精品一区二区三区四区| 日韩一区二区久久| 在线激情影院一区| 国产一区二区三区四区| 欧美成人午夜激情视频| 久久成人免费日本黄色| 一区二区三区国产精华| 欧美成人xxx| 久久在线免费观看| 欧美一级电影久久| 欧美在线观看网址综合| 亚洲视频第一页| 一区二区三区国产精品| 99精品99久久久久久宅男| 亚洲国产高清aⅴ视频| 国产日韩在线视频| 激情成人av在线| 亚洲第一在线| 99riav久久精品riav| 99视频+国产日韩欧美| 日韩视频免费观看高清在线视频| 国产在线精品一区二区中文| 国产一区二区三区日韩| 精品二区视频| 亚洲精品免费在线观看| 亚洲精品日本| 欧美一区二区在线播放| 久久精品国产久精国产一老狼| 久久成人精品无人区| 噜噜噜在线观看免费视频日韩| 久久日韩粉嫩一区二区三区| 欧美jizzhd精品欧美巨大免费| 欧美激情免费在线| 亚洲视频免费| 久久久久久久久久看片| 亚洲福利视频一区| 一本久久a久久精品亚洲| 久久国产手机看片| 欧美激情在线免费观看| 国产裸体写真av一区二区 | 欧美1区免费| 午夜精品久久久久99热蜜桃导演| 亚洲欧美日韩精品久久| 久久精品欧洲| 久久婷婷国产综合精品青草| 麻豆久久精品| 欧美激情一区二区| 久久久av网站| 国产视频一区在线| 亚洲在线网站| 亚洲特级片在线| 国产精品爱啪在线线免费观看| 尤物yw午夜国产精品视频明星 | 欧美伦理在线观看| 国产伊人精品| 久久久久久高潮国产精品视| 在线一区观看| 国产日韩精品视频一区| 久久精品99| 久久综合精品国产一区二区三区| 国产一区二区你懂的| 久久久青草婷婷精品综合日韩 | 日韩视频免费观看| 欧美激情在线观看| 亚洲午夜三级在线| 欧美一区2区三区4区公司二百| 国产主播一区二区三区| 欧美激情一区二区| 国产伦精品一区二区三区免费 | 国产日韩欧美高清| 性久久久久久| 蜜臀av国产精品久久久久| 亚洲精品中文字幕在线| 一区二区三区视频在线观看| 国产视频一区在线| 亚洲国产精品欧美一二99| 欧美三区美女| 免费在线亚洲| 国产一区二区在线观看免费播放 | 亚洲国产欧美一区| 国产精品视频免费观看| 欧美1区2区3区| 国产一区久久久| 99精品欧美一区二区三区| 国产深夜精品福利| 中文精品视频| 99国内精品久久| 欧美日韩国产黄| 91久久综合亚洲鲁鲁五月天| 国产亚洲一区二区精品| 亚洲欧美变态国产另类| 午夜综合激情| 国产亚洲欧美日韩美女| 亚洲一区二区免费视频| 久久aⅴ国产紧身牛仔裤| 国产精品久久7|