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

              C++博客 :: 首頁 :: 聯(lián)系 ::  :: 管理
              163 Posts :: 4 Stories :: 350 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(48)

            我參與的團(tuán)隊(duì)

            搜索

            •  

            積分與排名

            • 積分 - 401320
            • 排名 - 59

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            上一課中我教給您三角形和四邊形的繪制方法。這一課我將教您給三角形和四邊形添加2種不同類型的著色方法。使用單調(diào)著色(Flat coloring)給四邊形涂上固定的一種顏色。使用平滑著色(Smooth coloring)將三角形的三個(gè)頂點(diǎn)的不同顏色混合在一起,創(chuàng)建漂亮的色彩混合。
               繼續(xù)在上節(jié)課的DrawGLScene例程上修改。下面將整個(gè)例程重寫了一遍。如果您計(jì)劃修改上節(jié)課的代碼,只需用下面的代碼覆蓋原來的DrawGLScene()就可以了。

              int DrawGLScene(GLvoid)                  // 此過程中包括所有的繪制代碼
              {
                   glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
            // 清除屏幕及深度緩存
                  glLoadIdentity();                 // 重置模型觀察矩陣
                  glTranslatef(-1.5f,0.0f,-6.0f);          // 左移 1.5 單位,并移入屏幕 6.0
                  glBegin(GL_TRIANGLES);               // 繪制三角形

               如果您還記得上節(jié)課的內(nèi)容,這段代碼在屏幕的左半部分繪制三角形。下一行代碼是我們第一次使用命令glColor3f(r,g,b)。括號(hào)中的三個(gè)參數(shù)依次是紅、綠、藍(lán)三色分量。取值范圍可以從0,0f到1.0f。類似于以前所講的清除屏幕背景命令。
               我們將顏色設(shè)為紅色(純紅色,無綠色,無藍(lán)色)。接下來的一行代碼設(shè)置三角形的第一個(gè)頂點(diǎn)(三角形的上頂點(diǎn)),并使用當(dāng)前顏色(紅色)來繪制。從現(xiàn)在開始所有的繪制的對(duì)象的顏色都是紅色,直到我們將紅色改變成別的什么顏色。

                      glColor3f(1.0f,0.0f,0.0f);        // 設(shè)置當(dāng)前色為紅色
                      glVertex3f( 0.0f, 1.0f, 0.0f);      // 上頂點(diǎn)

               第一個(gè)紅色頂點(diǎn)已經(jīng)設(shè)置完畢。接下來我們設(shè)置第二個(gè)綠色頂點(diǎn)。三角形的左下頂點(diǎn)被設(shè)為綠色。

                      glColor3f(0.0f,1.0f,0.0f);        // 設(shè)置當(dāng)前色為綠色
                      glVertex3f(-1.0f,-1.0f, 0.0f);      // 左下

               現(xiàn)在設(shè)置第三個(gè)也就是最后一個(gè)頂點(diǎn)。開始繪制之前將顏色設(shè)為藍(lán)色。這將是三角形的右下頂點(diǎn)。glEnd()出現(xiàn)后,三角形將被填充。但是因?yàn)槊總€(gè)頂點(diǎn)有不同的顏色,因此看起來顏色從每個(gè)角噴出,并剛好在三角形的中心匯合,三種顏色相互混合。這就是?交派?

                      glColor3f(0.0f,0.0f,1.0f);        // 設(shè)置當(dāng)前色為藍(lán)色
                      glVertex3f( 1.0f,-1.0f, 0.0f);      // 右下
                  glEnd();                     // 三角形繪制結(jié)束

                  glTranslatef(3.0f,0.0f,0.0f);          // 右移3單位

               現(xiàn)在我們繪制一個(gè)單調(diào)著色-藍(lán)色的正方形。最重要的是要記住,設(shè)置當(dāng)前色之后繪制的所有東東都是當(dāng)前色的。以后您所創(chuàng)建的每個(gè)工程都要使用顏色。即便是在完全采用紋理貼圖的時(shí)候,glColor3f仍舊可以用來調(diào)節(jié)紋理的色調(diào)。等等....,以后再說吧。
               我們必須要做的事只需將顏色一次性的設(shè)為我們想采用的顏色(本例采用藍(lán)色),然后繪制場景。每個(gè)頂點(diǎn)都是藍(lán)色的,因?yàn)槲覀儧]有告訴OpenGL要改變頂點(diǎn)的顏色。最后的結(jié)果是.....全藍(lán)色的正方形。再說一遍,順時(shí)針繪制的正方形意味著我們所看見的是四邊形的背面。

                  glColor3f(0.5f,0.5f,1.0f);           // 一次性將當(dāng)前色設(shè)置為藍(lán)色
                  glBegin(GL_QUADS);               // 繪制正方形
                      glVertex3f(-1.0f, 1.0f, 0.0f);     // 左上
                      glVertex3f( 1.0f, 1.0f, 0.0f);     // 右上
                      glVertex3f( 1.0f,-1.0f, 0.0f);     // 左下
                      glVertex3f(-1.0f,-1.0f, 0.0f);     // 右下
                  glEnd();                    // 正方形繪制結(jié)束
                  return TRUE;                  // 繼續(xù)運(yùn)行
              }

               最后換掉窗口模式下的標(biāo)題內(nèi)容。

                         if (keys[VK_F1])         // F1鍵按下了么?
                         {
                               keys[VK_F1]=FALSE;
                // 若是,使對(duì)應(yīng)的Key數(shù)組中的值為 FALSE
                             KillGLWindow();     // 銷毀當(dāng)前的窗口
                             fullscreen=!fullscreen; // 切換 全屏 / 窗口 模式
                              // 重建 OpenGL 窗口(修改)
                             if (!CreateGLWindow("NeHe’s Color Tutorial",
                                   640,480,16,fullscreen))
                              {
                                   return 0;
                // 如果窗口未能創(chuàng)建,程序退出
                             }
                          }


            在這一課中,我試著盡量詳細(xì)的解釋如何為您的OpenGL多邊形添加單調(diào)和平滑的著色效果的步驟。改改代碼中的紅綠藍(lán)分量值,看看最后有什么樣的結(jié)果。如 果您有什么意見或建議請(qǐng)給我寫信。如果您認(rèn)為有什么不對(duì)或可以改進(jìn),請(qǐng)告訴我。我想做最好的OpenGL教程并對(duì)您的反饋感興趣。
            posted on 2007-12-09 18:51 sdfasdf 閱讀(651) 評(píng)論(1)  編輯 收藏 引用 所屬分類: OPENGL

            Feedback

            # re: OpenGL教程- 著色 第三課 2007-12-09 19:08 學(xué)海一人
            Thank you!  回復(fù)  更多評(píng)論
              

            嫩草伊人久久精品少妇AV| 久久综合久久鬼色| 精品久久久久久| 久久精品免费大片国产大片| 欧美国产成人久久精品| 好久久免费视频高清| 国产精品久久久香蕉| 国产精品无码久久久久| 亚洲综合伊人久久大杳蕉| 国产精品99久久久久久董美香| 国产精品热久久毛片| 久久天天躁狠狠躁夜夜avapp| 国内精品久久久久影院亚洲| 日本久久久久亚洲中字幕| 久久亚洲2019中文字幕| 久久精品国产免费一区| 亚洲色大成网站WWW久久九九| 99久久99久久精品国产| 亚洲欧美另类日本久久国产真实乱对白 | 久久人人爽人人爽人人片AV麻烦| 久久国产精品成人影院| 怡红院日本一道日本久久| 亚洲va久久久噜噜噜久久天堂| 尹人香蕉久久99天天拍| 99久久夜色精品国产网站| 国产午夜精品久久久久九九| 久久夜色精品国产噜噜亚洲AV| 中文字幕无码久久人妻| 99久久99久久精品国产片| 伊人久久无码中文字幕| 久久亚洲精品国产亚洲老地址| 久久国产视屏| 伊人色综合久久天天| 久久精品视频网| 国产精品女同一区二区久久| 国产日产久久高清欧美一区| 国产精品99久久精品| 热99re久久国超精品首页| 久久国产免费观看精品3| 久久精品亚洲日本波多野结衣 | 久久精品国产AV一区二区三区|