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

天行健 君子當自強而不息

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>
            激情欧美日韩| 久久久噜久噜久久综合| 亚洲欧美日韩国产综合| 亚洲免费电影在线| 亚洲精品在线免费观看视频| 性欧美大战久久久久久久免费观看 | 国产综合久久久久久| 国产乱码精品一区二区三区不卡| 欧美午夜精品理论片a级按摩 | 欧美第一黄色网| 欧美久久在线| 国产精品乱码久久久久久| 国产综合av| 亚洲欧洲另类| 亚洲深夜福利在线| 午夜精品影院在线观看| 久久精品毛片| 欧美黄色aa电影| 一本色道久久综合狠狠躁篇怎么玩 | 国产视频久久网| 亚洲国产精品一区二区久| 欧美日韩国产色视频| 国产精品嫩草久久久久| 在线看无码的免费网站| 国产日韩欧美综合一区| 一区二区在线不卡| 在线一区亚洲| 久久综合国产精品| 亚洲国产欧美日韩| 亚洲国产99精品国自产| 亚洲伦理网站| 久久激情婷婷| 欧美精品久久久久久| 欧美视频在线观看 亚洲欧| 欧美呦呦网站| 在线中文字幕不卡| 久久国产视频网| 欧美日韩999| 国产一区在线看| 日韩西西人体444www| 欧美在线国产| 亚洲伊人一本大道中文字幕| 一区二区三区视频观看| 99人久久精品视频最新地址| 欧美一区三区三区高中清蜜桃 | 亚洲经典三级| 亚洲欧美日韩精品久久久| 久久婷婷国产综合精品青草 | 亚洲成色精品| 亚洲欧美视频一区二区三区| 免费中文日韩| 亚洲欧美日本另类| 欧美日韩不卡合集视频| 国内久久精品| 亚洲女ⅴideoshd黑人| 午夜激情久久久| 欧美成人一区二区三区在线观看| 99精品久久| 久久综合狠狠| 国产日韩精品一区二区| 一区二区三区在线视频观看| 伊人精品视频| 亚洲国产成人在线播放| 亚洲免费观看| 在线亚洲自拍| 久久精品麻豆| 欧美成人免费在线观看| 一道本一区二区| 欧美成人免费全部| 欲香欲色天天天综合和网| 性做久久久久久久久| 久热精品视频| 美女诱惑黄网站一区| 99精品视频免费观看视频| 六月婷婷一区| 精品91在线| 欧美成人亚洲| 国产精品99久久99久久久二8 | 亚洲欧美成aⅴ人在线观看| 欧美日韩国产一区二区三区| 亚洲欧洲精品一区二区三区波多野1战4 | 亚洲小说区图片区| 欧美一级在线亚洲天堂| 亚洲免费影院| 午夜精品久久久久| 亚洲精品乱码久久久久久黑人| 午夜精品亚洲一区二区三区嫩草| 免费视频一区| 亚洲欧美在线网| 国产精品一区二区三区久久久 | 亚洲精品裸体| 欧美色视频在线| 亚洲一级特黄| 亚洲摸下面视频| 国产一区二区三区久久精品| 久久精品视频免费| 亚洲另类在线视频| 欧美激情日韩| 欧美国产综合视频| 欧美精品三级日韩久久| 欧美日韩亚洲一区二| 一区二区视频免费在线观看 | 伊人久久久大香线蕉综合直播| 一区二区国产日产| 亚洲少妇在线| 欧美午夜大胆人体| 香蕉久久a毛片| 欧美在线视频日韩| 国产日韩欧美在线播放| 久久不射电影网| 快射av在线播放一区| 亚洲视频久久| 日韩视频一区二区三区在线播放| 国产精品久久久久婷婷| 久久久久国产一区二区三区四区| 免费日韩av片| 亚洲在线免费| 久久久噜噜噜| 亚洲伊人色欲综合网| 性做久久久久久免费观看欧美| 欧美日韩三级视频| 亚洲欧美日韩中文视频| 蜜桃精品久久久久久久免费影院| 欧美亚洲在线播放| a4yy欧美一区二区三区| 猛干欧美女孩| 欧美久久久久久久久| 久久av二区| 欧美日韩精品高清| 麻豆成人精品| 亚洲婷婷国产精品电影人久久| 黄色在线成人| 亚洲一区999| 激情综合色综合久久综合| 美女诱惑一区| 国产日产欧产精品推荐色| 久久久久久尹人网香蕉| 欧美日韩免费在线视频| 牛牛影视久久网| 国产欧美一区二区三区视频| 亚洲精品一区二| 亚洲欧洲中文日韩久久av乱码| 免费日韩av电影| 亚洲狼人精品一区二区三区| 夜夜爽99久久国产综合精品女不卡| 国产精品一区二区三区乱码| 日韩亚洲欧美中文三级| 日韩视频精品| 亚洲国产乱码最新视频| 欧美一区永久视频免费观看| 亚洲影音一区| 欧美午夜a级限制福利片| 亚洲欧洲在线播放| 韩日成人在线| 亚洲国产日韩精品| 91久久精品视频| 欧美黄色网络| 免费日韩成人| 国产精品揄拍一区二区| 亚洲激情网站| 一区二区国产精品| 欧美日韩亚洲天堂| 欧美一区二区观看视频| 国产精品久久久久高潮| 亚洲视频一区在线| 亚洲欧美日韩一区二区在线 | 美腿丝袜亚洲色图| 亚洲大片一区二区三区| 亚洲卡通欧美制服中文| 欧美精品一区二区在线观看 | 亚洲免费在线看| 久久久噜噜噜久久中文字免| 亚洲日本欧美| 一区二区三区视频免费在线观看| 欧美电影打屁股sp| 国产一区二区成人| 日韩亚洲欧美成人一区| 韩国成人精品a∨在线观看| 久久精品一二三| 欧美激情小视频| 夜夜嗨av一区二区三区| 久久婷婷影院| 久久男女视频| 久久久久久亚洲精品杨幂换脸| 欧美一区二区成人6969| 久久香蕉精品| 伊人一区二区三区久久精品| 美女尤物久久精品| 亚洲精品综合精品自拍| 性欧美大战久久久久久久久| 国内自拍视频一区二区三区| 久久精品久久99精品久久| 伊人色综合久久天天| 久久婷婷丁香| 一本色道久久综合精品竹菊 | 欧美一级在线视频| 在线观看成人一级片| 欧美激情视频一区二区三区在线播放 | 日韩一区二区精品| 国产欧美日韩激情|