




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領
文檔簡介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上實驗四 OpenGL多邊形存儲及繪制 序號: 姓名: 學號: 成績 指導教師: 廖赟 1實驗目的:基于OpenGL畫點函數(shù),讀取box.obj文件中的頂點坐標,繪制多邊形。2實驗環(huán)境:(1)運行win7/win8/win10操作系統(tǒng)的PC一臺(2)每臺PC機安裝VC+開發(fā)環(huán)境3實驗步驟:a、讀取box.obj中頂點信息,如下。b、其中行開頭v 代表頂點,之后兩個數(shù)字表示頂點坐標(X,Y),坐標原點(0,0)位于窗口左下角。c、其中行開頭f代表多邊形頂點索引,之后數(shù)字表示多邊形頂點索引,索引下標從0開始,下標0表示頂點數(shù)據(jù)第一行,下標1表示頂點數(shù)據(jù)第二行,以此類推。d、
2、實現(xiàn)頂點表及面片表相關數(shù)據(jù)結(jié)構(gòu)。e、繪制索引所要求的兩個多邊形。4實驗分析,回答下列問題(1)算法流程圖lineSegment(): NoYes No Yes ReadFile():noyesyesnononoyesyesnoyesnoyesyesnoyesnoyes(2)多邊形繪制算法代碼(包含完整注釋)答:#include "windows.h"#include <iostream>#include <fstream>#define GLUT_DISABLE_ATEXIT_HACK#include "GL.h"#include
3、 "GLU.h"#include "GLUT.h"using namespace std;int v100;int f1010;void init(void)glClearColor(1.0, 1.0, 1.0, 0.0); /設置窗口背景顏色為白色glMatrixMode(GL_PROJECTION); /設置投影參數(shù)gluOrtho2D(0.0, 400.0, 0.0, 450.0);void lineSegment(void)glClear(GL_COLOR_BUFFER_BIT);glColor3f(0.0,0.0,0.0); /設置點顏色for
4、(int y = 0,j = 1; fj0!=fj1; j+)for(;fjy+1 != fj0;y+) /第一個多邊形glBegin(GL_LINES);glVertex2i(v2*fjy, v2*fjy+1);glVertex2i(v2*fjy+1, v2*fjy+1+1); glEnd();/第二個多邊形glBegin(GL_LINES);glVertex2i(v2*fjy, v2*fjy+1);glVertex2i(v2*fj0, v2*fj0+1);glEnd();y=0;glFlush();void ReadFile()ifstream in;string file;in.open
5、("E:/學校學習/計算機圖形學/計算機圖形學_實驗4/box.obj");if(!in)printf("打開失敗");char ch;int num = 0;int i = 0;bool isv = true; /為true存入數(shù)組vbool isf = false; /為true存入數(shù)組fint j = 0;int y = 0;while(!in.eof()in.read(&ch,1); /每次讀取一個字節(jié)存在ch中if(ch='f')isv = false;j+;y = 0;if(isv)if (ch>=48&
6、&ch<=57)num = num * 10 + (int)ch-48; /計算頂點坐標值, 48對應0,57對應9if(ch=' ')if(num!=0)vi+ = num;/存入頂點坐標值 num = 0;elseif (ch>=48&&ch<=57)num = num * 10 + (int)ch-48,isf = true; /計算頂點索引if(ch=' ')if(isf)fjy+ = num,isf = false; /存入頂點索引值num = 0;int main(int argc, CHAR* argv)g
7、lutInit(&argc, argv);glutInitDisplayMode(GLUT_SINGLE|GLUT_RGB); /初始化窗口的顯示模式glutInitWindowPosition(50, 100); /設置窗口的位置glutCreateWindow("line segment"); /創(chuàng)建一個名為"line segment"的窗口ReadFile();init(); /完成窗口初始化glutDisplayFunc(lineSegment); /設置當前窗口的顯示回調(diào)函數(shù)glutMainLoop(); /啟動主GLUT事件處理循環(huán)return 0;(3)簡述多邊形機內(nèi)表示形式?答:多邊形在機內(nèi)以數(shù)據(jù)表的形式表示。在輸入每個多邊形的信息時,數(shù)據(jù)放進一些表格中等待后續(xù)處理、顯示和場景的對象管理。這些多邊形數(shù)據(jù)表分成幾何數(shù)據(jù)表和屬性數(shù)據(jù)表。幾何數(shù)據(jù)表存放頂點坐標和標識多邊形面片空間方向的參數(shù),屬性數(shù)據(jù)表存放指定對象
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年輔警招聘考試綜合提升試卷附答案詳解(研優(yōu)卷)
- 2022年2月韶關市直遴選面試真題附解析
- 2022年11月三明市稅務系統(tǒng)遴選面試真題帶詳細解析
- 2025年行政執(zhí)法基礎知識綜合練習題含答案詳解(綜合卷)
- 2025年皖北煤電集團總醫(yī)院招聘24人筆試備考題庫及1套參考答案詳解
- 麗江云南麗江市交通運輸綜合行政執(zhí)法支隊執(zhí)法輔助人員招聘6人筆試歷年參考題庫含答案詳解(滿分必刷)
- Chlorogentisylquinone-生命科學試劑-MCE
- 2025企業(yè)員工雇傭合同協(xié)議
- 2025企業(yè)間借款合同范本2
- 2023-2024學年河北省保定市曲陽縣統(tǒng)編版六年級下冊期末考試語文試卷
- 公司崗變薪變管理制度
- 影像科招聘試題及答案
- 2025年六五環(huán)境日生態(tài)環(huán)保常識及法律知識有獎競答題庫及答案(共90題)
- 上海市社區(qū)工作者管理辦法
- 湖南師范大學學位英語歷年考試真題
- 腦卒中康復PPT醫(yī)學課件
- 老年人的居家護理課件
- PCB 企業(yè)生產(chǎn)工藝及風險點
- 消防安全工作臺賬-消防臺賬記錄
- 中醫(yī)腫瘤臨床路徑
- 中考數(shù)學《分式及分式方程》計算題(附答案)
評論
0/150
提交評論