




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、第3章 直線和圓弧的生成算法3.1 直線圖形的生成算法 數(shù)學(xué)上的直線是沒(méi)有寬度、由無(wú)數(shù)個(gè)點(diǎn)構(gòu)成的集合,顯然,光柵顯示器只能近地似顯示直線。當(dāng)我們對(duì)直線進(jìn)行光柵化時(shí),需要在顯示器有限個(gè)像素中,確定最佳逼近該直線的一組像素,并且按掃描線順序,對(duì)這些像素進(jìn)行寫操作,這個(gè)過(guò)程稱為用顯示器繪制直線或直線的掃描轉(zhuǎn)換。 由于在一個(gè)圖形中,可能包含成千上萬(wàn)條直線,所以要求繪制算法應(yīng)盡可能地快。本節(jié)我們介紹一個(gè)像素寬直線繪制的三個(gè)常用算法:數(shù)值微分法(DDA)、中點(diǎn)畫線法和Bresenham算法。3.1.1逐點(diǎn)比較法3
2、.1.2數(shù)值微分(DDA)法設(shè)過(guò)端點(diǎn)P0(x0 ,y0)、P1(x1 ,y1)的直線段為L(zhǎng)(P0 ,P1),則直線段L的斜率 L的起點(diǎn)P0的橫坐標(biāo)x0向L的終點(diǎn)P1的橫坐標(biāo)x1步進(jìn),取步長(zhǎng)=1(個(gè)像素),用L的直線方程y=kx+b計(jì)算相應(yīng)的y坐標(biāo),并取像素點(diǎn)(x,round(y)作為當(dāng)前點(diǎn)的坐標(biāo)。因?yàn)椋?#160; yi+1 = kxi+1+b = k1xi+b+kDx
3、160; = yi+kDx 所以,當(dāng)Dx =1; yi+1 = yi+k。也就是說(shuō),當(dāng)x每遞增1,y遞增k(即直線斜率)。根據(jù)這個(gè)原理,我們可以寫出DDA(Digital Differential Analyzer)畫線算法程序。 DDA畫線算法程序:void DDALine(int x0,int y0,int x1,int y1,int color) int x; float dx, dy, y, k; dx = x1-x0; dy=y1-y0;&
4、#160; k=dy/dx,;y=y0; for (x=x0;x< x1;x+) drawpixel (x, int(y+0.5), color); y=y+k; 注意:我們這里用整型變量color表示像素的顏色和灰度。 舉例:用DDA方法掃描轉(zhuǎn)換連接兩點(diǎn)P0(0,0)和P1(5,2)的直線段。xint(y+0.5)y+0.5000100.4+0.5210.8+0.5311.2+0.5421.6+0.5圖3.1.1 直線段的掃描轉(zhuǎn)換
5、注意:上述分析的算法僅適用于|k| 1的情形。在這種情況下,x每增加1,y最多增加1。當(dāng) |k| > 1時(shí),必須把x,y地位互換,y每增加1,x相應(yīng)增加1/k。在這個(gè)算法中,y與k必須用浮點(diǎn)數(shù)表示,而且每一步都要對(duì)y進(jìn)行四舍五入后取整,這使得它不利于硬件實(shí)現(xiàn)。動(dòng)畫演示:數(shù)值微分畫線算法(DDA) 3.1.3中點(diǎn)畫線法 假定直線斜率k在01之間,當(dāng)前像素點(diǎn)為(xp,yp),則下一個(gè)像素點(diǎn)有兩種可選擇點(diǎn)P1(xp+1,yp)或P2(xp+1,yp+1)。若P1與P2的中點(diǎn)(xp+1,yp+0.5)
6、稱為M,Q為理想直線與x=xp+1垂線的交點(diǎn)。當(dāng)M在Q的下方時(shí),則取P2應(yīng)為下一個(gè)像素點(diǎn);當(dāng)M在Q的上方時(shí),則取P1為下一個(gè)像素點(diǎn)。這就是中點(diǎn)畫線法的基本原理。 圖3.1.2 中點(diǎn)畫線法每步迭代涉及的像素和中點(diǎn)示意圖 下面討論中點(diǎn)畫線法的實(shí)現(xiàn)。過(guò)點(diǎn)(x0,y0)、(x1, y1)的直線段L的方程式為F(x, y)=ax+by+c=0,其中,a=y0-y1, b=x1-x0, c=x0y1-x1y0,欲判斷中點(diǎn)M在Q點(diǎn)的上方還是下方,只要把M代入F(x,y),并判斷它的符號(hào)即可
7、。為此,我們構(gòu)造判別式:d=F(M)=F(xp+1, yp+0.5)=a(xp+1)+b(yp+0.5)+c 當(dāng)d<0時(shí),M在L(Q點(diǎn))下方,取P2為下一個(gè)像素; 當(dāng)d>0時(shí),M在L(Q點(diǎn))上方,取P1為下一個(gè)像素; 當(dāng)d=0時(shí),選P1或P2均可,約定取P1為下一個(gè)像素;注意到d是xp, yp的線性函數(shù),可采用增量計(jì)算,提高運(yùn)算效率。 若當(dāng)前像素處于d³0情況,則取正右方像素
8、P1(xp+1, yp),要判下一個(gè)像素位置,應(yīng)計(jì)算 d1=F(xp+2, yp+0.5)=a(xp+2)+b(yp+0.5)=d+a,增量為a。 若d<0時(shí),則取右上方像素P2(xp+1, yp+1)。要判斷再下一像素,則要計(jì)算d2= F(xp+2, yp+1.5)=a(xp+2)+b(yp+1.5)+c=d+a+b ,增量為ab。畫線從(x0, y0)開始,d的初值 d0=F(x0+1, y0+0.5)=F(x0, y0)+a+0.5b,因
9、; F(x0, y0)=0,所以d0=a+0.5b。 由于我們使用的只是d的符號(hào),而且d的增量都是整數(shù),只是初始值包含小數(shù)。因此,我們可以用2d代替d來(lái)擺脫小數(shù),寫出僅包含整數(shù)運(yùn)算的算法程序。 中點(diǎn)畫線算法程序:void Midpoint Line (int x0,int y0,int x1, int y1,int color) int a, b, d1, d2, d, x, y; a=y0-y1; b=x1-x0;d=2*a+b; d1=2*a;d2=2* (a+b); x=x0;y=y0;
10、; drawpixel(x, y, color); while (x<x1) if (d<0) x+;y+; d+=d2; else x+; d+=d1; drawpixel (x, y, color); /* while */ /* mid PointLine */ 舉例:用中點(diǎn)畫線方法掃描轉(zhuǎn)換連接兩點(diǎn)P0(0,0)和P1(5,2)的直線段。a=y0-y1=-2; b=x1-x
11、0=5; d0=2*a+b=1;d1=2*a=-4;d2=2*(a+b)=6 ,xyd00110-321331-14255215圖3.1.3 中點(diǎn)畫線法問(wèn)題1:若上述算法往下取二步(Di=2),則算法和像素的取法將變成怎樣?問(wèn)題2:與DDA法相比,中點(diǎn)法的優(yōu)點(diǎn)是什么?動(dòng)畫演示:中點(diǎn)畫線算法 Bresenham算法 Bresenham算法是計(jì)算機(jī)圖形學(xué)領(lǐng)域使用最廣泛的直線掃描轉(zhuǎn)換算法。仍然假定直線斜率在01之間,該方法類似于中點(diǎn)法,由一個(gè)誤差項(xiàng)符號(hào)決定下一個(gè)像素點(diǎn)。 算法原理如下:過(guò)各行各列像素中心構(gòu)造一組虛擬網(wǎng)格線。按直線
12、從起點(diǎn)到終點(diǎn)的順序計(jì)算直線與各垂直網(wǎng)格線的交點(diǎn),然后確定該列像素中與此交點(diǎn)最近的像素。該算法的巧妙之處在于采用增量計(jì)算,使得對(duì)于每一列,只要檢查一個(gè)誤差項(xiàng)的符號(hào),就可以確定該列的所求像素。 如圖所示,設(shè)直線方程為yi+1=yi+k(xi+1-xi)+k。假設(shè)列坐標(biāo)像素已經(jīng)確定為xi,其行坐標(biāo)為yi。那么下一個(gè)像素的列坐標(biāo)為xi1,而行坐標(biāo)要么為yi,要么遞增1為yi1。是否增1取決于誤差項(xiàng)d的值。誤差項(xiàng)d的初值d00,x坐標(biāo)每增加1,d的值相應(yīng)遞增直線的斜率值k,即ddk。一旦 d1,就把它減去1,這樣保證d在0、1之間。當(dāng)d0.5時(shí),直線與垂線x
13、=xi1交點(diǎn)最接近于當(dāng)前像素(xi,yi)的右上方像素(xi1,yi1);而當(dāng)d<0.5時(shí),更接近于右方像素(xi1,yi)。為方便計(jì)算,令ed0.5,e的初值為0.5,增量為k。當(dāng)e0時(shí),取當(dāng)前像素(xi,yi)的右上方像素(xi1,yi1);而當(dāng)e<0時(shí),取(xi,yi)右方像素(xi1,yi)。圖3.1.4 Bresenham算法所用誤差項(xiàng)的幾何含義Bresenham畫線算法程序:void Bresenhamline (int x0,int y0,int x1, int y1,int color) int x, y, dx, dy; float k, e;
14、0; dx = x1-x0;dy = y1- y0;k=dy/dx; e=-0.5; x=x0,;y=y0; for (i=0;i<dx;i+) drawpixel (x, y, color); x=x+1;e=e+k; if (e³0) y+; e=e-1; 舉例:用Bresenham方法掃描轉(zhuǎn)換連接兩點(diǎn)P0(0,0)和P1(5,2)的直線段。xye00-0.510-0.121-0.731-0.342-0.9
15、52-0.5圖3.1.5 Bresenham算法 上述Bresenham算法在計(jì)算直線斜率與誤差項(xiàng)時(shí)用到小數(shù)與除法。可以改用整數(shù)以避免除法。由于算法中只用到誤差項(xiàng)的符號(hào),因此可作如下替換:2*e*dx。 改進(jìn)的Bresenham畫線算法程序:void InterBresenhamline (int x0,int y0,int x1, int y1,int color) dx = x1-x0,;dy = y1- y0,;e=-dx; x=x0; y=y0; for (i=0; i<d
16、x; i+) drawpixel (x, y, color); x+; e=e+2*dy; if (e³0) y+; e=e-2*dx; 動(dòng)畫演示:Bresenham畫線算法:3.2 圓弧的掃描轉(zhuǎn)換算法 這一節(jié)我們來(lái)討論圓弧的掃描轉(zhuǎn)換算法。3.2.1圓的特征 圓被定義為到給定中心位置(xc,yc)距離為r的點(diǎn)集。圓心位于原點(diǎn)的圓有四條對(duì)稱軸x=0,y=0,x=y和x=-y。若已知圓弧上一點(diǎn)(x,y),可以得到其關(guān)于四條對(duì)稱
17、軸的其它7個(gè)點(diǎn),這種性質(zhì)稱為圓的八對(duì)稱性。因此,只要掃描轉(zhuǎn)換八分之一圓弧,就可以求出整個(gè)圓弧的像素集。 顯示圓弧上的八個(gè)對(duì)稱點(diǎn)的算法:void CirclePoints(int x,int y,int color) drawpixel(x,y,color); drawpixel(y,x,color); drawpixel(-x,y,color); drawpixel(y,-x,color); drawpixel(x,-y,color); drawpixel(-y,x,color); drawpixel(-x,-y,color); drawpixe
18、l(-y,-x,color);3.2.2中點(diǎn)畫圓法 如果我們構(gòu)造函數(shù) F(x,y)=x2+y2-R2,則對(duì)于圓上的點(diǎn)有F(x,y)=0,對(duì)于圓外的點(diǎn)有F(x,y)>0,對(duì)于圓內(nèi)的點(diǎn)F(x,y)<0 。與中點(diǎn)畫線法一樣,構(gòu)造判別式:d=F(M)=F(xp+1,yp-0.5)=(xp+1)2+(yp-0.5)2-R2若 d<0,則應(yīng)取P1為下一像素,而且再下一像素的判別式為:d=F(xp+2,yp-0.5)=(xp+2)2+(yp-0.5)2-R2=d+2xp+3若d0,則應(yīng)取P2為下一像素,而且下一像素的判別式為:d=F(xp+2,yp-1.5)=(xp+2)2+(yp-1.5)2-R2=d+2(xp-yp)+5我們這里討論的第一個(gè)像素是(0,R),判別式d的初始值為:d0=F(1,R-0.5)=1.25-R圖3.2.1 當(dāng)前像素與下一像素的候選者 中點(diǎn)畫圓算法:MidPointCircle(int r int color) int x,y; float d; x=0; y=r; d=
溫馨提示
- 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工廠員工安全培訓(xùn)考試試題帶答案(黃金題型)
- 2025年項(xiàng)目部安全管理人員安全培訓(xùn)考試試題答案各地真題
- 2025企業(yè)員工安全培訓(xùn)考試試題【培優(yōu)A卷】
- 2024-2025車間職工安全培訓(xùn)考試試題【各地真題】
- 2025年各個(gè)班組安全培訓(xùn)考試試題附答案解析
- 2025年企業(yè)負(fù)責(zé)人安全培訓(xùn)考試試題及完整答案【名校卷】
- 2024-2025新入職工入職安全培訓(xùn)考試試題附答案【達(dá)標(biāo)題】
- 2025年全員安全培訓(xùn)考試試題及答案突破訓(xùn)練
- 2025安全管理員安全培訓(xùn)考試試題及答案打印
- 2025年新員工崗前安全培訓(xùn)考試試題(重點(diǎn))
- 腦卒中患者的藥物管理確保正確用藥避免風(fēng)險(xiǎn)
- 小學(xué)綜合實(shí)踐《我們的傳統(tǒng)節(jié)日》說(shuō)課稿
- 《蟻群算法》課件
- 關(guān)于廠房的出售知識(shí)講座
- 基于深度學(xué)習(xí)的語(yǔ)音分離技術(shù)研究
- 【中小企業(yè)財(cái)務(wù)管理存在的問(wèn)題及對(duì)策分析-以A公司為例5100字(論文)】
- 茶樓組織架構(gòu)及人員配置方案
- 閥門手冊(cè)使用與維修
- 住房城鄉(xiāng)建設(shè)領(lǐng)域重大安全風(fēng)險(xiǎn)隱患清單
- 學(xué)校STEM課程調(diào)查問(wèn)卷(學(xué)生)
- 《虛擬現(xiàn)實(shí)(VR)制作與應(yīng)用》考試復(fù)習(xí)題庫(kù)(匯總)
評(píng)論
0/150
提交評(píng)論