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

天行健 君子當自強而不息

D3D中的地形繪制基礎(4)

新建網頁 1 13

13.5在地形上“行走”

構造了一個地形以后,我們想要有移動攝像機的能力,以便模擬在地形上行走的效果。我們需要調整攝像機的高度,這依賴于地形部分的知識,好的,繼續往下看。我們首先需要找到照相機所在的方格的位置,并給出x軸和z軸坐標,cTerrain::get_height函數能做到這些,它能提供x軸、z軸坐標參數,返回攝像機需要被設置在地形上的高度值,現在看實現部分。

float cTerrain::get_height(float x, float z)
    {
        // Translate on xz-plane by the transformation that takes the terrain START point to the origin,
        // note that we negative z value so positive z-axis will be down in logical.
        x = m_width/2.0f + x;
        z = m_depth/2.0f - z;
   
        // Scale down by the transformation that makes the cell_spacing equal to one.
        x /= m_cell_spacing;
        z /= m_cell_spacing;


We first translate by the transformation that takes the start point of the terrain to the origin. Next, we scale by the inverse of the cell spacing variable; this scaling sets the cell spacing to 1. Then we switch to a new frame of reference where the positive z-axis points “down.” Of course, there is no code that changes the frame of reference, but it is now understood that +z goes down. Figure 13.9 shows these steps graphically.

We see that our changed coordinate system matches the ordering of a matrix. That is, the upper-left corner is at the origin, the column count increases in the right direction, and the row count increases in the down direction. Thus, by Figure 13.9 and knowing the cell spacing is equal to 1, we can immediately see that the row and column of the cell we are in is given by:

       // From now on, we will interpret our positive z-axis as going in the 'down' direction, 
        // rather than the 'up' direction. This allows to extract the row and column simply by 
        // 'flooring' x and z:
   
    float col = floorf(x);
        float row = floorf(z);
   
        // ensures row and col are valid
   
        if(row < 0)
            row = 0;
   
        if(row >= m_num_cells_per_col - 1)
            row = m_num_cells_per_col - 1;
   
        if(col < 0)
            col = 0;
   
        if(col >= m_num_cells_per_row)
            col = m_num_cells_per_row;

現在我們將取得方格的四個頂點的高度。

       // get the heights of the quad we're in:
        // 
        //  A   B
        //  *---*
        //  | / |
        //  *---*  
        //  C   D    
   
    float AHeight = get_height_map_entry(row,   col);
        float BHeight = get_height_map_entry(row,   col+1);
        float CHeight = get_height_map_entry(row+1, col);
        float DHeight = get_height_map_entry(row+1, col+1);

現在我們知道了方格的四個頂點的高度,我們需要找到照相機所在的位置的方格的高度,因為一個方格可能同時向幾個方向傾斜,這可能會稍微難一點,見圖 13.10:

為了找到高度,我們需要知道我們在方格中的哪個三角形里。方格是由二個三角形渲染成的,找到我們所在的三角形,我們要取得我們所在的方格并且轉換它,它的左上點是原點。

自從用行和列來描述我們所在的方格左上頂點的位置以來,我們必須沿x軸平移-col個單位,并沿z軸平移-row個單位。沿著x軸和z軸的平移過程用如下代碼表示。

  //
        // Find the triangle we are in:
        //
   
        // Translate by the transformation that takes the upper-left corner of the cell we are in 
        // to the origin.  Recall that our cell_spacing was nomalized to 1.  Thus we have a unit square
        // at the origin of our +x -> 'right' and +z -> 'down' system.
   
    float dx = x - col;
        float dz = z - row;
   
        float height = 0.0f;


Then, if dx < 1.0 – dx we are in the “upper” triangle v0v1v2. Otherwise, we are in the “lower” triangle v0v2v3 (see Figure 13.10).

Now we explain how to find the height if we are in the “upper” triangle. The process is similar for the “lower” triangle, and of course the code for both follows shortly. To find the height if we are in the “upper”triangle, we construct two vectors, u = (cellSpacing, B – A, 0) and v = (0, C – A, – cellSpacing), on the sides of the triangle and originating at the terminal point of the vector q = (qx, A, qz) as Figure 13.12.a shows. Then we linearly interpolate along u by dx, and we linearly interpolate along v by dz. Figure 13.12.b illustrates these interpolations. The y-coordinate of the vector (q + dxu + dzv) gives the height based on the given x- and z-coordinates; recall the geometric interpretation of vector addition to see this.

注意:我們只關心改變的高度值,我們只修改y值,忽視其他部分,因此,Height=A + dxuy + dzvy

   float height = 0.0f;
   
        if(dz < 1.0f - dx)    // upper triangle ABC
        {
            float uy = BHeight - AHeight;    // A->B
            float vy = CHeight - AHeight;    // A->C
   
            // Linearly interpolate on each vector.  The height is the vertex height the vectors u and v 
            // originate from {A}, plus the heights found by interpolating on each vector u and v.
                height = AHeight + lerp(0.0f, uy, dx) + lerp(0.0f, vy, dz);
        }
        else    // lower triangle DCB
        {
            float uy = CHeight - DHeight; // D->C
            float vy = BHeight - DHeight; // D->B
   
            // Linearly interpolate on each vector.  The height is the vertex height the vectors u and v 
            // originate from {D}, plus the heights found by interpolating on each vector u and v.
                height = DHeight + lerp(0.0f, uy, 1.0f - dx) + lerp(0.0f, vy, 1.0f - dz);
        }
   
        return height;
    }

