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

隨感而發(fā)

雜七雜八

統(tǒng)計(jì)

留言簿(13)

閱讀排行榜

評(píng)論排行榜

OpenGL學(xué)習(xí)筆記【4】——給立方體紋理貼圖(texture)

今天我學(xué)習(xí)了對(duì)一個(gè)正方體貼紋理:
這次先奉上源代碼:

#pragma comment(lib, "glaux.lib")
#include 
<gl\glaux.h>
#include 
<gl\glut.h>

GLuint g_texture 
= 0;
GLfloat xrot 
=0;
GLfloat yrot 
=0;
GLfloat zrot 
=0;                                    // Keep Going


//繪制一個(gè)立方體
int DrawCube(void)
{
    glBindTexture(GL_TEXTURE_2D, g_texture);        
//使用貼圖紋理

    glPushMatrix();        
//壓入變換矩陣

    glRotatef(xrot,
1.0f,0.0f,0.0f);            //旋轉(zhuǎn)矩陣,這里繞x軸旋轉(zhuǎn)。
    glRotatef(yrot,0.0f,1.0f,0.0f);            //旋轉(zhuǎn)矩陣,這里繞y軸旋轉(zhuǎn)。
    glRotatef(zrot,0.0f,0.0f,1.0f);            //繞z軸旋轉(zhuǎn),這里zrot是角度制的度數(shù)。

    glBegin(GL_QUADS);  
//啟用四邊形帶繪制模式繪制

    
// 繪制前面,這里開始確定紋理坐標(biāo),然后是確定點(diǎn)的位置
    glTexCoord2f(0.0f0.0f); glVertex3f(-1.0f-1.0f,  1.0f);
    glTexCoord2f(
1.0f0.0f); glVertex3f( 1.0f-1.0f,  1.0f);
    glTexCoord2f(
1.0f1.0f); glVertex3f( 1.0f,  1.0f,  1.0f);
    glTexCoord2f(
0.0f1.0f); glVertex3f(-1.0f,  1.0f,  1.0f);

    
// 繪制后面
    glTexCoord2f(1.0f0.0f); glVertex3f(-1.0f-1.0f-1.0f);
    glTexCoord2f(
1.0f1.0f); glVertex3f(-1.0f,  1.0f-1.0f);
    glTexCoord2f(
0.0f1.0f); glVertex3f( 1.0f,  1.0f-1.0f);
    glTexCoord2f(
0.0f0.0f); glVertex3f( 1.0f-1.0f-1.0f);

    
// 上面
    glTexCoord2f(0.0f1.0f); glVertex3f(-1.0f,  1.0f-1.0f);
    glTexCoord2f(
0.0f0.0f); glVertex3f(-1.0f,  1.0f,  1.0f);
    glTexCoord2f(
1.0f0.0f); glVertex3f( 1.0f,  1.0f,  1.0f);
    glTexCoord2f(
1.0f1.0f); glVertex3f( 1.0f,  1.0f-1.0f);

    
//底面
    glTexCoord2f(1.0f1.0f); glVertex3f(-1.0f-1.0f-1.0f);
    glTexCoord2f(
0.0f1.0f); glVertex3f( 1.0f-1.0f-1.0f);
    glTexCoord2f(
0.0f0.0f); glVertex3f( 1.0f-1.0f,  1.0f);
    glTexCoord2f(
1.0f0.0f); glVertex3f(-1.0f-1.0f,  1.0f);
    
    
// 右面
    glTexCoord2f(1.0f0.0f); glVertex3f( 1.0f-1.0f-1.0f);
    glTexCoord2f(
1.0f1.0f); glVertex3f( 1.0f,  1.0f-1.0f);
    glTexCoord2f(
0.0f1.0f); glVertex3f( 1.0f,  1.0f,  1.0f);
    glTexCoord2f(
0.0f0.0f); glVertex3f( 1.0f-1.0f,  1.0f);

    
// 左面
    glTexCoord2f(0.0f0.0f); glVertex3f(-1.0f-1.0f-1.0f);
    glTexCoord2f(
1.0f0.0f); glVertex3f(-1.0f-1.0f,  1.0f);
    glTexCoord2f(
1.0f1.0f); glVertex3f(-1.0f,  1.0f,  1.0f);
    glTexCoord2f(
0.0f1.0f); glVertex3f(-1.0f,  1.0f-1.0f);

    glEnd();

    glPopMatrix(); 
//彈出變換矩陣

    
return 1;

}

