www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > > 充電吧
[導(dǎo)讀]在上節(jié)課的內(nèi)容上作些擴(kuò)展,我們現(xiàn)在開(kāi)始生成真正的3D對(duì)象,而不是象前兩節(jié)課中那樣3D世界中的2D對(duì)象。我們給三角形增加一個(gè)左側(cè)面,一個(gè)右側(cè)面,一個(gè)后側(cè)面來(lái)生成一個(gè)金字塔(四棱錐)。給正方形增加左、右、

在上節(jié)課的內(nèi)容上作些擴(kuò)展,我們現(xiàn)在開(kāi)始生成真正的3D對(duì)象,而不是象前兩節(jié)課中那樣3D世界中的2D對(duì)象。我們給三角形增加一個(gè)左側(cè)面,一個(gè)右側(cè)面,一個(gè)后側(cè)面來(lái)生成一個(gè)金字塔(四棱錐)。給正方形增加左、右、上、下及背面生成一個(gè)立方體。?

我們混合金字塔上的顏色,創(chuàng)建一個(gè)平滑著色的對(duì)象。給立方體的每一面則來(lái)個(gè)不同的顏色。

只需要在上節(jié)課的基礎(chǔ)上改動(dòng)render函數(shù)

void Lesson4::render()
{
    glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);

    glViewport(0,0,(GLint)width(),(GLint)height()); // 重置當(dāng)前視口
    glMatrixMode(GL_PROJECTION);                    // 選擇投影矩陣
    glLoadIdentity();                               // 重置投影矩陣為單位矩陣
    // glu庫(kù)函數(shù)Qt不支持,但是glu庫(kù)函數(shù)是對(duì)gl庫(kù)函數(shù)的封裝,方便使用。因此我們可以自己
    // 寫(xiě)一個(gè)類(lèi)似gluPerspective的函數(shù)myPerspective,用于設(shè)置透視。
    //gluPerspective(45.0f,(GLfloat)width/(GLfloat)height,0.1f,100.0f);
    myPerspective(45.0,(GLfloat)width()/(GLfloat)height(),0.1,100.0);

    glMatrixMode(GL_MODELVIEW);// 選擇模型視圖矩陣
    glLoadIdentity();          // 重置模型視圖矩陣為單位矩陣

    glTranslatef(-1.5f,0.0f,-6.0f); // 左移1.5單位,并移入屏幕6.0
    glRotatef(rtri,0.0f,1.0f,0.0f);	// 繞Y軸旋轉(zhuǎn)金字塔

    // 注意所有的面-三角形都是逆時(shí)針次序繪制的。這點(diǎn)十分重要,在以后的課程中我會(huì)作出解釋。
    // 現(xiàn)在,您只需明白要么都逆時(shí)針,要么都順時(shí)針,但永遠(yuǎn)不要將兩種次序混在一起,
    // 除非您有足夠的理由必須這么做。
    glBegin(GL_TRIANGLES);			    // 繪制金字塔
    glColor3f(1.0f,0.0f,0.0f);			// 紅色
    glVertex3f( 0.0f, 1.0f, 0.0f);		// 三角形的上頂點(diǎn) (前側(cè)面)
    glColor3f(0.0f,1.0f,0.0f);			// 綠色
    glVertex3f(-1.0f,-1.0f, 1.0f);		// 三角形的左下頂點(diǎn) (前側(cè)面)
    glColor3f(0.0f,0.0f,1.0f);			// 藍(lán)色
    glVertex3f( 1.0f,-1.0f, 1.0f);		// 三角形的右下頂點(diǎn) (前側(cè)面)
    glColor3f(1.0f,0.0f,0.0f);			// 紅色
    glVertex3f( 0.0f, 1.0f, 0.0f);		// 三角形的上頂點(diǎn) (右側(cè)面)
    glColor3f(0.0f,0.0f,1.0f);			// 藍(lán)色
    glVertex3f( 1.0f,-1.0f, 1.0f);		// 三角形的左下頂點(diǎn) (右側(cè)面)
    glColor3f(0.0f,1.0f,0.0f);			// 綠色
    glVertex3f( 1.0f,-1.0f, -1.0f);		// 三角形的右下頂點(diǎn) (右側(cè)面)
    glColor3f(1.0f,0.0f,0.0f);			// 紅色
    glVertex3f( 0.0f, 1.0f, 0.0f);		// 三角形的上頂點(diǎn) (后側(cè)面)
    glColor3f(0.0f,1.0f,0.0f);			// 綠色
    glVertex3f( 1.0f,-1.0f, -1.0f);		// 三角形的左下頂點(diǎn) (后側(cè)面)
    glColor3f(0.0f,0.0f,1.0f);			// 藍(lán)色
    glVertex3f(-1.0f,-1.0f, -1.0f);		// 三角形的右下頂點(diǎn) (后側(cè)面)
    glColor3f(1.0f,0.0f,0.0f);			// 紅色
    glVertex3f( 0.0f, 1.0f, 0.0f);		// 三角形的上頂點(diǎn) (左側(cè)面)
    glColor3f(0.0f,0.0f,1.0f);			// 藍(lán)色
    glVertex3f(-1.0f,-1.0f,-1.0f);		// 三角形的左下頂點(diǎn) (左側(cè)面)
    glColor3f(0.0f,1.0f,0.0f);			// 綠色
    glVertex3f(-1.0f,-1.0f, 1.0f);		// 三角形的右下頂點(diǎn) (左側(cè)面)
    glEnd();                            // 金字塔繪制結(jié)束

    glLoadIdentity();
    glTranslatef(1.5f,0.0f,-6.0f);  // 右移1.5單位,并移入屏幕6.0
    glRotatef(rquad,1.0f,1.0f,1.0f);// 在XYZ軸上旋轉(zhuǎn)立方體

    glBegin(GL_QUADS);				    // 繪制立方體
    glColor3f(0.0f,1.0f,0.0f);			// 顏色改為藍(lán)色
    glVertex3f( 1.0f, 1.0f,-1.0f);		// 四邊形的右上頂點(diǎn) (頂面)
    glVertex3f(-1.0f, 1.0f,-1.0f);	    // 四邊形的左上頂點(diǎn) (頂面)
    glVertex3f(-1.0f, 1.0f, 1.0f);		// 四邊形的左下頂點(diǎn) (頂面)
    glVertex3f( 1.0f, 1.0f, 1.0f);		// 四邊形的右下頂點(diǎn) (頂面)
    glColor3f(1.0f,0.5f,0.0f);			// 顏色改成橙色
    glVertex3f( 1.0f,-1.0f, 1.0f);		// 四邊形的右上頂點(diǎn)(底面)
    glVertex3f(-1.0f,-1.0f, 1.0f);		// 四邊形的左上頂點(diǎn)(底面)
    glVertex3f(-1.0f,-1.0f,-1.0f);		// 四邊形的左下頂點(diǎn)(底面)
    glVertex3f( 1.0f,-1.0f,-1.0f);		// 四邊形的右下頂點(diǎn)(底面)
    glColor3f(1.0f,0.0f,0.0f);			// 顏色改成紅色
    glVertex3f( 1.0f, 1.0f, 1.0f);		// 四邊形的右上頂點(diǎn)(前面)
    glVertex3f(-1.0f, 1.0f, 1.0f);		// 四邊形的左上頂點(diǎn)(前面)
    glVertex3f(-1.0f,-1.0f, 1.0f);		// 四邊形的左下頂點(diǎn)(前面)
    glVertex3f( 1.0f,-1.0f, 1.0f);		// 四邊形的右下頂點(diǎn)(前面)
    glColor3f(1.0f,1.0f,0.0f);			// 顏色改成黃色
    glVertex3f( 1.0f,-1.0f,-1.0f);		// 四邊形的右上頂點(diǎn)(后面)
    glVertex3f(-1.0f,-1.0f,-1.0f);		// 四邊形的左上頂點(diǎn)(后面)
    glVertex3f(-1.0f, 1.0f,-1.0f);		// 四邊形的左下頂點(diǎn)(后面)
    glVertex3f( 1.0f, 1.0f,-1.0f);		// 四邊形的右下頂點(diǎn)(后面)
    glColor3f(0.0f,0.0f,1.0f);			// 顏色改成藍(lán)色
    glVertex3f(-1.0f, 1.0f, 1.0f);		// 四邊形的右上頂點(diǎn)(左面)
    glVertex3f(-1.0f, 1.0f,-1.0f);		// 四邊形的左上頂點(diǎn)(左面)
    glVertex3f(-1.0f,-1.0f,-1.0f);		// 四邊形的左下頂點(diǎn)(左面)
    glVertex3f(-1.0f,-1.0f, 1.0f);		// 四邊形的右下頂點(diǎn)(左面)
    glColor3f(1.0f,0.0f,1.0f);			// 顏色改成紫羅蘭色
    glVertex3f( 1.0f, 1.0f,-1.0f);		// 四邊形的右上頂點(diǎn)(右面)
    glVertex3f( 1.0f, 1.0f, 1.0f);		// 四邊形的左上頂點(diǎn)(右面)
    glVertex3f( 1.0f,-1.0f, 1.0f);		// 四邊形的左下頂點(diǎn)(右面)
    glVertex3f( 1.0f,-1.0f,-1.0f);		// 四邊形的右下頂點(diǎn)(右面)
    glEnd();						    // 立方體繪制結(jié)束
}

