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

天行健 君子當自強而不息

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 閱讀(1851) 評論(0)  編輯 收藏 引用

公告

導航

統計

常用鏈接

隨筆分類(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>
            欧美成年人视频| 久久精品国产亚洲一区二区三区 | 亚洲欧美三级在线| 一区二区av| 国产亚洲激情视频在线| 久久综合久久88| 欧美成人精品一区| 中文av一区特黄| 午夜在线观看欧美| 亚洲成人在线视频播放| 亚洲国产一区二区a毛片| 欧美乱在线观看| 性久久久久久| 老司机午夜精品视频| 9人人澡人人爽人人精品| 亚洲午夜精品一区二区三区他趣| 国产婷婷色综合av蜜臀av| 久久这里只有| 欧美视频在线观看视频极品 | 亚洲国产精品一区二区www在线| 亚洲国产精品日韩| 国产精品都在这里| 久久亚洲国产精品一区二区| 欧美日韩国产一区| 久久嫩草精品久久久久| 欧美久久久久中文字幕| 久久久久网址| 欧美系列电影免费观看| 毛片av中文字幕一区二区| 欧美日韩精品不卡| 久久久美女艺术照精彩视频福利播放| 欧美v国产在线一区二区三区| 亚洲欧美国产三级| 欧美成人精品在线视频| 久久精品欧美日韩| 欧美日韩天堂| 欧美国产日韩一二三区| 国产日韩欧美一区二区三区在线观看 | 欧美成人69av| 国产主播一区二区| 亚洲特色特黄| 一区二区电影免费观看| 久久综合激情| 六月丁香综合| 国产亚洲精品综合一区91| av72成人在线| 9国产精品视频| 免费成人毛片| 麻豆精品精华液| 国产亚洲欧美激情| 亚洲一区免费看| 99国产精品久久久久久久| 久久一区二区三区av| 久久久高清一区二区三区| 国产精品手机在线| 一区二区三区日韩精品| 一区二区三区免费看| 欧美电影在线免费观看网站| 欧美国产视频一区二区| 亚洲国产精品成人综合色在线婷婷| 久久激五月天综合精品| 久久精品在这里| 国内精品福利| 久久精品视频一| 麻豆精品精华液| 亚洲国产婷婷综合在线精品 | 国产精品高潮视频| 中文国产一区| 欧美一区二区性| 国产日韩一区二区三区| 久久精品一区二区三区不卡牛牛 | 亚洲一级在线| 久久成人精品无人区| 国产女主播一区二区三区| 欧美一级在线视频| 免费在线观看成人av| 亚洲精品久久久久| 欧美日韩亚洲91| 校园春色综合网| 欧美va亚洲va香蕉在线| 亚洲精品在线免费观看视频| 欧美日韩一区二区三区在线 | 欧美www在线| 在线视频一区二区| 久久成人久久爱| 亚洲国产天堂久久国产91| 欧美日韩一卡| 久久国产精品一区二区| 亚洲国产精品久久久| 亚洲综合三区| 伊人春色精品| 国产精品成人一区二区网站软件| 午夜久久资源| 亚洲激情网址| 久久精品观看| 99在线精品免费视频九九视| 国产日韩精品在线播放| 免费国产一区二区| 亚洲一区国产视频| 亚洲国产日韩精品| 久久精品99久久香蕉国产色戒| 亚洲精品日韩在线| 国产综合网站| 欧美午夜精品一区二区三区| 久久蜜桃精品| 亚洲欧美日韩国产中文在线| 亚洲高清久久网| 久久久久久久国产| 国产精品99久久99久久久二8 | 一区二区三区导航| 欧美91大片| 久久国产精品网站| 一区二区三区毛片| 亚洲福利小视频| 国产亚洲一区二区三区在线播放| 欧美日韩免费高清| 久久久噜噜噜久久久| 亚洲欧美日韩精品综合在线观看| 91久久精品国产91性色| 久久综合999| 欧美在线资源| 午夜日本精品| 亚洲午夜一级| 在线一区免费观看| 亚洲精品国产精品国自产观看浪潮 | 欧美午夜精品久久久久久浪潮| 欧美a级理论片| 久久在线91| 久久精品中文字幕一区| 欧美一区二区三区精品| 亚洲欧美三级伦理| 亚洲影院免费| 亚洲综合国产| 亚洲女同在线| 性欧美大战久久久久久久久| 亚洲一区二区三区四区五区黄| 日韩视频在线一区二区三区| 亚洲三级免费观看| 亚洲精品乱码久久久久久| 亚洲国产成人一区| 亚洲国产91| 亚洲日本中文字幕区| 亚洲激情视频在线| 亚洲精品在线免费| 亚洲乱码一区二区| 99综合电影在线视频| 中文精品视频一区二区在线观看| 在线一区二区日韩| 午夜国产精品影院在线观看| 性欧美激情精品| 久久亚洲综合网| 欧美成人精品在线| 欧美精品一区二区三区在线看午夜| 欧美日韩免费在线视频| 国产精品久久久久久久久久久久久久| 国产精品v欧美精品v日本精品动漫| 国产精品久久久久999| 国产伦精品一区二区三区视频孕妇 | 午夜宅男久久久| 久久久噜噜噜久久| 欧美理论片在线观看| 欧美视频在线播放| 国产真实精品久久二三区| 在线不卡亚洲| 一本高清dvd不卡在线观看| 亚洲中午字幕| 蜜月aⅴ免费一区二区三区| 亚洲国产成人在线播放| 亚洲一区二区三区四区中文| 久久精品一区蜜桃臀影院| 欧美黄色小视频| 国产精品热久久久久夜色精品三区| 国产人久久人人人人爽| 亚洲国产婷婷香蕉久久久久久| 亚洲神马久久| 免费观看一区| 亚洲素人一区二区| 乱码第一页成人| 国产精品日韩欧美一区| 亚洲狠狠丁香婷婷综合久久久| 亚洲午夜一区二区| 欧美电影免费观看高清完整版| 在线亚洲美日韩| 免费亚洲一区二区| 国产香蕉97碰碰久久人人| 亚洲毛片在线看| 久久阴道视频| 亚洲一区久久久| 欧美另类久久久品 | 欧美成人一区二免费视频软件| 国产精品永久免费在线| 亚洲精品国久久99热| 久久久久青草大香线综合精品| 日韩视频在线免费观看| 免费久久99精品国产自在现线| 国产欧美精品日韩区二区麻豆天美| 艳女tv在线观看国产一区| 美日韩精品视频| 欧美一区二区三区在线| 国产精品女人久久久久久|