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

天行健 君子當(dāng)自強(qiáng)而不息

DirectX 9的坐標(biāo)系統(tǒng)變換

HTML clipboard HTML clipboard  

世界坐標(biāo)系到攝影坐標(biāo)系的變換

攝影坐標(biāo)系的原點(diǎn)為世界坐標(biāo)系中的觀察位置eye點(diǎn),z軸與觀察方向(從eye點(diǎn)出發(fā)到at點(diǎn)的向量)一致。
由于僅由一個(gè)坐標(biāo)原點(diǎn)的位置和一個(gè)z坐標(biāo)軸的方向不足以完全確定一個(gè)坐標(biāo)系,因此,還需要指定一個(gè)up向量來定位攝影坐標(biāo)系的y軸方向。這個(gè)在世界坐標(biāo)系中給出的up向量是不必與觀察方向垂直的,只是指明攝影坐標(biāo)系應(yīng)該以向上的方向還是以向下的方向作為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


要正確運(yùn)行以下的示例程序,需要在工程中包含d3dx9.lib,或者在main函數(shù)前加入
#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)



透視投影變換

為了顯示三維物體,必須將三維物體透視投影到平面上,以獲得一個(gè)二維的平面圖象,同時(shí)還要保存物體的深度信息(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


視截體的平面計(jì)算

在世界坐標(biāo)系中選擇觀察者位置,并確定視角的方向和視線的遠(yuǎn)近距離,視截體的6個(gè)側(cè)面也就決定下來,由于三維物體一開始是在世界坐標(biāo)系中給出的,因此視截體在世界坐標(biāo)系中的6個(gè)平面的計(jì)算就顯得相當(dāng)重要,因?yàn)榭捎蛇@6個(gè)視截體的平面法向量計(jì)算出世界空間中的哪些三維物體應(yīng)該顯示出來。

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

世界空間中的視截體在攝影變換和透視投影變換后,變成攝影空間中的立方體[-1, 1] x [-1, 1] x [0, 1],即6個(gè)視截體平面的方程分別為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平面中的二維圖像變換到計(jì)算機(jī)的屏幕視口中進(jìn)行顯示,同時(shí)還將z軸[0, 1]變換為[min_z, max_z],這就是透視投影空間到視口的坐標(biāo)變換。對于DirectX來說,通常取min_z = 0和max_z = 1,即維持z軸的坐標(biāo)值不變。

在三維游戲開發(fā)中,一般使用D3DVIEWPORT9結(jié)構(gòu)體和 IDirect3DDevice9::SetViewport Method設(shè)置視口的區(qū)域。

 
 

posted on 2007-05-04 02:09 lovedday 閱讀(3741) 評論(0)  編輯 收藏 引用 所屬分類: ■ DirectX 9 Program

公告

導(dǎo)航

統(tǒng)計(jì)

常用鏈接

隨筆分類(178)

3D游戲編程相關(guān)鏈接

搜索