運(yùn)行效果


Qt5版本NeHe OpenGL教程1-5課源碼鏈接:https://download.csdn.net/download/caoshangpa/10413680

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

  PowerVR GPU系列現(xiàn)可提供從單簇到六簇內(nèi)核的多種組合   全球移動(dòng)通信大會(huì),西班牙巴塞羅那 —— 2013 年 2 月 25 日 —&md

關(guān)鍵字: 內(nèi)核 GPU ip powervr g6100 opengl es3.0

長(zhǎng)期以來(lái),Android一直為開(kāi)發(fā)人員提供免費(fèi)的用戶界面,以補(bǔ)充背景圖片的多樣化創(chuàng)建,甚至在多年前,甚至還支持在背景圖片中使用openGL。 但是,舊的移動(dòng)設(shè)備無(wú)法很好地?cái)U(kuò)展背景圖像,因此移動(dòng)實(shí)時(shí)背景圖像的開(kāi)發(fā)主要由“出...

關(guān)鍵字: Android opengl 壁紙

函數(shù)原型:?????void glLoadIdentity(void)函數(shù)說(shuō)明:????? OpenGL為我們提供了一個(gè)非常簡(jiǎn)單的恢復(fù)初始坐標(biāo)系的手段,那就是調(diào)用glLoadIdentity()命令。

