版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
《計(jì)算機(jī)圖形學(xué)》實(shí)驗(yàn)報(bào)告《實(shí)驗(yàn)名稱(chēng)》直線段裁剪姓名學(xué)號(hào)專(zhuān)業(yè)班級(jí)天津大學(xué)計(jì)算機(jī)科學(xué)與技術(shù)學(xué)院一、實(shí)驗(yàn)?zāi)康募兪煺莆誄ohen-Sutherland直線裁剪算法,并編程實(shí)現(xiàn)二、實(shí)驗(yàn)內(nèi)容(1)裁剪窗口為矩形窗口,且矩形邊和坐標(biāo)軸平行,長(zhǎng)寬自己定。(2)待裁剪線段端點(diǎn)坐標(biāo)自己定;裁剪線段涵蓋完全可見(jiàn)、不完全可見(jiàn)、完全不可見(jiàn)類(lèi)型。(3)規(guī)定顯示待裁剪線段并用不同顏色標(biāo)示出裁剪結(jié)果。實(shí)現(xiàn)方法:一般情況下,需要判斷一條直線是所有可見(jiàn),所有不可見(jiàn),部分裁剪(一段裁剪),所有裁剪(兩端裁剪)。通過(guò)把裁剪區(qū)域提成許多部分,然后給每一段被裁剪的線段的兩端分派一位代碼,通過(guò)少量if語(yǔ)句和一個(gè)case語(yǔ)句就可以判斷出具體情況。偽代碼如下:#defineCLIP_CODE_(tái)C 0x0000#defineCLIP_CODE_N 0x0008#defineCLIP_CODE_S?0x0004#defineCLIP_CODE_(tái)E?0x0002#defineCLIP_CODE_W 0x0001#defineCLIP_CODE_NE?0x000a#defineCLIP_CODE_SE?0x0006#defineCLIP_CODE_NW?0x0009#defineCLIP_CODE_SW 0x0005實(shí)驗(yàn)環(huán)節(jié):1)生成裁剪窗口,窗口由直線xl=250,xr=850,yb=250,yt=4502)繪制直線段3)編寫(xiě)Cohen-Sutherland直線裁剪算法,對(duì)直線段進(jìn)行裁剪編碼定義規(guī)則:第一位C1:若端點(diǎn)位于窗口之左側(cè),即X<xl,則C1=1,否則C1=0。第二位C2:若端點(diǎn)位于窗口之右側(cè),即X>xr,則C2=1,否則C2=0。第三位C3:若端點(diǎn)位于窗口之下側(cè),即Y<yb,則C3=1,否則C3=0。第四位C4:若端點(diǎn)位于窗口之上側(cè),即Y>yt,則C4=1,否則C4=0。裁剪環(huán)節(jié):對(duì)所有直線的端點(diǎn)都建立了區(qū)域碼之后,就可按區(qū)域碼判斷直線在窗口之內(nèi)或窗口之外。這可分為如下幾種情況:①若一直線的兩個(gè)端點(diǎn)的區(qū)域碼均為0000則此直線在窗口邊界之內(nèi),應(yīng)子保存。②若一直線的兩個(gè)端點(diǎn)的區(qū)域碼的同一位同時(shí)為1,則此直線所有在窗口邊界之外,應(yīng)子裁剪。例如,若一直線的一個(gè)端點(diǎn)的區(qū)域碼為1001,另一個(gè)端點(diǎn)的區(qū)域碼為0101,則此兩端點(diǎn)的區(qū)域碼的第一位均為1,說(shuō)明此兩端點(diǎn)均在窗口邊界之左,因此,直線在窗口邊界之外,應(yīng)予裁剪??捎脤⒅本€兩個(gè)端點(diǎn)的區(qū)域碼進(jìn)行與操作的方法,判斷直線是否在窗口之外,若與操作的結(jié)果為0000則兩端點(diǎn)的區(qū)域碼任何位均不同時(shí)為1此直線不一定被裁剪。③以上兩種情況之外的直線,有也許穿過(guò)窗口,也有也許不穿過(guò)窗口,下圖中所示的兩條直線都不符合情況②的規(guī)定,但一條直線(P1P(pán)2)穿過(guò)窗口,另一直線(P3P4)不穿過(guò)窗口。對(duì)這類(lèi)直線可以進(jìn)行如下解決:取窗口外的一個(gè)端點(diǎn)與窗口邊界比較以擬定可排除直線的哪一部分,然后,把直線剩下的部分與其他邊界比較,這樣一直到直線所有被排除或擬定直線的哪一部分在窗口之內(nèi)為止??砂础白蟆⒂?、下、上”的順序建立檢查直線端點(diǎn)與窗口邊界關(guān)系的算法。圖③三、實(shí)驗(yàn)結(jié)果?畫(huà)線效果一:畫(huà)線效果二:其他效果用戶可自行繪制四、實(shí)驗(yàn)分析和總結(jié)掌握了openGL的基本用法,掌握了Cohen-Sutherland直線裁剪算法,并編程實(shí)現(xiàn)出來(lái).五、源代碼voidCCsLineView::Cohen()//Cohen-Sutherland算法{ BOOLChange;?doublex,y; RC0=EnCode(Pointx[0],Pointy[0]);?RC1=EnCode(Pointx[1],Pointy[1]); while(TRUE) {? ? Change=FALSE; ?if(0==(RC0|RC1))??{//簡(jiǎn)取之? ?return; ?} elseif(0!=(RC0&RC1)) {//簡(jiǎn)棄之?? return; ?} else??{???if(0==RC0)//假如P0點(diǎn)在窗口內(nèi),互換P0和P1,保證p0點(diǎn)在窗口外 ? {? ? //互換點(diǎn)的坐標(biāo)值 ? doubleTPointx,TPointy;??? TPointx=Pointx[0];TPointy=Pointy[0];? ??Pointx[0]=Pointx[1];Pointy[0]=Pointy[1];????Pointx[1]=TPointx;Pointy[1]=TPointy;??? //互換點(diǎn)的編碼值 ? unsignedintTRC; ? TRC=RC0;RC0=RC1;RC1=TRC; ? }???//按左、右、下、上的順序裁剪 ? if(RC0&LEFT)//P0點(diǎn)位于窗口的左側(cè) {????x=wxl;//求交點(diǎn)y?? ?y=Pointy[0]+(Pointy[1]-Pointy[0])*(x-Pointx[0])/(Pointx[1]-Pointx[0]);? ? Pointx[0]=x;Pointy[0]=y; ? ?Change=TRUE;? ?RC0=EnCode(Pointx[0],Pointy[0]);RC1=EnCode(Pointx[1],Pointy[1]); }?? ?if(RC0&RIGHT)//P0點(diǎn)位于窗口的右側(cè)?? {?? x=wxr;//求交點(diǎn)y? ? y=Pointy[0]+(Pointy[1]-Pointy[0])*(x-Pointx[0])/(Pointx[1]-Pointx[0]);?? Pointx[0]=x;Pointy[0]=y;? ? Change=TRUE; ?RC0=EnCode(Pointx[0],Pointy[0]);RC1=EnCode(Pointx[1],Pointy[1]); ?}?? ?? if(RC0&BOTTOM)//P0點(diǎn)位于窗口的下側(cè)???{?? ?y=wyb;//求交點(diǎn)x ? x=Pointx[0]+(Pointx[1]-Pointx[0])*(y-Pointy[0])/(Pointy[1]-Pointy[0]); ? Pointx[0]=x;Pointy[0]=y; ? ?Change=TRUE;??? RC0=EnCode(Pointx[0],Pointy[0]);RC1=EnCode(Pointx[1],Pointy[1]);?? } ??? if(RC0&TOP)//P0點(diǎn)位于窗口的上側(cè)?? { ? ?y=wyt;//求交點(diǎn)x? x=Pointx[0]+(Pointx[1]-Pointx[0])*(y-Pointy[0])/(Pointy[1]-Pointy[0]);? Pointx[0]=x;Pointy[0]=y;?? ?Change=TRUE; ?? RC0=EnCode(Pointx[0],Pointy[0]);RC1=EnCode(Pointx[1],Pointy[1]); ? }? if(FALSE==Change) ? { ? ?return;???} } }}voidCCsLineView::OnDraw(CDC*pDC){ CRectRect; GetClientRect(&Rect);//獲得客戶區(qū)的大小?CBitmap Bitmap,*pBitmap; Bitmap.LoadBitmap(IDB_BITMAP1); CDC MemDC; MemDC.CreateCompatibleDC(GetDC()); pBitmap=MemDC.SelectObject(&Bitmap); MemDC.BitBlt(0,0,Rect.Width(),Rect.Height(),&Picture,0,0,SRCCOPY); ?MemDC.TextOut((wxl+wxr)/2,wyb-20,"窗口");//窗口標(biāo)題 //繪制窗口和直線 CPenPen3,*pOldPen3;//定義3個(gè)像素寬度的畫(huà)筆 Pen3.CreatePen(PS_SOLID,2,RGB(0,0,0));?pOldPen3=MemDC.SelectObject(&Pen3); MemDC.MoveTo(wxl,wyt);MemDC.LineTo(wxr,wyt);?MemDC.LineTo(wxr,wyb);MemDC.LineTo(wxl,wyb); MemDC.LineTo(wxl,wyt);MemDC.SelectObject(pOldPen3); Pen3.DeleteObject(); CPenPen1,*pOldPen1;//定義1個(gè)像素寬度的畫(huà)筆?Pen1.CreatePen(PS_SOLID,2,RGB(255,0,0));?pOldPen1=MemDC.SelectObject(&Pen1);? if(m_i>=1) {? MemDC.MoveTo(ROUND(Pointx[0]),ROUND(Pointy[0])); ?MemDC.LineTo(ROUND(Pointx[1]),ROUND(Pointy[1])); ? } MemDC.SelectObject(pOldPen1); Pen1.DeleteObject();? CDC*dc=GetDC(); dc->BitBlt(0,0,Rect.Width(),Rect.Height(),&MemDC,0,0,SRCCOPY);?MemDC.SelectObject(pBitmap);}voidCCsLineView::Ondrawline()//屏幕畫(huà)線函數(shù){??if(FALSE==m_Attat(yī)ch)?{ ?Picture.CreateCompatibleDC(GetDC());??CBitmap *Bitmap,*pBitmap;? Bitmap=newCBitmap; Bitmap->LoadBitmap(IDB_BITMAP1); ?pB(yǎng)itmap=Picture.SelectObject(Bitmap);? m_Attatch=TRUE;?} m_Draw=TRUE;?m_i=0; Invalidate(FALSE);?AfxGetMainWnd()->SetWindowText("Cohen-Sutherland直線裁剪算法");//顯示標(biāo)題?MessageBox("請(qǐng)使用鼠標(biāo)在屏幕上繪制直線,然后點(diǎn)擊裁剪按鈕進(jìn)行裁剪","提醒",MB_OKCANCEL); }voidCCsLineView::OnMouseMove(UINTnFlags,CPointpoint)//鼠標(biāo)移動(dòng)函數(shù){ //TODO:Addyourmessagehandlercodehereand/orcalldefault?if(TRUE==m_Draw) { ?if(m_i<2) {???Pointx[m_i]=point.x;Pointy[m_i]=point.y; ??Invalidate
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年其他計(jì)算機(jī)信息服務(wù)合作協(xié)議書(shū)
- 2025年聚氧乙烯醚合作協(xié)議書(shū)
- 2025年谷胱甘肽及酵母提取物合作協(xié)議書(shū)
- 2025年中外合資經(jīng)營(yíng)員工企業(yè)勞動(dòng)合同(2篇)
- 2025年中學(xué)一年級(jí)班主任工作小結(jié)模版(三篇)
- 2025年二手房出租合同簡(jiǎn)單版(2篇)
- 2025年個(gè)人租房合租協(xié)議(2篇)
- 2025年個(gè)人承租房屋協(xié)議范文(2篇)
- 2025年代理商項(xiàng)目合作協(xié)議范文(2篇)
- 2025年交通事故賠償諒解協(xié)議(2篇)
- 新測(cè)繪法解讀
- 進(jìn)行壓力容器的檢驗(yàn)(課件)
- 【光明乳業(yè)企業(yè)償債能力問(wèn)題及完善建議8900字論文】
- 提高感染性休克集束化治療達(dá)標(biāo)率
- 譯林版七年級(jí)下冊(cè)英語(yǔ)單詞默寫(xiě)表
- 人教版五年級(jí)上冊(cè)數(shù)學(xué)簡(jiǎn)便計(jì)算大全600題及答案
- 2016-2023年湖南高速鐵路職業(yè)技術(shù)學(xué)院高職單招(英語(yǔ)/數(shù)學(xué)/語(yǔ)文)筆試歷年考點(diǎn)試題甄選合集含答案解析
- 政治單招考試重點(diǎn)知識(shí)點(diǎn)
- 專(zhuān)題01 中華傳統(tǒng)文化-中考英語(yǔ)時(shí)文閱讀專(zhuān)項(xiàng)訓(xùn)練
- 阿特拉斯擰緊工具維修培訓(xùn)課件
- 北京四合院介紹課件
評(píng)論
0/150
提交評(píng)論