




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、 計算機圖形學基礎 實驗報告實驗序號:03 實驗項目名稱:多邊形填充算法的實現學號姓名專業、班級軟件工程實驗地點計-201指導教師時 間2016.4.05一、實驗目的及要求多邊形的填充算法有很多種,比如說邊緣填充算法,柵欄填充算法,還有種子填充算法。種子填充算法和其他幾種的算法采用的是完全不同的方法。二、實驗設備(環境)及要求1、了解MATLAB軟件基本操作,熟悉基本計算和繪圖功能。 2、環境要求:配有Windows XP及以上操作系統,安裝MATLAB軟件的完整版。 3、實驗過程中,務必仔細觀察上機現象,記錄必要信息,分析實驗結果,按要求寫出實驗報告。三、實驗內容與步驟題目:多邊形填充算法的
2、實現 四、實驗結果與數據處理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,"雙擊鼠標左鍵,生成多邊形");pDC->TextOut(20,50,"先在多邊形內部單擊鼠標右鍵,選擇種子點,然后單擊功能菜單實現填充");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. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025中介貿易合同范本
- 2025鞋店租賃合同樣本
- 稅貸借款合同范本
- 2025土地承包權轉讓合同樣本
- 酒店安全形勢分析會
- 2025年商業店鋪裝修合同范本
- 解除基站租賃合同范本
- 老年護理教師說課
- 鐵路集裝箱堆場管理
- 養生店前臺合同范本
- 世界投資報告2024 (概述)- 投資便利化和數字政務
- 2024年三級直播銷售員(高級)職業技能鑒定考試復習題庫(含答案)
- 2024-2030年中國高壓泵行業市場發展趨勢與前景展望戰略分析報告
- 青海省勞動合同范本「標準版」
- 回歸以人為本 課件-2024-2025學年高中美術人教版 (2019) 選擇性必修4 設計
- 安徽省合肥市一中、六中、八中2025屆高三下學期一模考試生物試題含解析
- SL+303-2017水利水電工程施工組織設計規范
- 2024年全國中學生生物學聯賽試題
- 國企外聘合同范本
- 2024年第九屆“鵬程杯”六年級語文邀請賽試卷(復賽)
- 人教版高中化學必修二《第一節 硫及其化合物》同步練習及答案解析
評論
0/150
提交評論