void display(void)
{
    glClear(GL_COLOR_BUFFER_BIT 
| GL_DEPTH_BUFFER_BIT);    // 清楚顏色數(shù)據(jù)和深度數(shù)據(jù)(清屏)
    glLoadIdentity();                                    // Reset The View
    glTranslatef(0.0f,0.0f,-5.0f);

    DrawCube();

    glutSwapBuffers();            
//交換緩沖區(qū)。顯示圖形
}


//載入一個(gè).bmp格式的貼圖紋理
int LoadGLTextures(GLuint& unTexture, const char* chFileName)                
{
    AUX_RGBImageRec 
*TextureImage;                    //保存貼圖數(shù)據(jù)的指針
    TextureImage = auxDIBImageLoad("Data/NeHe.bmp"); //載入貼圖數(shù)據(jù)

    glGenTextures(
1&unTexture);                    // 創(chuàng)建一個(gè)紋理,unTexture

    glBindTexture(GL_TEXTURE_2D, unTexture);        
//綁定紋理,然后對(duì)該紋理區(qū)添加紋理數(shù)據(jù)

    
//設(shè)置紋理的信息,
    glTexImage2D(GL_TEXTURE_2D, 03, TextureImage->sizeX, TextureImage->sizeY, 0, GL_RGB, GL_UNSIGNED_BYTE, TextureImage->data);
    glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR); 
//設(shè)置濾波為線性濾波
    glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR);    //線性濾波

    
if (TextureImage)                //釋放資源
    {
        
if (TextureImage->data)
        
{
            free(TextureImage
->data);
        }

        free(TextureImage);
    }


    
return 1;
}