關(guān)鍵字: opengl glloadidentity

pro文件QT -=gui greaterThan(QT_MAJOR_VERSION, 4): QT += widgets TARGET = lesson1 TEMPLATE = app

關(guān)鍵字: opengl QT

坐標(biāo)系統(tǒng)想要弄懂幾何變換,一定要搞清楚OpenGL中的坐標(biāo)系統(tǒng)。從我們構(gòu)造模型的局部坐標(biāo)系(Local/Object Space)經(jīng)過(guò)一系列處理最終渲染到屏幕坐標(biāo)(Screen Space)下,這過(guò)程

關(guān)鍵字: opengl 坐標(biāo)系

被用戶詬病20年后,NVIDIA終于做出讓步,在SIGGRAPH開(kāi)幕活動(dòng)中,NVIDIA發(fā)布Studio Driver: SIGGRAPH Edition驅(qū)動(dòng)程序(v431.70),正式為所有GeFo

關(guān)鍵字: NVIDIA opengl

在這一課里,將學(xué)會(huì)如何將紋理映射到立方體的六個(gè)面。學(xué)習(xí)texture map紋理映射(貼圖)有很多好處。比方說(shuō)您想讓一顆導(dǎo)彈飛過(guò)屏幕。根據(jù)前幾課的知識(shí),我們最可行的辦法可能是很多個(gè)多邊形來(lái)構(gòu)建導(dǎo)彈的輪

關(guān)鍵字: nehe opengl

當(dāng)前光柵位置:? ? 當(dāng)前光柵位置就是開(kāi)始繪制下一幅位圖/圖像的屏幕位置。 ?//左下角glRasterPos2f(GLfloat x, GLfloat y);glRasterPos3f(GLfloa

關(guān)鍵字: opengl

這一課將把如下圖片做成一個(gè)飄動(dòng)的旗幟,其實(shí)主要還是用到了紋理映射。lesson10.h#ifndef?LESSON10_H #define?LESSON10_H #include#include#i

關(guān)鍵字: opengl QT

在這一課里,我們將添加光照和鍵盤(pán)控制,它讓程序看起來(lái)更美觀?,F(xiàn)在設(shè)置4個(gè)變量來(lái)控制繞x軸和y軸旋轉(zhuǎn)角度的步長(zhǎng),以及繞x軸和y軸的旋轉(zhuǎn)速度。另外還創(chuàng)建了一個(gè)z變量來(lái)控制進(jìn)入屏幕深處的距離。并添加一個(gè)布爾

關(guān)鍵字: opengl qt5
關(guān)閉