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

            逛奔的蝸牛

            我不聰明,但我會很努力

               ::  :: 新隨筆 ::  ::  :: 管理 ::
            一、
            在寫風吹旗幟效果的時候,注意的是上一個點與下一個點的如Z坐標的關系,下一個點的Z坐標是上一個點的此時的Z坐標,其實就是按波的傳遞性來計算,Z坐標可以按任何曲線的函數來計算,如sin, cos,這只是最基本的思想,要做得真實,就看算法的了,但動態實現就是用坐標傳遞。
             
            如把旗幟分成44行,44列,只計算Z坐標的傳遞,不考試X與Y,
            那么,一共有45 * 45個點,每個點三個坐標值
             
                    const float PI = 3.1415;
                    const int row = 44;    //要分成的行數
                    const int column = 44;   // 要分成的列數
                    const float length = 9;  //旗幟的長度
                    const disx = length / (float)column;
                    const disy = length / (float)row;
                    float coord[row][column][3];
             
                    // 按行逐行計算坐標值
                    for (int i=0; i < row; i++) {
                            float y = i * disy - length / 2.0;
                            for (int j=0; j < column; j++) {
                                    coord[i][j][0] = j * disx - length / 2.0; //是為了保證旗幟處于正中間
                                    coord[i][j][1] = y;
                                    coord[i][j][2] = sin((float)j / (float)colum * 2.0 * PI);
                                    // 注意除法時要不要把兩個數都是整數
                            }
                    }
             
            傳遞Z坐標
                    for (int i=0; i < row; i++) {
                            float hold = coord[i][0][2]; //保存第一個點的Z坐標,最后一個點要使用
                            for (int j=0; j < column-1; j++) {
                                    coord[i][j][2] = coord[i][j+1][2];
                            }
                            coord[i][column-1] = hold;
                    }
             
            這是最簡單的計算,每一列的Z坐標都相同,重復了最后一個點的Z坐標與第一個點的Z坐標,還可以把列點的Z坐標按照一定的曲線方程來計算,然后把它傳遞給下一個點,還有X與Z坐標也有可能會變化,這里都是最簡單的形式。

            二、
            為了能使Z軸即能在垂直方向運動,又能在水平方向運動,則需要兩個數組來保存水平方向和垂直方向的Z坐標值。然后Z坐標為這兩個坐標值的合成:
                    const int row = 45;
                    const int column = 45;
                    const float width= 9.0f;
                    const float height = 9.0f;
             
                    float coord[row][column][3];  // Flag的坐標
                    float hzcoord[row][column];   // Flag的Z坐標水平分量
                    float vzcoord[column][row];   // Flag的Z坐標垂直分量
             
                   
                    //計算Z坐標的水平分量
                    for (int i = 0; i < row; i++) {
                            for (int j = 0; j < column; j++) {
                                    hzcoord[i][j] = sin((float)j / (float)column * 360 * 3.1415 / 180);
                            }
                    }
             
                    //計算Z坐標的垂直分量
                    for (int i = 0; i < column; i++) {
                            for (int j = 0; j < row; j++) {
                                    vzcoord[i][j] = sin((float)j / (float)column * 360 * 3.1415 / 180);
                            }
                    }
             
                     float disx = width / column;
                     float disy = height /row;
                    //計算每個點的坐標
                    for (int i = 0; i < row; i++) {
                            for (int j = 0; j < column; j++) {
                                    coord[i][j][0] = j * disx - width / 2.0;
                                    coord[i][j][1] = i * disy - height / 2.0;
                                    coord[i][j][2] = hzcoord[i][j] + vzoord[j][i];
                            }
                    }
             
            上面已經完成初始化每個點的坐標,下面就到了動態的每一幀時Z坐標的傳遞了:
             
                    //水平坐標分量的傳遞
                    for (int i = 0; i < row; i++) {
                            float hold = hzcoord[i][0];
                            for (int j = 0; j < column - 1; j++) {
                                    hzcoord[i][j] = hzcoord[i][j+1];
                            }
                            hzcoord[i][column-1] = hold;
                    }
             
                    //垂直坐標分量的傳遞
                    for (int i = 0; i < column; i++) {
                            float hold = vzcoord[i][0];
                            for (int j = 0; j < row - 1; j++) {
                                    vzcoord[i][j] = vzcoord[i][j+1];
                            }
                            vzcoord[i][row-1] = hold;
                    }
                   
                    //每一幀時要計算的每個點的坐標
                    for (int i = 0; i < row; i++) {
                            for (int j = 0; j < column; j++) {
                                    //X與Y坐標我們不用去變換,因為只考慮了Z坐標的變化
                                    //coord[i][j][0] = j * disx - width / 2.0;
                                    //coord[i][j][1] = i * disy - height / 2.0;
                                    coord[i][j][2] = hzcoord[i][j] + vzoord[j][i];
                            }
                    }
            posted on 2010-12-17 17:45 逛奔的蝸牛 閱讀(1117) 評論(0)  編輯 收藏 引用 所屬分類: OpenGL
            国产69精品久久久久777| 国产毛片久久久久久国产毛片| 国产精品99久久久久久董美香| 91精品观看91久久久久久| 欧美丰满熟妇BBB久久久| 热re99久久精品国99热| 7国产欧美日韩综合天堂中文久久久久| 国产精品欧美久久久久无广告 | 国产成人精品久久综合| 亚洲欧美国产日韩综合久久| 亚洲AV无码一区东京热久久 | 国产精品福利一区二区久久| 99久久国产亚洲高清观看2024| 久久午夜福利无码1000合集| 亚洲狠狠综合久久| 久久久久国产精品人妻| 一级做a爱片久久毛片| 中文字幕无码精品亚洲资源网久久 | 色综合久久88色综合天天 | 久久精品九九亚洲精品| 无码国内精品久久人妻麻豆按摩| 久久99国内精品自在现线| 7777精品伊人久久久大香线蕉| 国产精品欧美亚洲韩国日本久久| 久久精品国产免费观看三人同眠| 激情五月综合综合久久69| 丁香狠狠色婷婷久久综合| 久久综合亚洲欧美成人| 精品久久亚洲中文无码| 欧美日韩成人精品久久久免费看| 久久99精品国产99久久| 97久久综合精品久久久综合| 亚洲综合精品香蕉久久网| 色综合久久夜色精品国产| 日韩亚洲国产综合久久久| 99久久er这里只有精品18| 伊人久久大香线蕉av一区| 一本久久综合亚洲鲁鲁五月天| 国产福利电影一区二区三区久久久久成人精品综合 | 伊人久久成人成综合网222| 久久亚洲2019中文字幕|