//初始化
void init (void
{
    glClearColor (
0.00.00.00.0);            //清理顏色,為黑色,(也可認(rèn)為是背景顏色)

    glCullFace(GL_BACK);                        
//背面裁剪(背面不可見)
    glEnable(GL_CULL_FACE);                        //啟用裁剪
    glEnable(GL_TEXTURE_2D);
    LoadGLTextures(g_texture, 
"Data/NeHe.bmp");            //載入紋理貼圖
}


//當(dāng)窗口大小改變時(shí),會(huì)調(diào)用這個(gè)函數(shù)
void reshape(GLsizei w,GLsizei h)
{
    
//這里小說明一下:矩陣模式是不同的,他們各自有一個(gè)矩陣。投影相關(guān)
    
//只能用投影矩陣。(只是目前情況下哦,等我學(xué)多了可能就知道為什么了。)

    glViewport(
0,0,w,h);        //設(shè)置視口
    glMatrixMode(GL_PROJECTION);    //設(shè)置矩陣模式為投影變換矩陣,
    glLoadIdentity();                //變?yōu)閱挝痪仃?/span>
    gluPerspective(60, (GLfloat)w / h, 01000);    //設(shè)置投影矩陣
    glMatrixMode(GL_MODELVIEW);        //設(shè)置矩陣模式為視圖矩陣(模型)
    glLoadIdentity();                //變?yōu)閱挝痪仃?/span>
}


//閑置函數(shù),當(dāng)主循環(huán)空閑時(shí)就會(huì)調(diào)用這個(gè)函數(shù)
void MyIdle(void)
{
    Sleep(
10);
    xrot
+=0.3f;        //增加旋轉(zhuǎn)的角度。
    yrot+=0.2f;
    zrot
+=0.4f;                                    
    glutPostRedisplay();
}


int main(int argc, char** argv)
{
    glutInit(
&argc, argv);        //Opnegl初始化
    glutInitDisplayMode (GLUT_DOUBLE | GLUT_RGBA); //設(shè)置顯示模式為雙緩沖,RGEBA

    glutInitWindowSize (
800600);            //窗口大小
    glutInitWindowPosition (100100);        //窗口位置
    glutCreateWindow ("hello");                //創(chuàng)建一個(gè)標(biāo)題為hello的窗口
    init ();                                //初始化資源,這里一定要在創(chuàng)建窗口以后,不然會(huì)無效。
    glutDisplayFunc(display);                //窗口大小改變時(shí)的回調(diào)
    glutReshapeFunc(reshape);                //繪制圖形時(shí)的回調(diào)
    glutIdleFunc(MyIdle);
    glutMainLoop();                            
//主循環(huán)。
    return 0;  
}

 

主要流程:

OpneGL的流程,先初始化。

1. 在Init函數(shù)中,初始化我們的信息:

glClearColor (0.0, 0.0, 0.0, 0.0); //清理顏色,為黑色,(也可認(rèn)為是背景顏色)

glCullFace(GL_BACK); //背面裁剪(背面不可見)

glEnable(GL_CULL_FACE); //啟用裁剪

glEnable(GL_TEXTURE_2D);

LoadGLTextures(g_texture"Data/NeHe.bmp"); //載入紋理貼圖

這里的順序是可以打亂的,記住一定要載入紋理,我這里是寫了一個(gè)函數(shù)來載入。然后要啟用紋理貼圖。glEnable(GL_TEXTURE_2D);。還有一件事情是比不可少的,就是一定要啟用裁剪,并且一定要用GL_BACK。我也不知道為什么,反正用glut創(chuàng)建的窗口就不可以,如果是直接用windows下創(chuàng)建的不用這個(gè)也是可以的。原理暫時(shí)還不清楚。

2 . 然后是繪制圖形:

就是繪制一個(gè)正方體,并貼上圖。

glTexCoord2f(0.0f, 1.0f); 這是貼圖的紋理坐標(biāo),在0-1范圍內(nèi),他就是把一張紋理看成0-1的區(qū)域,這就是用他該區(qū)域的紋理貼圖。

glVertex3f(-1.0f,  1.0f, -1.0f); //畫點(diǎn),這里畫點(diǎn)后,他的紋理就有上面的貼圖的紋理坐標(biāo)來確定。就確定了這點(diǎn)的貼圖信息。

3.新加了一個(gè)idle函數(shù),他能在循環(huán)空閑的時(shí)候調(diào)用,我們用他來改變旋轉(zhuǎn)的角度并重畫圖形,這樣就可以看到圖形動(dòng)起來了。

posted on 2009-04-25 11:07 shongbee2 閱讀(16087) 評(píng)論(1)  編輯 收藏 引用 所屬分類: OpenGL

評(píng)論

# re: OpenGL學(xué)習(xí)筆記【4】——給立方體紋理貼圖(texture) 2012-05-15 21:22 zwx

代碼很經(jīng)典呀。  回復(fù)  更多評(píng)論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 亚洲高清精品中出| 久久精品一区蜜桃臀影院 | 亚洲美女免费视频| 国模私拍视频一区| 国产精品美女久久久久久免费| 欧美黄色日本| 久久夜色精品亚洲噜噜国产mv| 香蕉av777xxx色综合一区| 亚洲精品激情| 亚洲人成在线观看| 欧美激情亚洲另类| 免费精品视频| 老司机精品导航| 久久亚洲电影| 欧美一级久久久| 午夜在线电影亚洲一区| 在线亚洲欧美视频| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 久久视频精品在线| 久久国产手机看片| 久久精品夜夜夜夜久久| 午夜日韩在线| 欧美中文字幕在线播放| 欧美一区二区三区成人 | 欧美国产第一页| 女同性一区二区三区人了人一 | 久热精品视频在线观看一区| 欧美一区二区三区在线观看视频 | 亚洲大片av| 亚洲高清视频的网址| 亚洲高清不卡av| 91久久精品国产91久久性色| 亚洲国产精品第一区二区| 亚洲国产精品ⅴa在线观看 | 亚洲精品资源| 一区二区三区.www| 亚洲一区二区三区高清 | 欧美国产精品久久| 欧美激情网友自拍| 亚洲欧洲在线一区| 一本色道久久综合狠狠躁篇的优点 | 国产精品人成在线观看免费| 国产精品午夜电影| 国内精品久久久久久久影视麻豆| 好吊妞**欧美| 亚洲欧洲精品一区二区三区| 日韩亚洲欧美高清| 亚洲欧美国产高清| 久久久久se| 亚洲国产第一| 一本色道婷婷久久欧美| 午夜精品视频| 老巨人导航500精品| 欧美日韩高清免费| 国产免费亚洲高清| 亚洲二区免费| 亚洲午夜日本在线观看| 久久激情视频久久| 欧美激情精品| 亚洲一区二区动漫| 久久在线免费| 国产精品美女视频网站| 精久久久久久| 亚洲午夜精品久久久久久浪潮| 久久国产精品99国产| 欧美国产极速在线| 亚洲欧美成人综合| 美日韩精品视频免费看| 欧美小视频在线观看| 一区在线免费观看| 亚洲一区中文| 欧美成人影音| 午夜精品久久久久久久白皮肤| 麻豆9191精品国产| 国产精品免费看片| 亚洲精品国产日韩| 久久精品国产清高在天天线 | 欧美不卡福利| 亚洲天堂网站在线观看视频| 玖玖视频精品| 国产欧美欧洲在线观看| 99精品国产在热久久| 久久久久久网站| 一区二区三区福利| 欧美r片在线| 国产一区二区毛片| 亚洲愉拍自拍另类高清精品| 欧美成人黄色小视频| 亚洲欧美激情一区二区| 欧美日韩123| 亚洲激情不卡| 久久婷婷人人澡人人喊人人爽| 99re66热这里只有精品4| 久久综合九色综合欧美就去吻| 国产精品日韩在线播放| 日韩视频―中文字幕| 美女露胸一区二区三区| 午夜精品福利一区二区三区av| 欧美日韩1区| 亚洲人成网站在线播| 美女福利精品视频| 久久成人精品一区二区三区| 国产精品户外野外| 在线亚洲一区二区| 亚洲国产综合在线| 能在线观看的日韩av| 好吊日精品视频| 久久精品国产一区二区三| 亚洲天堂av在线免费| 欧美日韩一视频区二区| 一本色道久久综合亚洲精品按摩| 欧美电影在线观看完整版| 久久久久久久综合| 国内精品久久久久久影视8| 久久gogo国模裸体人体| 亚洲一区二区成人在线观看| 国产精品av久久久久久麻豆网| 一区二区三区欧美在线观看| 亚洲激精日韩激精欧美精品| 欧美xx视频| 日韩视频一区二区在线观看| 亚洲福利视频网| 免费成人黄色| 亚洲毛片在线| 亚洲精品一区二区三区蜜桃久| 欧美激情乱人伦| 夜夜爽夜夜爽精品视频| 亚洲精选大片| 国产精品成人一区二区| 亚洲在线观看视频网站| 亚洲无玛一区| 国产日韩欧美91| 久久夜色精品国产亚洲aⅴ| 久久激情五月丁香伊人| 136国产福利精品导航网址应用| 蜜桃久久av一区| 欧美r片在线| 亚洲无亚洲人成网站77777| 中国亚洲黄色| 国产午夜一区二区三区| 麻豆av一区二区三区久久| 久久免费观看视频| 日韩手机在线导航| 中日韩午夜理伦电影免费| 国产精品免费一区二区三区在线观看| 欧美在线关看| 久久久久久尹人网香蕉| 亚洲精品美女久久7777777| 亚洲精品免费电影| 国产精品人人做人人爽| 久热精品视频在线| 欧美成人午夜剧场免费观看| 亚洲最新在线视频| 亚洲免费在线| 亚洲国产视频一区二区| 99视频有精品| 国产揄拍国内精品对白| 亚洲国产精品999| 国产精品久久久久久久app| 久久亚洲精品欧美| 欧美人妖另类| 久久久99免费视频| 欧美精品粉嫩高潮一区二区| 销魂美女一区二区三区视频在线| 久久精品在线播放| 一区二区三区国产在线| 久久高清免费观看| 日韩亚洲欧美一区| 久久xxxx精品视频| 一区二区欧美国产| 久久精品国内一区二区三区| 一本综合久久| 久久久免费精品视频| 亚洲永久免费视频| 久久婷婷一区| 欧美一级大片在线观看| 欧美国产成人精品| 久久国产一区二区三区| 欧美精品一区二区三区在线播放| 欧美在线视频免费观看| 欧美大片网址| 麻豆九一精品爱看视频在线观看免费 | 亚洲精品一区二区三区在线观看 | 亚洲视频福利| 蜜臀av一级做a爰片久久| 欧美尤物一区| 欧美日韩亚洲天堂| 欧美激情久久久久久| 国产欧美在线视频| 99亚洲一区二区| 亚洲人精品午夜| 久久精品国产成人| 欧美在线播放高清精品| 欧美日韩一区精品| 亚洲级视频在线观看免费1级| 狠狠色丁香婷综合久久|