




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
第3章圖元掃描轉(zhuǎn)換3.1實驗內(nèi)容簡述和實驗?zāi)繕?.2掃描轉(zhuǎn)換直線段(DDA)3.3基于Bresenham算法繪制直線段3.4基于Bresenham算法繪制圓3.5課外拓展性實驗
3.1實驗內(nèi)容簡述和實驗?zāi)繕?/p>
基本實驗內(nèi)容包括:掃描轉(zhuǎn)換直線段、基于Bresenham算法繪制直線段、基于Bresenham算法繪制圓。
完成本實驗后,讀者能夠:
(1)描述光柵化的原因和原理(布魯姆知識模型:記憶和理解);
(2)列舉常見的光柵化繪制現(xiàn)象(布魯姆知識模型:理解);
(3)復(fù)述DDA、中點、Bresenham算法流程(布魯姆知識模型:記憶);
(4)推導(dǎo)DDA、中點、Bresenham算法繪制二次曲線的遞推公式,并能夠算法化(布魯姆知識模型:理解和應(yīng)用);
(5)基于OpenGL,采用中點、Bresenham算法編程繪制二次曲線(布魯姆知識模型:應(yīng)用);
(6)檢查并發(fā)現(xiàn)圖元光柵化繪制效果存在的問題,判斷原因,找出對策并改善(布魯姆知識模型:應(yīng)用、分析、評價)。
3.2掃描轉(zhuǎn)換直線段(DDA)
給定直線方程y
=k
×x
+b上兩點(x0,y0)和(x1,y1),繪制上述兩點之間的直線段。
(3.1)
對應(yīng)算法步驟為:
(1)輸入直線段的兩端點p0(x0,y0)和p1(x1,y1)。
(2)計算公式(3.1)中的初始值k。
(3)令直線段上的點為(xf,yf),初始為(x0,y0)。
(4)當(dāng)xf
<=x1時,迭代以下兩步驟,否則結(jié)束
①將(xf,yf)取整為(xi,yi),并進行繪制。
②計算直線段上的下一點,即xf
=xf
+1,并根據(jù)公式(3.1)計算下一點的yf。
1.關(guān)鍵函數(shù)代碼實現(xiàn)
2.案例效果
用DDA方法繪制一條直線段,直線段的兩端點如圖3-1(a)所示,坐標分別為(-200,-200)和(200,200),最終效果如圖3-1(b)所示。
圖3-1用DDA方法繪制直線段
3.3基于Bresenham算法繪制直線段
假設(shè)當(dāng)前像素點坐標為(xi,yi,r),且當(dāng)前直線段的斜率小于等于1,則逼近直線段的下一個像素點坐標(xi+1,yi+1,r)的具體取值規(guī)則如下:xi+1=xi
+1;yi+1,r的值由公式(3.2)給出。這里,di為yi+1,r取值的判別公式,由其決定下一像素點為(xi+1,yi,r)還是(xi+1,yi,r
+1)。此處,令di=yi+1–yi,r
–0.5,其中yi+1為當(dāng)前直線段與x
=xi+1相交時的真實y坐標。
為此,當(dāng)di≥0時,說明當(dāng)前直線段的下一實際交點(xi+1,yi+1)離(xi+1,yi,r
+1)更近,即yi+1,r更適合為yi,r
+1;否則,yi+1,r更適合取值yi,r。同時,判別式的遞推公式為di+1
=yi+2
–yi+1,r
–0.5=yi+1
+k
–yi+1,r
–0.5,也取決于yi+1,r的取值,如公式(3.3)所示。此處,k為當(dāng)前直線段的斜率(dy
÷dx),為此,di的初始值為k–0.5。
為了提高算法的效率,對上述公式實施整數(shù)計算。為此,對判別式乘以2?×?dx,此時公式(3.3)更新為公式(3.4),且初始di為2
×dy
–dx。
(3.4)
對應(yīng)算法步驟如下:
(1)輸入直線的兩端點p0(x0,y0)和p1(x1,y1)。
(2)計算初始值dy,dx,d。
(3)繪制點(xf,yf),初始值為(x0,y0)。
(4)判斷d的符號。若d>=0,則下一個(x,y)更新為(x
+1,y
+1),同時將d更新為d
+?2?×?(dy
-
dx);否則,將下一個(x,y)更新為(x+1,y),d更新為d
+?2?×?dy。
(5)當(dāng)xf
<x1時,迭代步驟(3)和(4)。否則結(jié)束。
1.關(guān)鍵函數(shù)代碼實現(xiàn)
2.案例效果
用Bresenham算法繪制一條直線段,直線段的兩端點如圖3-2(a)所示,坐標分別為(0,0)和(100,100),最終效果如圖3-2(b)所示。
圖3-2用Bresenham算法繪制直線段
3.4基于Bresenham算法繪制圓
基于Bresenham算法繪制圓的算法的主要步驟如下:
(1)輸入圓的半徑r,默認圓心為(0,0)。
(2)計算初始值x、y,判別式d?=?3-2r。
(3)根據(jù)圓的對稱性繪制點(x,y),(-x,y),(x,-y),(-x,-y),(y,x),(-y,x),(y,-x),(-y,-x)。
(4)根據(jù)d的符號確定下一點y的取值。如果d>0,則下一個(x,y)更新為(x+1,y-1),同時將判別式d更新為d+4(x-y)+10;否則下一個(x,y)更新為(x+1,y),將判別式d更新為d+4x+6。
(5)迭代步驟(3)和(4),直至圓繪制結(jié)束。
1.關(guān)鍵函數(shù)代碼實現(xiàn)
2.案例效果
用Bresenham算法繪制一個圓心在(0,0)、半徑為200
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 假山施工合同承包書
- 房屋建筑工程保修合同協(xié)議
- 影視制作與發(fā)行合作合同
- 三方消防施工合同
- 苗木種植土地承包合同
- 加氣塊砌筑合同協(xié)議書
- 勞務(wù)中介公司服務(wù)合同
- 溫州浙江溫州瑞安市人民醫(yī)院招聘合同制工作人員筆試歷年參考題庫附帶答案詳解
- 法語獨家商務(wù)代理合同
- 廣州華商職業(yè)學(xué)院《典型企業(yè)云平臺搭建》2023-2024學(xué)年第二學(xué)期期末試卷
- 家庭急救知識(異物卡喉的急救)共45張課件
- 機臺異常處理規(guī)定
- 2021年蘇州市職業(yè)大學(xué)職業(yè)適應(yīng)性測試試題及答案解析
- DBJ∕T 13-253-2016 福建省耐腐蝕混凝土應(yīng)用技術(shù)規(guī)程
- 電鍍廢水中各種重金屬廢水處理反應(yīng)原理及控制條件
- 數(shù)據(jù)結(jié)構(gòu)英文教學(xué)課件:chapter3 Linked Lists
- 《汽車文化》全套教案
- 會計英語專業(yè)詞匯全
- 拆除工程檢驗批質(zhì)量檢驗記錄
- 怎樣把握文章線索
- LED與金鹵燈對比(共4頁)
評論
0/150
提交評論