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

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

Direct3D中的繪制(3)

立方體——只比三角形稍微復(fù)雜一點(diǎn),這個(gè)程序渲染一個(gè)線框立方體。

這個(gè)簡(jiǎn)單的繪制和渲染立方體的程序的運(yùn)行結(jié)果如下圖所示:

 

源程序:

/**************************************************************************************
  Renders a spinning cube in wireframe mode.  Demonstrates vertex and index buffers, 
  world and view transformations, render states and drawing commands.
 *************************************************************************************
*/

#include 
"d3dUtility.h"

#pragma warning(disable : 
4100)

const int WIDTH  = 640;
const int HEIGHT = 480;

IDirect3DDevice9
*        g_d3d_device    = NULL;
IDirect3DVertexBuffer9
*    g_vertex_buffer = NULL;
IDirect3DIndexBuffer9
*    g_index_buffer    = NULL;

class cVertex
{
public:
    
float m_x, m_y, m_z;

    cVertex() {}

    cVertex(
float x, float y, float z)
    {
        m_x 
= x;
        m_y 
= y;
        m_z 
= z;
    }
};

const DWORD VERTEX_FVF = D3DFVF_XYZ;

////////////////////////////////////////////////////////////////////////////////////////////////////

bool setup()
{    
    g_d3d_device
->CreateVertexBuffer(8 * sizeof(cVertex), D3DUSAGE_WRITEONLY, VERTEX_FVF, 
                                     D3DPOOL_MANAGED, 
&g_vertex_buffer, NULL);

    g_d3d_device
->CreateIndexBuffer(36 * sizeof(WORD), D3DUSAGE_WRITEONLY, D3DFMT_INDEX16,
                                    D3DPOOL_MANAGED, 
&g_index_buffer, NULL);

    
// fill the buffers with the cube data

    cVertex
* vertices;
    g_vertex_buffer
->Lock(00, (void**)&vertices, 0);
    
    
// vertices of a unit cube
    vertices[0= cVertex(-1.0f-1.0f-1.0f);
    vertices[
1= cVertex(-1.0f,  1.0f-1.0f);
    vertices[
2= cVertex( 1.0f,  1.0f-1.0f);
    vertices[
3= cVertex( 1.0f-1.0f-1.0f);
    vertices[
4= cVertex(-1.0f-1.0f,  1.0f);
    vertices[
5= cVertex(-1.0f,  1.0f,  1.0f);
    vertices[
6= cVertex( 1.0f,  1.0f,  1.0f);
    vertices[
7= cVertex( 1.0f-1.0f,  1.0f);

    g_vertex_buffer
->Unlock();

    
// define the triangles of the cube
    WORD* indices = NULL;
    g_index_buffer
->Lock(00, (void**)&indices, 0);

    
// front side
    indices[0]  = 0; indices[1]  = 1; indices[2]  = 2;
    indices[
3]  = 0; indices[4]  = 2; indices[5]  = 3;

    
// back side
    indices[6]  = 4; indices[7]  = 6; indices[8]  = 5;
    indices[
9]  = 4; indices[10= 7; indices[11= 6;

    
// left side
    indices[12= 4; indices[13= 5; indices[14= 1;
    indices[
15= 4; indices[16= 1; indices[17= 0;

    
// right side
    indices[18= 3; indices[19= 2; indices[20= 6;
    indices[
21= 3; indices[22= 6; indices[23= 7;

    
// top
    indices[24= 1; indices[25= 5; indices[26= 6;
    indices[
27= 1; indices[28= 6; indices[29= 2;

    
// bottom
    indices[30= 4; indices[31= 0; indices[32= 3;
    indices[
33= 4; indices[34= 3; indices[35= 7;

    g_index_buffer
->Unlock();

    
// position and aim the camera

    D3DXVECTOR3 position(
0.0f0.0f-5.0f);
    D3DXVECTOR3 target(
0.0f0.0f0.0f);
    D3DXVECTOR3 up(
0.0f1.0f0.0f);

    D3DXMATRIX view_matrix;
    D3DXMatrixLookAtLH(
&view_matrix, &position, &target, &up);

    g_d3d_device
->SetTransform(D3DTS_VIEW, &view_matrix);

    
// set the projection matrix
    D3DXMATRIX proj;
    D3DXMatrixPerspectiveFovLH(
&proj, D3DX_PI * 0.5f, (float)WIDTH/HEIGHT, 1.0f1000.0f);
    g_d3d_device
->SetTransform(D3DTS_PROJECTION, &proj);

    
// set wireframe mode render state
    g_d3d_device->SetRenderState(D3DRS_FILLMODE, D3DFILL_WIREFRAME);

    
return true;
}

void cleanup()
{
    safe_release
<IDirect3DVertexBuffer9*>(g_vertex_buffer);
    safe_release
<IDirect3DIndexBuffer9*>(g_index_buffer);
}

bool display(float time_delta)
{
    
// spin the cube

    D3DXMATRIX rx, ry;

    
// rotate 45 degree on x-axis
    D3DXMatrixRotationX(&rx, 3.14f/4.0f);

    
// increment y-rotation angle each frame
    static float y = 0.0f;
    D3DXMatrixRotationY(
&ry, y);
    y 
+= time_delta;

    
// reset angle to zero when angle reaches 2*PI
    if(y >= 6.28f)
        y 
= 0.0f;

    
// combine x and y axis ratation transformations
    D3DXMATRIX rxy = rx * ry;

    g_d3d_device
->SetTransform(D3DTS_WORLD, &rxy);

    
// draw the scene

    g_d3d_device
->Clear(0, NULL, D3DCLEAR_TARGET | D3DCLEAR_ZBUFFER, 0xffffffff1.0f0);

    g_d3d_device
->BeginScene();

    g_d3d_device
->SetStreamSource(0, g_vertex_buffer, 0sizeof(cVertex));
    g_d3d_device
->SetIndices(g_index_buffer);
    g_d3d_device
->SetFVF(VERTEX_FVF);

    
// draw cube
    g_d3d_device->DrawIndexedPrimitive(D3DPT_TRIANGLELIST, 008012);

    g_d3d_device
->EndScene();

    g_d3d_device
->Present(NULL, NULL, NULL, NULL);

    
return true;
}

LRESULT CALLBACK wnd_proc(HWND hwnd, UINT msg, WPARAM word_param, LPARAM long_param)
{
    
switch(msg)
    {
    
case WM_DESTROY:
        PostQuitMessage(
0);
        
break;

    
case WM_KEYDOWN:
        
if(word_param == VK_ESCAPE)
            DestroyWindow(hwnd);
        
break;
    }

    
return DefWindowProc(hwnd, msg, word_param, long_param);
}

int WINAPI WinMain(HINSTANCE inst, HINSTANCE, PSTR cmd_line, int cmd_show)
{
    
if(! init_d3d(inst, WIDTH, HEIGHT, true, D3DDEVTYPE_HAL, &g_d3d_device))
    {
        MessageBox(NULL, 
"init_d3d() - failed."0, MB_OK);
        
return 0;
    }

    
if(! setup())
    {
        MessageBox(NULL, 
"Steup() - failed."0, MB_OK);
        
return 0;
    }

    enter_msg_loop(display);

    cleanup();
    g_d3d_device
->Release();

    
return 0;
}

 

setup函數(shù)創(chuàng)建頂點(diǎn)和索引緩存,鎖定它們,把構(gòu)成立方體的頂點(diǎn)寫(xiě)入頂點(diǎn)緩存,以及把定義立方體的三角形的索引寫(xiě)入索引緩存。然后把攝象機(jī)向后移動(dòng)幾個(gè)單位以便我們能夠看見(jiàn)在世界坐標(biāo)系中原點(diǎn)處被渲染的立方體。

 

display方法有兩個(gè)任務(wù);它必須更新場(chǎng)景并且緊接著渲染它。既然想旋轉(zhuǎn)立方體,那么我們將對(duì)每一幀增加一個(gè)角度使立方體能在這一幀旋轉(zhuǎn)。對(duì)于這每一幀,立方體將被旋轉(zhuǎn)一個(gè)很小的角度,這樣我們看起來(lái)旋轉(zhuǎn)就會(huì)更平滑。接著我們使用IDirect3DDevice9::DrawIndexedPrimitive方法來(lái)繪制立方體。

 

最后,我們釋放使用過(guò)的所有內(nèi)存。這意味著釋放頂點(diǎn)和索引緩存接口。

 

下載立方體演示程序


posted on 2008-03-14 14:48 lovedday 閱讀(589) 評(píng)論(0)  編輯 收藏 引用


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


公告

導(dǎo)航

統(tǒng)計(jì)

常用鏈接

隨筆分類(178)

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

搜索

最新評(píng)論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 欧美二区在线| 美女主播精品视频一二三四| 美日韩精品免费观看视频| 老司机免费视频一区二区三区| 久久se精品一区精品二区| 久久久免费av| 欧美成人自拍视频| 亚洲伦理在线免费看| 一二三四社区欧美黄| 亚洲欧美一区二区三区极速播放 | 亚洲美女少妇无套啪啪呻吟| 亚洲精品资源| 欧美一区日本一区韩国一区| 欧美在线视频日韩| 亚洲精品视频免费| 99re热这里只有精品免费视频| 日韩午夜在线电影| 亚洲影院色无极综合| 久久久久国内| 亚洲精品一区二区在线观看| 午夜精品久久久久久久99水蜜桃 | 一区二区三区精品国产| 午夜免费在线观看精品视频| 蜜桃av一区| 一区二区日韩| 男男成人高潮片免费网站| 国产精品乱码久久久久久| 亚洲国产影院| 久久免费99精品久久久久久| 亚洲久久一区| 久久综合九色综合网站| 国产精品入口66mio| 亚洲欧洲偷拍精品| 久久精品30| 亚洲天堂av在线免费观看| 老司机精品久久| 国产日韩欧美在线视频观看| 亚洲视频一区二区| 亚洲高清不卡| 久久精品在线| 国产日韩综合一区二区性色av| 99riav久久精品riav| 奶水喷射视频一区| 性欧美在线看片a免费观看| 欧美日韩在线视频观看| 亚洲国产精品综合| 看欧美日韩国产| 欧美专区中文字幕| 国产色产综合产在线视频| 午夜视频在线观看一区二区| 亚洲精品色婷婷福利天堂| 欧美韩日高清| 亚洲美女毛片| 亚洲美女视频在线免费观看| 欧美高清在线| 一区二区av在线| 夜夜嗨av一区二区三区四区| 欧美日韩一级片在线观看| 一本色道久久综合亚洲精品高清| 亚洲高清二区| 欧美日韩伦理在线| 亚洲在线网站| 翔田千里一区二区| 韩日欧美一区二区| 免费观看一区| 欧美精品日韩三级| 亚洲视频中文字幕| 欧美日韩国产精品自在自线| 女女同性女同一区二区三区91| 狠狠色丁香久久婷婷综合丁香| 欧美专区在线| 久久精品一区中文字幕| 亚洲第一偷拍| 亚洲日本成人网| 欧美日韩亚洲系列| 午夜精品久久久久久| 欧美一区二区三区免费视频| 激情久久久久久| 欧美成人午夜影院| 欧美精品123区| 亚洲欧美国产另类| 久久久久久香蕉网| 日韩视频免费大全中文字幕| 亚洲一区二区三区中文字幕| 狠狠色丁香婷婷综合| 亚洲人成人一区二区三区| 欧美视频精品一区| 久久久亚洲精品一区二区三区| 麻豆91精品| 亚洲女爱视频在线| 久久久精品欧美丰满| 999亚洲国产精| 午夜免费日韩视频| 日韩午夜三级在线| 欧美在线观看一二区| 日韩天堂av| 欧美中文字幕在线播放| 在线视频欧美精品| 久久精品欧美日韩精品| 一本久道综合久久精品| 欧美亚洲免费电影| 99热精品在线观看| 久久一二三四| 欧美在线啊v| 欧美日韩午夜在线| 欧美大片一区二区| 国产三级欧美三级日产三级99| 亚洲精品极品| 91久久精品美女| 久久久久国色av免费观看性色| 亚洲免费网址| 欧美日韩xxxxx| 米奇777在线欧美播放| 国产日韩精品在线观看| 日韩一级视频免费观看在线| 亚洲精品一区二区三区四区高清 | 久久国产夜色精品鲁鲁99| 欧美日韩福利视频| 久久一区激情| 国产亚洲精品久久久久久| 99国产成+人+综合+亚洲欧美| 亚洲国产欧美在线| 久久精品一本| 久久天天狠狠| 国模 一区 二区 三区| 亚洲欧美变态国产另类| 亚洲综合日本| 国产精品成av人在线视午夜片| 亚洲精品日韩在线| 亚洲国产天堂久久综合网| 黄色成人精品网站| 亚洲欧洲午夜| 亚洲欧洲精品一区二区三区| 欧美亚洲免费高清在线观看| 欧美中在线观看| 国产乱码精品一区二区三区五月婷 | 国产日韩精品一区| 亚洲视频免费| 午夜免费久久久久| 国产精品视频第一区| 亚洲欧美精品中文字幕在线| 欧美一区二区精美| 国产亚洲精品久久久久久| 久久精品国产久精国产思思| 久久免费视频在线| 亚洲二区视频在线| 欧美激情中文不卡| 亚洲每日在线| 亚洲欧美中文日韩在线| 国产乱子伦一区二区三区国色天香| 午夜精品久久久久久久久久久久久| 久久久久久9| 亚洲青色在线| 国产精品久久久99| 久久久久国产精品www| 欧美韩国在线| 亚洲视频香蕉人妖| 国产日韩欧美一区二区三区四区| 久久综合给合久久狠狠狠97色69| 亚洲国产精品va| 亚洲男人第一av网站| 国内成+人亚洲| 欧美大片18| 亚洲男女自偷自拍图片另类| 免播放器亚洲一区| 亚洲天堂av高清| 国产一区二区黄| 欧美福利视频网站| 午夜精品久久久久久久99热浪潮 | 午夜精品久久久久久久白皮肤| 国内精品久久久久久久影视麻豆 | 亚洲欧美另类国产| 欧美大尺度在线| 欧美一区二区三区四区视频| 在线成人激情| 国产精品免费视频观看| 欧美成人中文字幕| 午夜精品一区二区在线观看| 亚洲黄页一区| 久久人人97超碰国产公开结果 | 亚洲自拍偷拍福利| 欧美在线观看天堂一区二区三区| 国内精品久久久久伊人av| 免费在线观看日韩欧美| 亚洲视频自拍偷拍| 欧美1区免费| 久久国产精品久久久久久电车| 最新国产乱人伦偷精品免费网站| 国产精品萝li| 欧美黄色影院| 久久久久国产精品麻豆ai换脸| 99re66热这里只有精品4| 蜜桃av噜噜一区二区三区| 欧美一区二区在线免费播放| 一区二区欧美视频| 亚洲激情视频在线观看| 一区视频在线播放| 国产午夜精品全部视频播放|