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

  C++博客 :: 首頁 :: 聯系 ::  :: 管理
  163 Posts :: 4 Stories :: 350 Comments :: 0 Trackbacks

常用鏈接

留言簿(48)

我參與的團隊

搜索

  •  

積分與排名

  • 積分 - 402524
  • 排名 - 59

最新評論

閱讀排行榜

評論排行榜

  歡迎來到第20課的教程,*.bmp圖像被給各種操作系統所支持,因為它簡單,所以可以很輕松的作為紋理圖片加載它。知道現在,我們在把圖像加載到屏幕上時沒有擦除背景色,因為這樣簡單高效。但是效果并不總是很好。
大部分情況下,把紋理混合到屏幕,紋理不是太少就是太多。當使用精靈時,我不希望背景從精靈的縫隙中透出光來;但在顯示文字時,你希望文字的間隙可以顯示背景色。

由于以上原因,我們需要使用“掩模”。使用“掩模”需要兩個步驟,首先我們在場景上放置黑白相間的紋理,白色代表透明部分,黑色代表不透明部分。接著我們使用一種特殊的混合方式,只有在黑色部分上的紋理才會顯示在場景中。

我只重寫那些改變的地方,如果你做好了學習的準備,我們就上路吧。
 
  
  
 在這個程序里,我們使用7個全局變量。變量masking為一個布爾值,標志是否使用“掩模”。變量mp標志鍵M是否按下,變量sp標志空格是否按下。
接著我們創建保存5個紋理標志的數組,loop為循環變量。變量roll使得紋理沿屏幕滾動。
 
  

bool    masking=TRUE;                    // 是否使用“掩模”
bool    mp;                        // 鍵M是否按下
bool    sp;                        // 空格是否按下
bool    scene;                        // 繪制那一個場景

GLuint    texture[5];                    // 保存5個紋理標志
GLuint    loop;                        // 循環變量

GLfloat    roll;                        // 滾動紋理

  
 加載紋理代碼基本沒變,只是這里我們需要加載5個紋理 
  

int LoadGLTextures()                       
{
    int Status=FALSE;                       
    AUX_RGBImageRec *TextureImage[5];                // 創建保存5個紋理的數據結構
    memset(TextureImage,0,sizeof(void *)*5);            // 初始化

    if ((TextureImage[0]=LoadBMP("Data/logo.bmp")) &&        // 加載紋理0
        (TextureImage[1]=LoadBMP("Data/mask1.bmp")) &&        // 加載掩模紋理1,作為“掩模”使用
        (TextureImage[2]=LoadBMP("Data/image1.bmp")) &&        // 加載紋理1
        (TextureImage[3]=LoadBMP("Data/mask2.bmp")) &&        // 加載掩模紋理2,作為“掩模”使用
        (TextureImage[4]=LoadBMP("Data/image2.bmp")))        // 加載紋理2
    {
        Status=TRUE;                       
        glGenTextures(5, &texture[0]);                // 創建5個紋理

        for (loop=0; loop<5; loop++)                // 循環加載5個紋理
        {
            glBindTexture(GL_TEXTURE_2D, texture[loop]);
            glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR);
            glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR);
            glTexImage2D(GL_TEXTURE_2D, 0, 3, TextureImage[loop]->sizeX, TextureImage[loop]->sizeY,
                0, GL_RGB, GL_UNSIGNED_BYTE, TextureImage[loop]->data);
        }
    }
    for (loop=0; loop<5; loop++)                   
    {
        if (TextureImage[loop])                   
        {
            if (TextureImage[loop]->data)           
            {
                free(TextureImage[loop]->data);       
            }
            free(TextureImage[loop]);           
        }
    }
    return Status;                       
}

  
 改變窗口大小和初始化OpenGL的函數沒有變化
 
  
  
 現在到了最有趣的繪制部分了,我們從清楚背景色開始,接著把物體移入屏幕2個單位。 
  

int DrawGLScene(GLvoid)       
{
    glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);           
    glLoadIdentity();                           
    glTranslatef(0.0f,0.0f,-2.0f);                        // 物體移入屏幕2個單位
  
 下面一行,我們選擇'logo'紋理。我們將要通過四邊形把紋理映射到屏幕,并按照頂點的順序設置紋理坐標。
