講稿計算機動畫lab_第1頁
講稿計算機動畫lab_第2頁
講稿計算機動畫lab_第3頁
已閱讀5頁,還剩3頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、課程名稱:計算機動畫姓名:學(xué)院:計算機學(xué)院專業(yè):計算機科學(xué)與技術(shù)3110101386學(xué)號:指導(dǎo)教師:于2014 年10 月11 日浙江大學(xué)實驗課程名稱:計算機動畫實驗類型: 綜合實驗項目名稱:路徑控制曲線學(xué)生: 專業(yè): 計科學(xué)號: 3110101386同組學(xué)生:指導(dǎo)老師:于實驗地點: 實驗日期:14 年 10 月 11 日一、 實驗?zāi)康暮鸵笤趧赢嬛锌捎脴訔l曲線來表示運動路徑以及不規(guī)則物體的形狀。在本實驗中選用 Cardinal 樣條曲線,掌握它的表示和算法,了解控制參數(shù)對曲線形狀的影響。二、 實驗內(nèi)容和原理在動畫中可用樣條曲線來表示運動路徑以及不規(guī)則物體的形狀。在本實驗中選用 Cardina

2、l 樣條曲線,掌握它的表示和算法,了解控制參數(shù)對曲線形狀的影響。Cardinal 樣條曲線矩陣表示:這里 U 是冪次最高為 3 的插值變量,M 是 Hermite 多項式矩陣,B 是樣條曲線參數(shù)。下面是其展開表示。這里 u0,1, Pi-1, Pi, Pi+1,Pi+2 是控制點,控制曲線的彎曲程度。三、 實驗器材PC Windows8.1 Visual Studio 2010實驗代碼和已在文件夾中四、 實驗步驟定義 CSpline 類如下:struct CPtfloat x; float y;/float z;class CSplinepublic:CPt *knots0;CPt Splin

3、e100; n0;float m16; float u100;CSpline(x100,y100,n,grain, float ten)i,np; n0=n+1; np=n0; CPt jd100; CPt *knots; knots0 = (CPt*)malloc(sizeof(struct CPt);knots = (CPt*)malloc(sizeof(struct CPt); knots0=knots;for(i=1;i=np;i+)jdi.x = xi-1;加入鼠標(biāo)相應(yīng)函數(shù):加入鍵盤相應(yīng)函數(shù):void CTestView:OnChar(UnChar, Ut, UnFlags)if (

4、r = nChar)SetTimer(1, 200, NULL);/* Invalidate();CTestView:OnDraw(&dc); run+;*/CView:OnChar(nChar,t, nFlags);void CTestView:OnRButtonDown(UnFlags, CPopo)/grain = 5;CSpline cs(x, y, i, grain, 0.8); CCntDC dc(this);for (k=1;k(i-1)*grain;k+)dc.MoveTo(cs.Splinek-1.x, cs.Splinek-1.y);dc.LineTo(cs.Splinek

5、.x, cs.Splinek.y);CView:OnRButtonDown(nFlags, po);jdi.y = yi-1;jd0.x = x0;jd0.y = y0;jdnp+1.x = xnp-1; jdnp+1.y = ynp-1; np=np+2; knots=jd;CubicSpline(np, knots, grain, ten);float Matrix(float a, float b, float c, float d, float u); void GetCardinalMatrix(float a1);void CubicSpline(n, CPt *knots,gra

6、in, float ten);加入定時器:繪圖函數(shù)如下:void CTestView:OnDraw(CDC* pDC)CTestDoc* pDoc = Get(); CCntDC dc(this);CDC memDC;patibleDC(&dc);CBitmap cbmp; cbmp.LoadBitmapW(IDB_BITMAP1); BITMAP bitmap; cbmp.GetBitmap(&bitmap);CBitmap *hOldBitmap = memelectObject(&cbmp); grain = 5;CSpline cs(x, y, i, grain, 0.8); for

7、(k=1;k(i-1)*grain;k+)dc.MoveTo(cs.Splinek-1.x, cs.Splinek-1.y);dc.LineTo(cs.Splinek.x, cs.Splinek.y);double angle = (double)(cs.Splinerun.y - cs.Splinerun- 1.y)/(cs.Splinerun.x-cs.Splinerun-1.x);for (roe1=0; roe148; roe1+)for(roe2=0; roe248; roe2+)void CTestView:OnTimer(U_PTR nIDEvent)if (1=nIDEvent

8、)CCntDC dc(this); Invalidate(); CTestView:OnDraw(&dc);run+;CView:OnTimer(nIDEvent);五、1.實驗結(jié)果分析程序總體類視圖如下:2.程序效果以及描點:double destx = roe1*cos(angle*3.1415/180)- roe2*sin(angle*3.1415/180);double desty =roe1*sin(angle*3.1415/180)+roe2*cos(angle*3.1415/180);dc.BitBestx+cs.Splinerun.x-10,desty+cs.Splinerun.y- 25,2,1,&memDC,roe1,roe2,SRCCOPY);memelectObject(hOldBitmap); memDC.DeleteDC(); cbmp.DeleteObj

溫馨提示

  • 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論