下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、實(shí)驗(yàn)7-2一、實(shí)驗(yàn)題目在屏幕上使用鼠標(biāo)繪制任意控制點(diǎn)的控制多邊形,基于de Casteljau算法繪制如圖7-48所示的Bezier曲線。二、實(shí)驗(yàn)思想Bezier曲線上的點(diǎn),可以使用Bezier曲線方程直接計(jì)算,但使用de Casteljau遞推算法則要簡(jiǎn)單的多。1.遞推公式給定空間n+1個(gè)控制點(diǎn)Pi(i=0,1, 2n)及參數(shù)t,de Casteljau遞推算法表述為:當(dāng)n=3時(shí),有 三次Bezier曲線遞推如下 第一級(jí)遞推:第二級(jí)遞推:第三級(jí)遞推:其中:規(guī)定: 定義Bezier曲線的控制點(diǎn)編號(hào)為 其中,r為遞推次數(shù)。de Casteljau已經(jīng)證明,當(dāng)r=n時(shí), 表示曲線上的點(diǎn)。根據(jù)式(7
2、-16)可以繪制n次Bezier曲線。三、實(shí)驗(yàn)代碼void CTestView:OnMENUBezierCurve() / TODO: Add your command handler code hereRedrawWindow();MessageBox(單擊左鍵繪制特征多邊形,單擊右鍵繪制曲線,提示,MB_OK);pt=new CPoint N_MAX_POINT;Flag=true;CtrlPoint=0;void CTestView:DrawBezier()/繪制Bezier曲線CClientDC dc(this);int rate=500,n;n=CtrlPoint-1;double
3、x,y;double pxN_MAX_POINT,pyN_MAX_POINT;for(int k=0;k=n;k+)pxk=ptk.x;pyk=ptk.y; for(double t=0;t=1;t+=0.01/rate)x=DeCasteliau(t,px);y=DeCasteliau(t,py); dc.SetPixel(ROUND(x),ROUND(y),RGB(0,0,255);double CTestView:DeCasteliau(double t,double p)/德卡斯特里奧函數(shù)double ppN_MAX_POINTN_MAX_POINT;int n=CtrlPoint-1
4、;for(int k=0;k=n;k+)ppk0=pk;for(int r=1;r=n;r+)for(int i=0;i=n-r;i+) ppir=(1-t)*ppir-1+t*ppi+1r-1; return(pp0n);void CTestView:DrawCharPolygon()/繪制控制多邊形CClientDC dc(this);CPen NewPen,*OldPen;NewPen.CreatePen(PS_SOLID,3,RGB(0,0,0);OldPen=dc.SelectObject(&NewPen);for(int i=0;iCtrlPoint;i+)if(i=0)dc.Mo
5、veTo(pti);dc.Ellipse(pti.x-2,pti.y-2,pti.x+2,pti.y+2);elsedc.LineTo(pti);dc.Ellipse(pti.x-2,pti.y-2,pti.x+2,pti.y+2);dc.SelectObject(OldPen);NewPen.DeleteObject();void CTestView:OnLButtonDown(UINT nFlags, CPoint point)/獲得屏幕控制點(diǎn)坐標(biāo) / TODO: Add your message handler code here and/or call defaultCView:OnLButtonDown(nFlags, point);if(Flag)ptCtrlPoint.x=point.x;ptCtrlPoint.y=point.y;if(CtrlPointN_MAX_POINT-1)CtrlPoint+;elseFlag=false;DrawCharPolygon();void CTestView:OnRButtonDown(UINT nFlags, CPoint point)/調(diào)用繪制函數(shù) / TODO: Add your message handler code here and/or cal
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026湖南岳陽市屈原管理區(qū)數(shù)據(jù)局編外人員招聘2人考試參考題庫及答案解析
- 2026湖北省面向重慶大學(xué)普通選調(diào)生招錄考試備考題庫及答案解析
- 2026福建福州新區(qū)(長(zhǎng)樂區(qū))事業(yè)單位招聘青年人才12人考試參考試題及答案解析
- 生物電信號(hào)檢測(cè)設(shè)備:生命感知與醫(yī)療智能的核心載體
- 2026年紅河州水利局事業(yè)單位校園公開招聘?jìng)淇碱}庫及參考答案詳解一套
- 2026年濟(jì)南市歷城區(qū)教育和體育局所屬學(xué)校計(jì)劃赴部分高校招聘90人備考題庫及完整答案詳解1套
- 南昌大學(xué)鄱陽湖教育部環(huán)境與資源利用教育部重點(diǎn)實(shí)驗(yàn)室2025年科研助理招聘?jìng)淇碱}庫及參考答案詳解
- 2026年濟(jì)南市文化和旅游局所屬事業(yè)單位公開招聘工作人員備考題庫及完整答案詳解一套
- 2026年西安銀行總行科創(chuàng)金融相關(guān)崗位招聘?jìng)淇碱}庫及參考答案詳解
- 大班安全《防欺凌》課件
- 《市場(chǎng)監(jiān)督管理投訴舉報(bào)處理辦法》知識(shí)培訓(xùn)
- 地震監(jiān)測(cè)面試題目及答案
- 12S522混凝土模塊式排水檢查井圖集
- 物業(yè)的2025個(gè)人年終總結(jié)及2026年的年度工作計(jì)劃
- 交通警察道路執(zhí)勤執(zhí)法培訓(xùn)課件
- JJG 1205-2025直流電阻測(cè)試儀檢定規(guī)程
- 十五五學(xué)校五年發(fā)展規(guī)劃(2026-2030)
- 物流行業(yè)項(xiàng)目實(shí)施的協(xié)調(diào)措施
- 2025年上海市各區(qū)初三二模語文試題匯編《說明文閱讀》
- 心衰患者的用藥與護(hù)理
- 2025年結(jié)算工作總結(jié)
評(píng)論
0/150
提交評(píng)論