




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上計(jì)算機(jī)圖形學(xué)實(shí)驗(yàn)報(bào)告班級(jí):軟件1102姓名:夏明軒 學(xué)號(hào):1中點(diǎn)算法的線段光柵化一、設(shè)計(jì)思想和算法流程1.假定直線斜率0<K<1假定直線斜率0<K<1,且已確定點(diǎn)亮象素點(diǎn)P(Xp ,Yp ),則下一個(gè)與直線最接近的像素只能是P1點(diǎn)或P2點(diǎn)。設(shè)M為中點(diǎn),Q為交點(diǎn),現(xiàn)需確定下一個(gè)點(diǎn)亮的象素。當(dāng)M在Q的下方-> P2離直線更近更近->取P2 。M在Q的上方-> P1離直線更近更近->取P1M與Q重合, P1、P2任取一點(diǎn)。問題:如何判斷M與Q點(diǎn)的關(guān)系?由常識(shí)知:若y=kx+b;F(x,y)=y-kx-b;則有假設(shè)直線方程為:a
2、x+by+c=0 (y=(-a/b)x-c/b)通過兩點(diǎn)不能唯一確定a,b,c,取 a=y0-y1, b=x1-x0, c=x0y1-x1y0F(x,y)=ax+by+c=b(y-(-a/b)x-c/b); 則有欲判斷M點(diǎn)是在Q點(diǎn)上方還是在Q點(diǎn)下方,只需把M代入F(x,y),并檢查它的符號(hào)。構(gòu)造判別式:d=F(M)=F(xp+1,yp+0.5)=a(xp+1)+b(yp+0.5)+c當(dāng)d<0,M在直線(Q點(diǎn))下方,取右上方P2;當(dāng)d>0,M在直線(Q點(diǎn))上方,取右方P1;當(dāng)d=0,選P1或P2均可,約定取P1;能否采用增量算法呢?若d³0 ->M在直線上方->
3、取P1;此時(shí)再下一個(gè)象素的判別式為 d1=F(xp+2, yp+0.5) =a(xp+2)+b(yp+0.5)+c = a(xp +1)+b(yp +0.5)+c +a =d+a;增量為a若d<0 ->M在直線下方->取P2;此時(shí)再下一個(gè)象素的判別式為d2= F(xp+2, yp+1.5) =a(xp+2)+b(yp+1.5)+c = a(xp +1)+b(yp +0.5)+c +a +b =d+a+b ; 增量為ab畫線從(x0, y0)開始,d的初值d0=F(x0+1, y0+0.5)= a(x0 +1)+b(y0 +0.5)+c= F(x0, y0)+a+0.5b =
4、a+0.5b 由于只用d 的符號(hào)作判斷,為了只包含整數(shù)運(yùn)算, 可以用2d代替d來擺脫小數(shù),提高效率。2.斜率不在0,1的直線的處理設(shè)起點(diǎn)和終點(diǎn)分別為(x0,y0)和(x1,y1) 若k>1則(y0,x0)和(y1,x1)所確定的直線斜率k 0,1,適用于前面討論的情形。對(duì)(y0,x0)和(y1,x1)所確定的直線進(jìn)行掃描轉(zhuǎn)換,每確定一組(x,y),輸出(y,x)。若-1<k<0先對(duì)(x0,-y0)和(x1,-y1)所確定的直線進(jìn)行掃描轉(zhuǎn)換,每確定一組(x,y),輸出(x,-y)。若k<-1對(duì)(-y0,x0)和(-y1,x1)所確定的直線進(jìn)行掃描轉(zhuǎn)換,每確定一組(x,y)
5、,輸出(y,-x)。二、編程實(shí)現(xiàn)#include<gl/glut.h>#include<stdlib.h>#include<stdio.h>#include<iostream>using namespace std;int a1, a2, b1, b2, x, y, m;void main(int argc, char*argv)cout << "第一個(gè)點(diǎn)橫坐標(biāo):"cin
6、60;>> a1;cout << "第二個(gè)點(diǎn)橫坐標(biāo):"cin >> a2;cout << "第一個(gè)點(diǎn)縱坐標(biāo):"cin >> b1;cout << "第二個(gè)點(diǎn)縱坐標(biāo):"cin >> b2;glutInit(&argc, argv);glutInitDisplayMode(GLUT_SINGLE |&
7、#160;GLUT_RGB);glutInitWindowSize(500, 500);glutInitWindowPosition(100, 100);glutCreateWindow("1 夏明軒 光柵直線");glClearColor(0.0, 0.0, 0.0, 0.0);glMatrixMode(GL_PROJECTION);glLoadIdentity();gluOrtho2D(0.0, 500.0, 0.0, 500.0);if (a1&l
8、t;a2&&b1<b2)x = 2 * (b2 - b1);y = 2 * (b2 - b1) - 2*(a2 - a1);m = 2 * (b2 - b1) - (a2 - a1);else if (a1<a2&&b1>b2)x = 2
9、* (b1 - b2);y = 2 * (b1 - b2) - 2*(a2 - a1);m = 2 * (b1 - b2) - (a2 - a1);else if (a1>a2&&b1<b2)x = 2 * (b2 - b1);y = 2
10、160;* (b2 - b1) - 2*(a1 - a2);m = 2 * (b2 - b1) - (a1 - a2);else if (a1>a2&&b1>b2)x = 2 * (b1 - b2);y = 2 * (b1 - b2) - 2
11、*(a1 - a2);m = 2 * (b1 - b2) - (a1 - a2);doglColor3f(1.0, 1.0, 1.0);glBegin(GL_POINTS);glVertex2i(x, y);if (a1<a2&&b1<b2)a1+;if (m<0)m = m + x;elsem = m + y;b
12、1+;else if (a1<a2&&b1>b2)a1+;if (m<0)m = m + x;elsem = m + y;b1-;else if (a1>a2&&b1<b2)a1-;if (m<0)m = m + x;elsem = m + y;b1+;else if (a1>a2&&b1>b2)a1-;if (m<0)m = m + x;elsem = m + y;b1-;else if (a1 = a2&&b1>b2)b1+;elseb1-; while (a1!=a2 | b1!=b2);glEnd();glutMainL
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 裝潢印刷的智能監(jiān)測(cè)系統(tǒng)考核試卷
- 口腔中的微生物
- 職場(chǎng)技能提升解鎖成功的新篇章考核試卷
- 項(xiàng)目經(jīng)理年底匯報(bào)
- XXX石油服務(wù)集團(tuán)股份有限公司ESG管理制度
- Pyripyropene-B-生命科學(xué)試劑-MCE
- 中考二輪復(fù)習(xí)高頻考點(diǎn)突破考點(diǎn)2;方程與方程組
- 電力行業(yè)水電商業(yè)模式穩(wěn)定低利率時(shí)代價(jià)值凸顯
- 2025年鄉(xiāng)村振興農(nóng)村電子商務(wù)基礎(chǔ)設(shè)施建設(shè)資金申請(qǐng)指南
- 分布式能源系統(tǒng)生物質(zhì)能源應(yīng)用2025年與生物質(zhì)能發(fā)電技術(shù)專利布局研究報(bào)告
- GB 9448-1999焊接與切割安全
- 直播實(shí)訓(xùn)室設(shè)備清單表模板
- 實(shí)詞辨析與成語辨析
- 項(xiàng)目一乙烯生產(chǎn)過程課件
- 三位數(shù)乘一位數(shù)練習(xí)題(300道)
- 高職英語課程說課稿課件
- 政府投資項(xiàng)目審計(jì)與報(bào)告案例信息講解課件
- 婦產(chǎn)科課件-女性生殖系統(tǒng)炎癥
- 三甲醫(yī)院體檢報(bào)告單A4
- 污水處理缺氧、厭氧、好氧的工藝流程分析
- 子午線輪胎斷面分析
評(píng)論
0/150
提交評(píng)論