• <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>

            永遠也不完美的程序

            不斷學習,不斷實踐,不斷的重構……

            常用鏈接

            統計

            積分與排名

            好友鏈接

            最新評論

            用DirectX寫的Skybox

                    實現原理:設置5個面,即前、后、左、右、上5個,每個面4個頂點,共20個頂點,然后對每個面貼圖,行走時,skybox與行走做相同的操作。下面一步步實現:
            首先給出skybox的定義:
            class CSkybox
            {
            //
            //以下是基礎數據
            private:
                D3DXMATRIXA16 m_matWorld;     
            //世界矩陣 

                LPDIRECT3DTEXTURE9      m_pSideTexture[
            6];   //skybox的6個面的紋理
                D3DXVECTOR3             m_vSize;  
            // z, x, y分別為長,寬,高
                D3DXVECTOR3             m_vPos;   
            // skybox的中心點
                D3DXVECTOR3             m_vPosOrgin;   
            //原始點
            }

                    1、設置skybox的大小和位置,即設置盒子的長寬高。
            //設置位置
            void  SetBoxPos(
            const D3DXVECTOR3& vPos)
            {
                m_vPos 
            = vPos;          //當前點
                m_vPosOrgin 
            = m_vPos;   //原始點
            }

            void SetBoxSize(
            const D3DXVECTOR3& vSize)
            {
                m_vSize 
            = vSize;
            }

                    2、創建頂點緩沖,頂點的位置要根據第一步的盒子大小創建。
            實際上我只用了兩張紋理,從CG模型網下載的古墓麗影的天空盒紋理,所以創建紋理坐標時是0.5。
            BOOL CSkyBox::CreateVertexBuffer(LPDIRECT3DDEVICE9 p3DDevice9)
            {
                float fWidth 
            = m_vSize.x;
                float fLength 
            = m_vSize.z;
                float fHeight 
            = m_vSize.y;

                
            //確定8個點
                
            //上面的左上角
                D3DXVECTOR3 vTTopLeft(m_vPos.x 
            - fWidth / 2, m_vPos.y + fHeight / 2, fLength / 2 - m_vPos.z);
                D3DXVECTOR3 vTTopRight(fWidth 
            / 2 - m_vPos.x, m_vPos.y + fHeight / 2, fLength / 2 - m_vPos.z);
                D3DXVECTOR3 vTBottomLeft(m_vPos.x 
            - fWidth / 2, m_vPos.y + fHeight / 2, m_vPos.z - fLength / 2);
                D3DXVECTOR3 vTBottomRight(fWidth 
            / 2 - m_vPos.x, m_vPos.y + fHeight / 2, m_vPos.z - fLength / 2);

                
            //下面
                D3DXVECTOR3 vBTopLeft(m_vPos.x 
            - fWidth / 2, m_vPos.y - fHeight / 2, fLength / 2 - m_vPos.z);
                D3DXVECTOR3 vBTopRight(fWidth 
            / 2 - m_vPos.x, m_vPos.y - fHeight / 2, fLength / 2 - m_vPos.z);
                D3DXVECTOR3 vBBottomLeft(m_vPos.x 
            - fWidth / 2, m_vPos.y - fHeight / 2, m_vPos.z - fLength / 2);
                D3DXVECTOR3 vBBottomRight(fWidth 
            / 2 - m_vPos.x, m_vPos.y - fHeight / 2, m_vPos.z - fLength / 2);

                CUSTOMVERTEX_TXT cvVertices[] 
            =
                {
                    
            //上面的點
                    {vTBottomLeft, D3DCOLOR_XRGB(
            25500), 0.0f, 0.0f,}, //Vertex 2 - Red
                    {vTBottomRight, D3DCOLOR_XRGB(
            2552550), 1.0f, 0.0f,}, //Vertex 3 - Green
                    {vTTopLeft, D3DCOLOR_XRGB(
            255255255), 0.0f, 1.0f,}, //Vertex 1 - Red 
                    {vTTopRight, D3DCOLOR_XRGB(
            255255255), 1.0f, 1.0f,}, //Vertex 0 - Blue 

                    
            //前面
                    {vTTopLeft, D3DCOLOR_XRGB(
            255255255), 0.0f, 0.0f,}, //Vertex 0 - Blue 
                    {vTTopRight, D3DCOLOR_XRGB(
            255255255), 0.5f, 0.0f,}, //Vertex 1 - Red 
                    {vBTopLeft, D3DCOLOR_XRGB(
            255255255), 0.0f, 1.0f,}, //Vertex 2 - Red 
                    {vBTopRight, D3DCOLOR_XRGB(
            255255255), 0.5f, 1.0f,}, //Vertex 3 - Green 

                    
            //右面
                    {vTTopRight, D3DCOLOR_XRGB(
            255255255), 0.5f, 0.0f,}, //Vertex 0 - Blue
                    {vTBottomRight, D3DCOLOR_XRGB(
            02550), 1.0f, 0.0f,}, //Vertex 3 - Green
                    {vBTopRight, D3DCOLOR_XRGB(
            25500), 0.5f, 1.0f,}, //Vertex 2 - Red 
                    {vBBottomRight, D3DCOLOR_XRGB(
            255255255), 1.0f, 1.0f,}, //Vertex 1 - Red 


                    
            //后面
                    {vTBottomRight, D3DCOLOR_XRGB(
            255255255), 0.0f, 0.0f,}, //Vertex 0 - Blue
                    {vTBottomLeft, D3DCOLOR_XRGB(
            255255255), 0.5f, 0.0f,}, //Vertex 0 - Blue
                    {vBBottomRight, D3DCOLOR_XRGB(
            255255255), 0.0f, 1.0f,}, //Vertex 1 - Red 
                    {vBBottomLeft, D3DCOLOR_XRGB(
            255255255), 0.5f, 1.0f,}, //Vertex 1 - Red 

                    
            //左面
                    {vTBottomLeft, D3DCOLOR_XRGB(
            255255255), 0.5f, 0.0f,}, //Vertex 0 - Blue 
                    {vTTopLeft, D3DCOLOR_XRGB(
            255255255), 1.0f, 0.0f,}, //Vertex 0 - Blue 
                    {vBBottomLeft, D3DCOLOR_XRGB(
            255255255), 0.5f, 1.0f,}, //Vertex 1 - Red 
                    {vBTopLeft, D3DCOLOR_XRGB(
            255255255), 1.0f, 1.0f,}, //Vertex 1 - Red


                
            if(FAILED(p3DDevice9->CreateVertexBuffer(20 * sizeof(CUSTOMVERTEX_TXT),
                    
            0, D3DFVF_CUSTOMVERTEX,
                    D3DPOOL_DEFAULT, 
            &m_pVertexBuffer, NULL)))
                {
                    return 
            FALSE;
                }

                VOID
            * pVertices = NULL;

                
            if(FAILED(m_pVertexBuffer->Lock(0, sizeof(cvVertices), (void**)&pVertices, 0)))
                {
                    return 
            FALSE;
                }

                
            //Copy our stored vertices values into the vertex buffer
                memcpy(pVertices, cvVertices, sizeof(cvVertices));

                
            //Unlock the vertex buffer
                m_pVertexBuffer
            ->Unlock();

                return 
            TRUE;
            }

                    3、創建每個面的紋理。
                    4、更新世界矩陣。根據攝像頭位置的改變,改變skybox的世界矩陣就行了。
            void CSkyBox::UpdatePos(const D3DXVECTOR3& vPos)
            {
                m_vPos 
            = vPos;
                D3DXVECTOR3 v 
            = m_vPos - m_vPosOrgin;    //計算出平移的向量
                m_matWorld._41 
            = v.x;
                m_matWorld._42 
            = v.y;
                m_matWorld._43 
            = v.z;
            }

            posted on 2008-03-24 09:27 狂爛球 閱讀(1667) 評論(1)  編輯 收藏 引用 所屬分類: 圖形編程

            評論

            # re: 用DirectX寫的Skybox 2015-03-13 15:10 祛痘辦法有哪些

            {vTBottomLeft, D3DCOLOR_XRGB(255, 255, 255), 0.5f, 0.0f,}, //Vertex 0 - Blue
            {vTTopLeft, D3DCOLOR_XRGB(255, 255, 255), 1.0f, 0.0f,}, //Vertex 0 - Blue
            {vBBottomLeft, D3DCOLOR_XRGB(255, 255, 255), 0.5f, 1.0f,}, //Vertex 1 - Red
            {vBTopLeft, D3DCOLOR_XRGB(255, 255, 255), 1.0f, 1.0f,}, //Vertex 1 - Red  回復  更多評論   

            色综合合久久天天给综看| 精品久久久无码人妻中文字幕豆芽| 武侠古典久久婷婷狼人伊人| 热99re久久国超精品首页| 午夜久久久久久禁播电影 | 久久精品国产福利国产琪琪| 国产99精品久久| 国产国产成人精品久久| 国产69精品久久久久777| 国产精品久久成人影院| 91精品国产高清91久久久久久| 久久亚洲中文字幕精品有坂深雪| 欧美丰满熟妇BBB久久久| 欧美亚洲色综久久精品国产| 久久久国产精品亚洲一区| 色综合久久无码中文字幕| 亚洲精品乱码久久久久久中文字幕 | 国产成人久久精品一区二区三区| 国内精品久久久久久久久电影网| 久久久久se色偷偷亚洲精品av| 亚洲日本va中文字幕久久| 亚洲AV无码1区2区久久| 丁香五月网久久综合| 久久久国产精华液| 精品久久亚洲中文无码| 久久久久久夜精品精品免费啦| AA级片免费看视频久久| 亚洲色大成网站WWW久久九九| 久久99精品久久久久久动态图| 婷婷久久综合九色综合98| 四虎亚洲国产成人久久精品| 久久亚洲精品人成综合网| 亚洲国产精品人久久| 久久天天躁狠狠躁夜夜2020一 | 久久国产乱子伦精品免费强| 亚洲国产精品一区二区三区久久 | 午夜不卡久久精品无码免费| 99久久成人18免费网站| 亚洲精品乱码久久久久久| 久久久久99精品成人片牛牛影视| 欧洲人妻丰满av无码久久不卡|