Jonathan Roy說OpenGL是一個基于頂點的圖形系統,大部分你設置的參數是作為頂點的屬性而記錄的,紋理坐標就是這樣一種屬性。你只要簡單的設置各個頂點的紋理坐標,OpenGL就自動幫你把多邊形內部填充紋理,通過一個插值的過程。

向前面幾課一樣,我們假定四邊形面對我們,并把紋理坐標(0,0)綁定到左下角,(1,0)綁定到右下角,(1,1)綁定到右上角。給定這些設置,你應該能猜到四邊形中間對應的紋理坐標為(0.5,0.5),但你自己并沒有設置此處的紋理坐標!OpenGL為你做了計算。

在這一課里,我們通過設置紋理坐標達到一種滾動紋理的目的。紋理坐標是被歸一化的,它的范圍從0.0-1.0,值0被映射到紋理的一邊,值1被映射到紋理的另一邊。超過1的值,紋理可以按照不同的方式被映射,這里我們設置為它將回繞道另一邊并重復紋理。例如如果使用這樣的映射方式,紋理坐標(0.3,0.5)和(1.3,0.5)被映射到同一個紋理坐標。在這一課里,我們將嘗試一種無縫填充的效果。



 我們使用roll變量去設置紋理坐標,當它為0時,它把紋理的左下角映射到四邊形的左下角。當它大于0時,把紋理的左上角映射到四邊形的左下角,看起來的效果就是紋理沿四邊形向上滾動。 
  

    glBindTexture(GL_TEXTURE_2D, texture[0]);                // 選擇Logo紋理
    glBegin(GL_QUADS);                            // 繪制紋理四邊形
        glTexCoord2f(0.0f, -roll+0.0f); glVertex3f(-1.1f, -1.1f,  0.0f);   
        glTexCoord2f(3.0f, -roll+0.0f); glVertex3f( 1.1f, -1.1f,  0.0f);   
        glTexCoord2f(3.0f, -roll+3.0f); glVertex3f( 1.1f,  1.1f,  0.0f);   
        glTexCoord2f(0.0f, -roll+3.0f); glVertex3f(-1.1f,  1.1f,  0.0f);   
    glEnd();       
  
 啟用混合和禁用深度測試 
  

    glEnable(GL_BLEND);                            // 啟用混合
    glDisable(GL_DEPTH_TEST);                            // 禁用深度測試

  
 接下來我們需要根據masking的值設置是否使用“掩模”,如果是,則需要設置相應的混合系數。 
  

    if (masking)                                // 是否啟用“掩模”
    {

  
 如果啟用了“掩模”,我們將要設置“掩模”的混合系數。一個“掩模”只是一幅繪制到屏幕的紋理圖片,但只有黑色和白色。白色的部分代表透明,黑色的部分代表不透明。
下面這個混合系數使得,任何對應“掩模”黑色的部分會變為黑色,白色的部分會保持原來的顏色。
 
  

        glBlendFunc(GL_DST_COLOR,GL_ZERO);                    // 使用黑白“掩模”混合屏幕顏色
    }

  
 現在我們檢查繪制那一個層,如果為True繪制第二個層,否則繪制第一個層 
  

    if (scene)   
    {

  
 為了不使它看起來顯得非常大,我們把它移入屏幕一個單位,并把它按roll變量的值進行旋轉(沿Z軸)。 
  

        glTranslatef(0.0f,0.0f,-1.0f);                    // 移入屏幕一個單位
        glRotatef(roll*360,0.0f,0.0f,1.0f);                    // 沿Z軸旋轉

  
 接下我們檢查masking的值來繪制我們的對象 
  

        if (masking)                            // “掩模”是否打開
        {

  
 如果“掩模打開”,我們會把掩模繪制到屏幕。當我們完成這個操作時,將會看到一個鏤空的紋理出現在屏幕上。 
  

            glBindTexture(GL_TEXTURE_2D, texture[3]);        // 選擇第二個“掩模”紋理
            glBegin(GL_QUADS);                    // 開始繪制四邊形
                glTexCoord2f(0.0f, 0.0f); glVertex3f(-1.1f, -1.1f,  0.0f);   
                glTexCoord2f(1.0f, 0.0f); glVertex3f( 1.1f, -1.1f,  0.0f);   
                glTexCoord2f(1.0f, 1.0f); glVertex3f( 1.1f,  1.1f,  0.0f);   
                glTexCoord2f(0.0f, 1.0f); glVertex3f(-1.1f,  1.1f,  0.0f);   
            glEnd();                       
        }

  
 當我們把“掩模”繪制到屏幕上后,接著我們變換混合系數。這次我們告訴OpenGL把任何黑色部分對應的像素復制到屏幕,這樣看起來紋理就像被鏤空一樣帖子屏幕上。
注意,我們在變換了混合模式后在選擇的紋理。

如果我們沒有使用“掩模”,我們的圖像將與屏幕顏色混合。
 
  

        glBlendFunc(GL_ONE, GL_ONE);                // 把紋理2復制到屏幕
        glBindTexture(GL_TEXTURE_2D, texture[4]);            // 選擇第二個紋理
        glBegin(GL_QUADS);                        // 繪制四邊形
            glTexCoord2f(0.0f, 0.0f); glVertex3f(-1.1f, -1.1f,  0.0f);   
            glTexCoord2f(1.0f, 0.0f); glVertex3f( 1.1f, -1.1f,  0.0f);   
            glTexCoord2f(1.0f, 1.0f); glVertex3f( 1.1f,  1.1f,  0.0f);   
            glTexCoord2f(0.0f, 1.0f); glVertex3f(-1.1f,  1.1f,  0.0f);   
        glEnd();                       
    }

  
 繪制第一層圖像 
  

    else                                   
    {

  
 如果“掩模打開”,我們會把掩模繪制到屏幕。當我們完成這個操作時,將會看到一個鏤空的紋理出現在屏幕上。 
  

        if (masking)                            // “掩模”是否打開
        {

  
 如果“掩模打開”,我們會把掩模繪制到屏幕。當我們完成這個操作時,將會看到一個鏤空的紋理出現在屏幕上。 
  

            glBindTexture(GL_TEXTURE_2D, texture[1]);        // 選擇第一個“掩模”紋理
            glBegin(GL_QUADS);                    // 開始繪制四邊形
                glTexCoord2f(roll+0.0f, 0.0f); glVertex3f(-1.1f, -1.1f,  0.0f);   
                glTexCoord2f(roll+4.0f, 0.0f); glVertex3f( 1.1f, -1.1f,  0.0f);   
                glTexCoord2f(roll+4.0f, 4.0f); glVertex3f( 1.1f,  1.1f,  0.0f);   
                glTexCoord2f(roll+0.0f, 4.0f); glVertex3f(-1.1f,  1.1f,  0.0f);   
            glEnd();                       
        }

  
 當我們把“掩模”繪制到屏幕上后,接著我們變換混合系數。這次我們告訴OpenGL把任何黑色部分對應的像素復制到屏幕,這樣看起來紋理就像被鏤空一樣帖子屏幕上。
注意,我們在變換了混合模式后在選擇的紋理。

如果我們沒有使用“掩模”,我們的圖像將與屏幕顏色混合。
 
  

        glBlendFunc(GL_ONE, GL_ONE);                    // 把紋理1復制到屏幕
        glBindTexture(GL_TEXTURE_2D, texture[2]);                // 選擇第一個紋理
        glBegin(GL_QUADS);                            // 開始繪制四邊形
            glTexCoord2f(roll+0.0f, 0.0f); glVertex3f(-1.1f, -1.1f,  0.0f);   
            glTexCoord2f(roll+4.0f, 0.0f); glVertex3f( 1.1f, -1.1f,  0.0f);   
            glTexCoord2f(roll+4.0f, 4.0f); glVertex3f( 1.1f,  1.1f,  0.0f);   
            glTexCoord2f(roll+0.0f, 4.0f); glVertex3f(-1.1f,  1.1f,  0.0f);   
        glEnd();           
    }

  
 接下來啟用深度測試,禁用混合。 
  

    glEnable(GL_DEPTH_TEST);                            // 啟用深度測試
    glDisable(GL_BLEND);                            // 禁用混合

  
 最后增加roll變量,如果大于1,把它的值減1。 
  

    roll+=0.002f;                                // 增加紋理滾動變量
    if (roll>1.0f)                                // 大于1則減1
    {
        roll-=1.0f;                       
    }

    return TRUE;                                // 成功返回
}

  
 函數KillGLWindow(), CreateGLWindow() 和 WndProc() 沒有改變。
 
  
  
 接下來在wWinMain,我們添加鍵盤控制函數。我們檢查空格是否按下,如果是則設置sp變量為TRUE,sp變量用來切換場景。 
  

                if (keys[' '] && !sp)                // 空格鍵是否被按下?
                {
                    sp=TRUE;               
                    scene=!scene;                // 是則切換場景
                }

  
 如果空格鍵釋放,記錄下來 
  

                if (!keys[' '])                    // 如果空格鍵釋放,記錄下來
                {
                    sp=FALSE;               
                }

  
 我們檢查M鍵是否按下,如果是則設置mp變量為TRUE,sp變量用來切換是否使用“掩模” 
  

                if (keys['M'] && !mp)                // M鍵是否被按下
                {
                    mp=TRUE;               
                    masking=!masking;                // 是則切換“掩模”
                }

  
 如果M鍵釋放,記錄下來 
  

                if (!keys['M'])                    // 如果M鍵釋放,記錄下來
                {
                    mp=FALSE;               
                }

  
 Eric Desrosiers指出,你也可以在載入的時候測試*.bmp圖像中的每一個像素,如果你你想要透明的結果,你可以把顏色的alpha設置為0。對于其他的顏色,你可以把alpha設置為1。這個方法也能達到同樣的效果,但需要一些額外的代碼。