最新評論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产高清视频| 亚洲国产一区二区视频| 欧美一区2区三区4区公司二百| 欧美aa在线视频| 亚洲国产免费| 亚洲欧洲精品一区二区精品久久久| 亚洲视频电影在线| 国产麻豆综合| 欧美 日韩 国产一区二区在线视频 | 欧美片网站免费| 亚洲一区久久| 亚洲第一搞黄网站| 亚洲激情精品| 亚洲一区综合| 久久久免费精品视频| 在线视频你懂得一区| 美女啪啪无遮挡免费久久网站| 亚洲黄一区二区三区| 国产精品人人做人人爽人人添| 老**午夜毛片一区二区三区| 亚洲午夜一区二区| 亚洲精品一区在线观看香蕉| 久久国产精品黑丝| av成人免费观看| 影音先锋在线一区| 欧美影院在线播放| 在线观看国产一区二区| 欧美精品一卡| 欧美一区成人| 欧美**字幕| 国产亚洲欧洲997久久综合| 欧美欧美在线| 国产日本亚洲高清| 国产精品素人视频| 亚洲国产专区校园欧美| 欧美亚洲综合另类| 午夜精品福利在线| 中文国产成人精品久久一| 久久国产手机看片| 亚洲欧美在线看| 亚洲丁香婷深爱综合| 亚洲欧美成人一区二区在线电影| 在线亚洲一区二区| 蜜桃av一区二区| 欧美大片网址| 欧美日韩在线一区| 欧美极品欧美精品欧美视频| 国产一区二区无遮挡| 亚洲欧美卡通另类91av | 欧美精品三级日韩久久| 一区视频在线播放| 亚洲精品视频在线观看免费| 亚洲精品欧美日韩专区| 久久一区亚洲| 欧美激情国产日韩| 亚洲精品一区中文| 欧美日本一道本在线视频| 91久久在线播放| av成人天堂| 亚洲三级性片| 亚洲在线一区二区| 国产精品久久久久久久9999| 国内精品久久久久影院 日本资源| 狠狠久久综合婷婷不卡| 亚洲电影免费| 亚洲一区二区三区四区五区午夜| 亚洲欧美经典视频| 夜夜嗨网站十八久久| 久久精品亚洲一区二区三区浴池| 牛牛影视久久网| 亚洲国产精品嫩草影院| av成人手机在线| 亚洲精品欧美专区| 欧美日韩亚洲综合一区| 狠狠v欧美v日韩v亚洲ⅴ| 久久久久久久999| 亚洲电影免费观看高清完整版在线观看 | 99xxxx成人网| 欧美另类久久久品 | 麻豆精品视频| 夜夜嗨一区二区三区| 欧美私人网站| 欧美一区二区三区在线看| 91久久精品美女| 欧美色图五月天| 久久成人亚洲| 欧美成人久久| 欧美一区二区三区啪啪| 狼人社综合社区| 亚洲欧洲av一区二区| 久久亚洲不卡| 好看的日韩视频| 亚洲黄色一区| 国产精品一区二区在线| 免费日韩精品中文字幕视频在线| 欧美国产日韩精品免费观看| 国产一区日韩二区欧美三区| 久久综合中文色婷婷| 欧美国产日本| 久久久国产精品一区二区三区| 老色鬼久久亚洲一区二区| 一区二区三区欧美视频| 亚洲精品一区在线观看| 韩日精品视频| 在线视频精品一区| 亚洲成人在线视频播放| 亚洲午夜成aⅴ人片| 亚洲人午夜精品免费| 欧美一区午夜精品| 中文日韩在线视频| 美乳少妇欧美精品| 久久精品人人做人人爽| 国产精品vip| 亚洲在线视频网站| 一本久久a久久精品亚洲| 欧美日韩一区二区欧美激情| 久久中文欧美| 国产精品最新自拍| 亚洲毛片在线看| 亚洲高清免费在线| 欧美一区二区大片| 欧美一区二区在线免费观看| 欧美日韩在线电影| 亚洲精品美女久久7777777| 伊人久久大香线蕉av超碰演员| 亚洲影视在线| 性8sex亚洲区入口| 欧美无乱码久久久免费午夜一区| 亚洲电影在线| 亚洲麻豆视频| 亚洲性感激情| 国产精品99久久久久久宅男| 欧美韩日亚洲| 91久久线看在观草草青青| 亚洲精品免费电影| 欧美成人免费在线视频| 亚洲国产一区二区三区高清| 亚洲精品久久久久久一区二区| 麻豆精品一区二区综合av| 欧美成人午夜激情在线| 亚洲精品黄色| 免费观看久久久4p| 国产精品一区二区三区乱码| 一本色道久久综合亚洲91| 99精品欧美| 亚洲欧洲一二三| 亚洲国产精品久久91精品| 久久久99爱| 欧美aa国产视频| 欧美午夜电影在线观看| 亚洲精品久久久久久久久| 亚洲无限av看| 国产啪精品视频| 久久一区二区三区av| 亚洲国产一区二区三区在线播 | 亚洲三级观看| 欧美精品久久久久a| 一区二区三区视频观看| 久久成人精品| 亚洲国产一区二区三区高清| 欧美激情一区三区| 亚洲午夜激情| 久久婷婷av| 日韩视频中文| 国产啪精品视频| 女同性一区二区三区人了人一| 一本色道久久88亚洲综合88| 久久精品二区亚洲w码| 亚洲黄色在线看| 欧美视频在线观看 亚洲欧| 久久riav二区三区| 亚洲精品欧美专区| 久久人人超碰| 国产欧美日韩精品一区| 久久久青草青青国产亚洲免观| 亚洲激情偷拍| 久久国产乱子精品免费女| 亚洲精品久久久久久久久久久久久 | 国产美女精品视频免费观看| 久久亚洲精选| 亚洲与欧洲av电影| 亚洲国产另类久久久精品极度| 亚洲一区国产精品| 亚洲精华国产欧美| 国产欧美在线看| 欧美日韩在线视频观看| 老牛影视一区二区三区| 香蕉成人伊视频在线观看| 性欧美xxxx视频在线观看| 亚洲福利精品| 国产日韩欧美综合精品| 亚洲自拍三区| 亚洲国产天堂久久综合| 久久一综合视频| 欧美一区视频| 亚洲一区图片| aaa亚洲精品一二三区| 亚洲欧洲日韩在线| 妖精视频成人观看www| 亚洲第一精品久久忘忧草社区|