




版權(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é)基礎(chǔ) 實(shí)驗(yàn)報(bào)告實(shí)驗(yàn)序號(hào):03 實(shí)驗(yàn)項(xiàng)目名稱:多邊形填充算法的實(shí)現(xiàn)學(xué)號(hào)姓名專業(yè)、班級(jí)軟件工程實(shí)驗(yàn)地點(diǎn)計(jì)-201指導(dǎo)教師時(shí) 間2016.4.05一、實(shí)驗(yàn)?zāi)康募耙蠖噙呅蔚奶畛渌惴ㄓ泻芏喾N,比如說(shuō)邊緣填充算法,柵欄填充算法,還有種子填充算法。種子填充算法和其他幾種的算法采用的是完全不同的方法。二、實(shí)驗(yàn)設(shè)備(環(huán)境)及要求1、了解MATLAB軟件基本操作,熟悉基本計(jì)算和繪圖功能。 2、環(huán)境要求:配有Windows XP及以上操作系統(tǒng),安裝MATLAB軟件的完整版。 3、實(shí)驗(yàn)過程中,務(wù)必仔細(xì)觀察上機(jī)現(xiàn)象,記錄必要信息,分析實(shí)驗(yàn)結(jié)果,按要求寫出實(shí)驗(yàn)報(bào)告。三、實(shí)驗(yàn)內(nèi)容與步驟題目:多邊形填充算法的
2、實(shí)現(xiàn) 四、實(shí)驗(yàn)結(jié)果與數(shù)據(jù)處理class CDrawView:public CViewprotected:/create from serialization onlyCDrawView();DECLARE_DYNCREATE(CDrawView)public:CDrawDoc*GetDocument();public:CPoint spt7,s_point;.void CDrawView:OnDraw(CDC*pDC)CDrawDoc*pDoc=GetDocument();ASSERT_VALID(pDoc);CPen newpen(PS_SOLID,1,RGB(0,0,255);CPen*o
3、ld=pDC->SelectObject(&newpen);pDC->TextOut(20,20,"雙擊鼠標(biāo)左鍵,生成多邊形");pDC->TextOut(20,50,"先在多邊形內(nèi)部單擊鼠標(biāo)右鍵,選擇種子點(diǎn),然后單擊功能菜單實(shí)現(xiàn)填充");pDC->SelectObject(old);void CDrawView:OnSeedfill()CclientDC dc(this);int fill=RGB(0,255,0);int boundary=RGB(0,0,255);int x,y,p0,pmin,pmax;for(in
4、t m=1;m<7;m+)for(int n=0;n<7-m;n+)if(sptn.y<sptn+1.y)p0=sptn.y; sptn=sptn+1;sptn+1=p0;pmax=spt0.y;pmin=spt6.y;x=s_point.x;y=s_point.y;for(;y<=pmax;y+)int current=dc.GetPixel(x,y);while(current!=boundary)&&(current!=fill)dc.SetPixel(x,y,fill);x+;current=dc,GetPixel(x,y);x=s-point.
5、x;x-;current=dc.GetPixel(x,y); while(current!=boundary)&&(current!=fill)dc.SetPixel(x,y,fill);x-;current=dc,GetPixel(x,y);x=s-point.x;x=s_point.x;y=s_point.y-1;for(;y>=pmin;y-)int current=dc.GetPixel(x,y);while(current!=boundary)&&(current!=fill)dc.SetPixel(x,y,fill);x+;current=dc
6、,GetPixel(x,y);x=s-point.x;x-;current=dc.GetPixel(x,y); while(current!=boundary)&&(current!=fill)dc.SetPixel(x,y,fill);x-;current=dc,GetPixel(x,y);x=s-point.x;void CDrawView:OnLButtonDblClk(UINT nFlags,CPoint point)RedrawWindow();CDC*pDC=GetDC(); CPen newpen(PS_SOLID,1,RGB(0,0,255); CPen*old
7、=pDC->SelectObject(&newpen);spt0=CPoint(100,100); spt1=CPoint(250,100); spt2=CPoint(250,250);spt3=CPoint(100,250);spt4=CPoint(150,200); spt5=CPoint(90,150); spt6=CPoint(160,150); spt7=CPoint(100,100); pDC->SelectObject(old);CView:OnLButtonDblClk(nFlags,point);void CDrawView:OnLButtonDown(U
8、INT nFlags,CPoint point)s_point=pont;CView:OnRButtonDown(nFlags,point);CView:OnLButtonDblClk(nFlags, point);void CMy2dcadView:makeet()()int p1=0,p2=1;int smally,bigy,smallx,bigx;Edge*ep1;for(; p1<npoint;p1+,p2=(+p2)% npoint)if(lhpointp11=lhpointp21)continue;else if (lhpointp11<lhpointp21)small
9、y=lhpointp11;bigy=lhpointp21;smallx=lhpointp10;bigx=lhpointp20; else smally=lhpointp21;bigy=lhpointp11;smallx=lhpointp20;bigx=lhpointp10;ep1=new Edge;ep1->ymax=bigy;ep1->x=(float)smallx;ep1->deltax=(float)(smallx-bigx)/(smally-bigy);ep1->nextEdge=etsmally;etsmally=ep1;void CMy2dcadView:O
10、nRButtonDown(UINT nFlags,CPint point)/TODO:Add your message handler code here and/or call defaultCView:OnRButtonDown(nFlag,point);CClientDC dc(this);COLORREF Color;int scany=-1;int i=0,j=0;int k;int r,g,b;Edge*etp;makeet();while (et+scany=NULL);While(scany<600)if(etscany!=NULL)etp=etscany;while(etp)i=scany;while(i<etp->ymax)j=(int)etp->x;j+;while(i<600)Color=dc.GetPixel(j,i);r=255-GetRValue(Color);G=255-GetGValue(Color);B=25
溫馨提示
- 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ù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- DB32/T 3610.1-2019道路運(yùn)輸車輛主動(dòng)安全智能防控系統(tǒng)技術(shù)規(guī)范第1部分:平臺(tái)
- DB32/T 3562-2019橋梁結(jié)構(gòu)健康監(jiān)測(cè)系統(tǒng)設(shè)計(jì)規(guī)范
- DB31/T 968.2-2016全過程信用管理要求第2部分:行為清單編制指南
- DB31/T 820-2014肉鴿屠宰場(chǎng)防疫技術(shù)規(guī)范
- DB31/T 578-2011飼料中玉米赤霉醇類物質(zhì)的測(cè)定液相色譜-串聯(lián)質(zhì)譜法
- DB31/T 1419-2023醫(yī)療付費(fèi)“一件事”應(yīng)用規(guī)范
- DB31/T 1384-2022城市綠地防雷通用技術(shù)要求
- DB31/T 1363-2022口腔綜合治療臺(tái)水路衛(wèi)生管理要求
- DB31/T 1299-2021電梯轎廂上行超速保護(hù)裝置現(xiàn)場(chǎng)試驗(yàn)方法
- DB31/T 1266-2020乘用車自主緊急制動(dòng)系統(tǒng)技術(shù)要求及測(cè)試方法
- 2021年上海市高考英語(yǔ)試卷(春考)(解析卷)
- 《中國(guó)政法大學(xué)》課件
- 《湯姆索亞歷險(xiǎn)記》測(cè)試題(含答案)
- MySQL數(shù)據(jù)庫(kù)設(shè)計(jì)與應(yīng)用知到智慧樹章節(jié)測(cè)試課后答案2024年秋昆明理工大學(xué)
- 《“珍牡腎骨膠囊”對(duì)維持性血透患者鈣磷代謝紊亂的影響》
- 【MOOC】金融法學(xué)-浙江財(cái)經(jīng)大學(xué) 中國(guó)大學(xué)慕課MOOC答案
- 道路施工交通分流方案終版
- GB/T 44902-2024木工機(jī)床安全共同性要求
- 24秋國(guó)家開放大學(xué)《科學(xué)與技術(shù)》終結(jié)性考核大作業(yè)參考答案
- 商務(wù)談判經(jīng)典案例全案(56個(gè)案例)
- 《環(huán)境影響評(píng)價(jià)》全套教學(xué)課件
評(píng)論
0/150
提交評(píng)論