




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、計(jì)算機(jī)圖形學(xué)實(shí)驗(yàn)報(bào)告任課教師:錢(qián)文華2016年春季學(xué)期實(shí)驗(yàn):四連通區(qū)域種子填充算法實(shí)驗(yàn)時(shí)間:2016年12月8日實(shí)驗(yàn)地點(diǎn):信息學(xué)院2204實(shí)驗(yàn)?zāi)康模赫莆辗N子填充算法的原理,并會(huì)用種子填充算法和opengl并結(jié)合使用C+語(yǔ)言編寫(xiě)程序繪制多邊形實(shí)驗(yàn)原理:種子填充算法又稱為邊界填充算法。其基本思想是:從多邊形區(qū)域的一個(gè)內(nèi)點(diǎn)開(kāi)始,由內(nèi)向外用給定的顏色畫(huà)點(diǎn)直到邊界為止。如果邊界是以一種顏色指定的,則種子填充算法可逐個(gè)像素地處理直到遇到邊界顏色為止。內(nèi)點(diǎn)的檢測(cè)條件:if(interiorColor!=borderColor&&interiorColor!=fillColor)。種子填充算法
2、常用四連通域和八連通域技術(shù)進(jìn)行填充操作。從區(qū)域內(nèi)任意一點(diǎn)出發(fā),通過(guò)上、下、左、右四個(gè)方向到達(dá)區(qū)域內(nèi)的任意像素。用這種方法填充的區(qū)域就稱為四連通域;這種填充方法稱為四向連通算法。從區(qū)域內(nèi)任意一點(diǎn)出發(fā),通過(guò)上、下、左、右、左上、左下、右上和右下八個(gè)方向到達(dá)區(qū)域內(nèi)的任意像素。用這種方法填充的區(qū)域就稱為八連通域;這種填充方法稱為八向連通算法。一般來(lái)說(shuō),八向連通算法可以填充四向連通區(qū)域,而四向連通算法有時(shí)不能填充八向連通區(qū)域。四向連通填充算法:a)種子像素壓入棧中;b)如果棧為空,則轉(zhuǎn)e);否則轉(zhuǎn)c);c)彈出一個(gè)像素,并將該像素置成填充色;并判斷該像素相鄰的四連通像素是否為邊界色或已經(jīng)置成多邊形的填充
3、色,若不是,則將該像素壓入棧;d)轉(zhuǎn)b);e)結(jié)束。四連通填充算法利用到了遞歸的思想。本實(shí)驗(yàn)只包括四連通填充算法程序代碼:#include<glut.h>#include<stdlib.h>#include<math.h>#include<windows.h>voidinit(void)glClearC010r(1.0,1.0,1.0,0.0);glMatrixMode(GL_PROJECTION);gluOrtho2D(0.0,300.0,0.0,300.0);y,longvoidsetPixel(intx,intfillColor)glCol
4、or3f(fillC010r<<16,fillC010r<<8,fillColor);glBegin(GL_POINTS);glVertex2i(x,y);glEnd();voidboundaryFill4(intx,inty,longfillColor,longborderColor)unsignedcharparams3;longinteriorColor;glReadPixels(x,y,1,1,GL_RGB,GL_UNSIGNED_BYTE,params);interiorColor=RGB(params0,params1,params2);if(interio
5、rColor!=borderColor&&interiorColor!=fillColor)setPixel(x,y,fillColor);boundaryFill4(x+1,y,fillColor,borderColor);boundaryFill4(x-1,y,fillColor,borderColor);boundaryFill4(x,y+1,fillColor,borderColor);boundaryFill4(x,y-1,fillColor,borderColor);voidlineSegment(void)longborderColor=RGB(255,0,0);
6、longfillColor=RGB(0,0,255);glClear(GL_COLOR_BUFFER_BIT);glColor3f(255,0,0);glBegin(GL_LINE_LOOP);glVertex2i(0,40);glVertex2i(20,0);glVertex2i(60,0);glVertex2i(80,40);glVertex2i(60,80);glVertex2i(20,80);glEnd();boundaryFill4(60,60,fillColor,borderColor);glFlush();voidmain(intargc,char*argv)glutInit(&
7、amp;argc,argv);glutInitDisplayMode(GLUT_SINGLE|GLUT_RGB);glutInitWindowPosition(150,100);glutInitWindowSize(300,300);glutCreateWindow("種子填充");init();glutDisplayFunc(lineSegment);glutMainLoop();上實(shí)驗(yàn)課時(shí)機(jī)房的實(shí)驗(yàn)結(jié)果他疆克M刊j中咽亡恬,/司發(fā)|Fh:、此E2密曜*左±31nJoKnii<£twaMnpli腌國(guó)外箝乘;弭TWd:i,U卓爾如1a盧rtrS?招
8、后來(lái)的實(shí)驗(yàn)結(jié)果:glVertex2i(0,40);glVertex2i(20,0);glVertex2i(60,0);glVertex2i(80,40);glVertex2i(60,80);glVertex2i(20,80);glEnd();boundaryFill4(60,60,f川Color,borderColor);以上這段程序改成如下glVertex2i(90,40);glVertex2i(120,100);glVertex2i(90,160);glVertex2i(60,160);glVertex2i(60,40);glEnd();boundaryFill4(70,60,f川Colo
9、r,borderColor);改變參數(shù)后:再把glVertex2i(90,40);glVertex2i(120,100);glVertex2i(90,160);glVertex2i(60,160);glVertex2i(60,40);glEnd();boundaryFill4(70,60,f川Color,borderColor);改成glVertex2i(100,100);glVertex2i(200,100);glVertex2i(150,150);/glVertex2i(60,160);/glVertex2i(60,40);glEnd();boundaryFill4(150,120,fillColor,borderColor);后的結(jié)果如下圖:實(shí)驗(yàn)總結(jié):通過(guò)多組數(shù)據(jù)的測(cè)試,知道了上面算法的正確,普適性。種子填充的遞歸算法的優(yōu)點(diǎn)是原理非常簡(jiǎn)單,容易理解,缺點(diǎn)是由于多次遞歸,費(fèi)時(shí),費(fèi)內(nèi)存,效率不高,需要大量??臻g來(lái)存儲(chǔ)相鄰的點(diǎn),
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 內(nèi)容豐富的2025年市政工程試題及答案
- 工程經(jīng)濟(jì)實(shí)戰(zhàn)技巧試題及答案
- 教研學(xué)期工作成果分享計(jì)劃
- 五年級(jí)心理健康教育
- 營(yíng)銷(xiāo)行業(yè)安全管理回顧計(jì)劃
- 樹(shù)立積極職場(chǎng)心態(tài)的實(shí)施方案計(jì)劃
- 2024年石英電渦流水平傾斜儀項(xiàng)目資金需求報(bào)告代可行性研究報(bào)告
- 工程經(jīng)濟(jì)行業(yè)與市場(chǎng)趨向試題及答案
- 車(chē)輛及交通工具采購(gòu)協(xié)議
- 卡點(diǎn)清晰2025年工程項(xiàng)目管理試題及答案
- 2022年全國(guó)統(tǒng)一高考化學(xué)試卷和答案解析(全國(guó)甲卷)
- 唐代的文學(xué)傳播研究
- 【海瀾之家公司盈利能力探析11000字】
- pc板冷折彎工藝
- 中國(guó)傳統(tǒng)色彩文化
- 2022年1月上海春季高考英語(yǔ)真題(學(xué)生版+解析版+聽(tīng)力音頻)
- 【物流產(chǎn)業(yè)集群發(fā)展研究文獻(xiàn)綜述4800字】
- 幼兒園區(qū)域材料采購(gòu)清單
- 中國(guó)傳統(tǒng)音樂(lè)與西方音樂(lè)的對(duì)比與融合
- 廠內(nèi)運(yùn)輸車(chē)輛專項(xiàng)安全檢查表
- 企業(yè)商學(xué)院的組織架構(gòu)和培訓(xùn)體系架構(gòu)
評(píng)論
0/150
提交評(píng)論