Lerp函數是一個沿著一維直線的基本線性插值算法,實現如下:

float lerp(float a, float b, float t)
    {
        return a * (1 - t) + (b * t);
    }


繪制函數:

    void cTerrain::draw(D3DXMATRIX* world_matrix, bool draw_triangle)
    {
        if(m_device == NULL)
            return;
   
        m_device->SetTransform(D3DTS_WORLD, world_matrix);
   
        m_device->SetStreamSource(0, m_vertex_buffer, 0, sizeof(cTerrainVertex));
        m_device->SetFVF(TERRAIN_VERTEX_FVF);
        m_device->SetIndices(m_index_buffer);
   
        m_device->SetTexture(0, m_texture);
   
        m_device->SetRenderState(D3DRS_LIGHTING, FALSE);    // trun off lighting since we're lighting it ourselves
            m_device->DrawIndexedPrimitive(D3DPT_TRIANGLELIST, 0, 0, m_num_vertices, 0, m_num_triangles);
        m_device->SetRenderState(D3DRS_LIGHTING, TRUE);
   
        if(draw_triangle)
        {
            m_device->SetRenderState(D3DRS_FILLMODE, D3DFILL_WIREFRAME);
            m_device->DrawIndexedPrimitive(D3DPT_TRIANGLELIST, 0, 0, m_num_vertices, 0, m_num_triangles);
            m_device->SetRenderState(D3DRS_FILLMODE, D3DFILL_SOLID);
        }
    }

posted on 2008-04-02 21:21 lovedday 閱讀(1857) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


公告

導航

統計

常用鏈接

隨筆分類(178)

3D游戲編程相關鏈接

搜索