在這課里,我們給你演示了一個簡單的例子,它能高效的繪制一部分紋理而不使用alpha值。

謝謝Rob Santa的想法和例子程序,我從沒想到過這種方法。

我希望你喜歡這個教程,如果你在理解上有任何問題或找到了任何錯誤,請我知道,我想做最好的教程,你的反饋是非常重要的。

 


posted on 2007-12-17 16:49 sdfasdf 閱讀(1027) 評論(0)  編輯 收藏 引用 所屬分類: OPENGL
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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久久久久久麻豆网| 欧美日韩在线影院| 国产色综合天天综合网| 影音先锋中文字幕一区| 最新国产の精品合集bt伙计| 亚洲深夜福利在线| 久久激情综合网| 欧美成人精品在线播放| 99精品国产99久久久久久福利| 亚洲深爱激情| 老司机午夜精品视频在线观看| 欧美黄污视频| 国产欧美精品| 亚洲全部视频| 久久超碰97中文字幕| 欧美黄污视频| 欧美亚洲在线播放| 欧美日本二区| 国外成人在线视频网站| 日韩亚洲欧美一区二区三区| 欧美一区二区三区日韩视频| 欧美国产在线视频| 欧美专区在线播放| 欧美午夜精品久久久久久人妖| 国产一区二区精品在线观看| 99成人精品| 亚洲国产欧美在线人成| 亚洲电影免费观看高清完整版在线| 国产一区亚洲| 亚洲天堂免费在线观看视频| 猛男gaygay欧美视频| 亚洲午夜精品在线| 欧美区一区二区三区| 精品99一区二区| 欧美尤物一区| 日韩亚洲综合在线| 欧美精品一区三区| 亚洲日本久久| 欧美成人一区二区三区| 欧美一区二区大片| 国产女同一区二区| 先锋影音网一区二区| 亚洲精品裸体| 欧美激情影院| 亚洲精品乱码久久久久| 欧美a级片一区| 久久国产欧美精品| 国产亚洲精品v| 久久国产一区二区三区| 午夜精品一区二区三区在线| 国产精品久在线观看| 中文亚洲视频在线| 一本色道久久精品| 国产精品视频yy9099| 亚洲一区二区三区在线视频| 亚洲国产精品一区制服丝袜 | 狠狠色狠狠色综合日日小说| 亚洲欧美在线另类| 亚洲欧美日韩综合国产aⅴ| 国产精品hd| 欧美一级免费视频| 香蕉尹人综合在线观看| 国产乱码精品一区二区三区不卡| 亚洲一区二区三区精品在线观看| 99re热精品| 国产精品老女人精品视频| 亚洲摸下面视频| 新狼窝色av性久久久久久| 韩国欧美国产1区| 欧美大片免费观看在线观看网站推荐| 久久亚洲图片| 99国产精品久久久久老师 | 久久精品亚洲精品| 亚洲高清久久久| 欧美亚洲在线播放| 国产欧美一区二区三区久久| 久久香蕉国产线看观看网| 欧美 日韩 国产一区二区在线视频| 亚洲激情视频网站| 夜夜夜精品看看| 韩国成人福利片在线播放| 亚洲国产另类久久久精品极度| 亚洲国产欧美一区| 亚洲精品中文字幕有码专区| 欧美日韩国产欧美日美国产精品| 一本一道久久综合狠狠老精东影业 | 欧美日本成人| 久久精品一区蜜桃臀影院 | 欧美成人a视频| 午夜影视日本亚洲欧洲精品| 久久久免费精品| 亚洲欧美国产毛片在线| 久久久女女女女999久久| 国产精品99久久久久久久女警 | 国产精品亚洲综合天堂夜夜| 久久综合伊人77777尤物| 欧美日韩国产在线播放| 久久青草久久| 国产精品久久久久久影视| 欧美成人一区在线| 国产人成一区二区三区影院| 亚洲三级免费电影| 18成人免费观看视频| 亚洲免费婷婷| 亚洲系列中文字幕| 欧美电影在线免费观看网站 | 亚洲理伦电影| 亚洲第一区在线观看| 亚洲欧美一区二区三区极速播放 | 亚洲一区二区三区精品动漫| 亚洲黄色有码视频| 欧美在线免费观看视频| 亚洲一级二级| 欧美日韩高清在线播放| 欧美国产精品劲爆| 一区精品在线| 欧美伊人久久| 欧美一区二区三区免费看| 欧美新色视频| 99精品福利视频| 一区二区精品在线| 欧美激情亚洲激情| 亚洲国产一区在线| 亚洲精品乱码久久久久久日本蜜臀| 性做久久久久久久免费看| 亚洲女同精品视频| 欧美亚洲成人免费| 亚洲午夜精品久久| 欧美一级片一区| 国产视频一区欧美| 欧美一区二区三区免费看 | 免费成人黄色片| 久久久久久久波多野高潮日日| 欧美国产精品劲爆| 欧美激情无毛| 亚洲免费成人| 欧美日韩一区二区三区| 亚洲久久视频| 午夜在线播放视频欧美| 国产日产高清欧美一区二区三区| 亚洲综合色婷婷| 久久天堂成人| 亚洲国产高清视频| 欧美极品影院| 亚洲深夜影院| 久久综合狠狠| 亚洲精品久久久久久久久久久 | 亚洲专区国产精品| 久久精品99久久香蕉国产色戒| 国产自产2019最新不卡| 久久久久九九视频| 亚洲激情av| 性久久久久久久久| 在线精品视频一区二区三四| 欧美另类久久久品 | 欧美日韩国产在线播放| 一区二区免费看| 久久琪琪电影院| 99在线热播精品免费99热| 国产精品视区| 欧美88av| 亚洲中无吗在线| 欧美激情视频一区二区三区免费| 一区二区免费在线播放| 国产一区二区无遮挡| 欧美精品日韩综合在线| 亚洲永久在线观看| 亚洲国产欧美在线| 久久久一区二区三区| 一区二区精品国产| 一区二区自拍| 国产美女诱惑一区二区| 欧美激情片在线观看| 午夜精品久久久久久久白皮肤| 欧美国产专区| 久久久999精品视频| 亚洲一区二区视频在线观看| 激情欧美一区二区三区| 国产精品成人一区二区网站软件 | 日韩视频免费观看| 久久伊人免费视频| 亚洲欧美日韩综合| 亚洲精品乱码视频 | 亚洲专区一区二区三区| 亚洲精品乱码久久久久久| 国产一区二区0| 国产精品扒开腿做爽爽爽视频| 久久亚洲欧美国产精品乐播| 亚洲欧美在线观看| 亚洲午夜伦理| 一区二区三区精品视频| 亚洲欧洲一区二区在线播放| 免费日韩av片|