最新評論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲综合视频1区| 免费黄网站欧美| 一区二区国产精品| 欧美日韩久久精品| 亚洲欧美在线网| 亚洲欧美国产三级| 国产亚洲欧美一区二区| 久久一区免费| 免费成人av资源网| 日韩午夜在线观看视频| av成人免费在线| 国产私拍一区| 欧美大胆成人| 欧美视频一区二区| 欧美在线视频播放| 久久一本综合频道| 亚洲精品国产系列| 亚洲午夜精品一区二区| 国产在线日韩| 91久久久精品| 国产精品久久中文| 免费观看30秒视频久久| 欧美日韩高清在线播放| 久久av最新网址| 欧美成人资源| 欧美在线视频a| 欧美激情成人在线| 欧美在线视频免费播放| 欧美mv日韩mv国产网站app| 亚洲素人一区二区| 久久午夜av| 午夜精彩视频在线观看不卡 | 久久99在线观看| 久久这里有精品15一区二区三区| 一区二区日韩| 久久一区免费| 欧美一区二区精品| 欧美精品尤物在线| 久久亚洲私人国产精品va媚药| 欧美精品网站| 毛片一区二区三区| 国产精品久久久久久久久婷婷| 欧美国产亚洲视频| 国产性做久久久久久| 亚洲美女精品一区| 18成人免费观看视频| 亚洲一区二区视频| 亚洲视频欧洲视频| 欧美电影免费观看大全| 看片网站欧美日韩| 国产人久久人人人人爽| av成人免费在线观看| 日韩视频在线观看| 欧美成人dvd在线视频| 蜜臀av国产精品久久久久| 国产伦精品一区二区三区视频孕妇 | 国产欧美一区二区精品仙草咪| 亚洲高清一区二区三区| 在线观看视频一区二区| 午夜影院日韩| 欧美一区二区日韩| 国产精品高潮久久| 日韩一级裸体免费视频| 一区二区三区成人| 欧美日韩一区三区四区| 亚洲美女免费视频| 宅男精品视频| 欧美婷婷久久| 一区二区三欧美| 亚洲一区二区三区国产| 欧美人妖在线观看| 9国产精品视频| 一区二区欧美日韩视频| 欧美日韩亚洲一区二区三区四区| 91久久国产综合久久蜜月精品 | 欧美精品入口| 亚洲免费观看高清完整版在线观看熊 | 欧美在线观看视频| 国产午夜精品在线观看| 欧美亚洲综合另类| 麻豆91精品91久久久的内涵| 亚洲第一在线综合在线| 欧美国产日韩一区二区在线观看| 亚洲精品欧美日韩专区| 亚洲午夜精品国产| 国产香蕉97碰碰久久人人| 久久精品国产亚洲5555| 欧美国产精品一区| 亚洲一区二区免费视频| 国产欧美日韩在线| 久久尤物视频| 99亚洲视频| 久久精品亚洲一区二区| 亚洲国产99精品国自产| 欧美精品在线免费播放| 亚洲一区二区网站| 欧美风情在线观看| 亚洲一区视频在线| 狠狠色综合播放一区二区| 欧美成人网在线| 亚洲午夜激情| 欧美成人中文字幕在线| 亚洲网站视频福利| 狠狠色丁香婷综合久久| 欧美久久久久久| 欧美一级播放| 9色精品在线| 美日韩免费视频| 亚洲愉拍自拍另类高清精品| 激情视频一区二区三区| 国产精品国产三级国产| 蜜臀a∨国产成人精品| 亚洲专区一区二区三区| 亚洲国产成人在线播放| 久久精品国产成人| 亚洲视频在线免费观看| 在线播放国产一区中文字幕剧情欧美| 欧美日韩国产精品一卡| 久久久久久噜噜噜久久久精品| 中文一区二区| 亚洲国产日韩一区二区| 久久米奇亚洲| 小嫩嫩精品导航| 一区二区激情小说| 91久久精品一区二区别| 国产日韩久久| 国产精品羞羞答答| 国产精品久久77777| 欧美成va人片在线观看| 久久久久久网| 久久久久国产精品麻豆ai换脸| 亚洲砖区区免费| 亚洲视频在线视频| 亚洲区国产区| 亚洲国产精品一区二区三区| 久久午夜国产精品| 久久久久久久久久久一区| 欧美一级专区| 欧美亚洲尤物久久| 欧美一区二区黄| 亚洲欧美日韩专区| 亚洲一区二区在线观看视频| 一区二区电影免费观看| 一本色道精品久久一区二区三区 | 国产精品乱码一区二区三区| 欧美日韩国产欧| 欧美日本在线播放| 欧美日韩大片一区二区三区| 欧美激情综合五月色丁香| 欧美14一18处毛片| 欧美精品日韩一本| 欧美日韩一卡二卡| 欧美三级中文字幕在线观看| 欧美日韩一区二区三区免费| 国产精品mm| 国产视频一区欧美| 激情视频一区| 亚洲免费观看| 亚洲综合丁香| 欧美一级视频精品观看| 久久久久久亚洲精品中文字幕| 毛片精品免费在线观看| 欧美激情久久久久| 亚洲伦理中文字幕| 一本一本久久a久久精品综合妖精| 夜夜嗨av一区二区三区免费区| 亚洲天堂成人| 久久久久久高潮国产精品视| 免费欧美在线视频| 欧美日韩免费一区二区三区| 欧美日韩午夜在线| 国产亚洲一区二区在线观看 | 欧美日韩日本网| 欧美午夜免费电影| 国产亚洲aⅴaaaaaa毛片| 伊人久久大香线蕉综合热线| 亚洲人成久久| 亚洲欧美另类综合偷拍| 久久噜噜亚洲综合| 99re66热这里只有精品4| 久久99伊人| 欧美日韩一区免费| 在线观看亚洲精品| 亚洲系列中文字幕| 老司机免费视频久久| 日韩一级不卡| 久久久久久电影| 国产精品久久综合| 亚洲精品国产欧美| 久久偷窥视频| 99视频一区| 欧美成人黄色小视频| 国产精品自拍一区| 日韩一区二区精品葵司在线| 久久激情一区| 中日韩在线视频| 欧美国产精品中文字幕| 狠狠色丁香婷婷综合| 欧美一区二区三区在线观看| 亚洲国产三级网|