




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、算機圖形學-圖形 的幾何變換的實現算 法精品文檔收集于網絡,如有侵權請聯系管理員刪除實驗二 圖形的幾何變換的實現算法班級08信計 學號59姓名 分數一、實驗目的和要求:1、掌握而為圖形的基本幾何變換,如平移,旋轉,縮放,對稱,錯切變 換;。2、掌握OpenGL中模型變換函數,實現簡單的動畫技術。3、學習使用OpenG晚成基本圖形。4、鞏固所學理論知識,加深對二維變換的理解,加深理解利用變換矩陣可由簡單圖形得到復雜圖形。加深對變換矩陣算法的理解。編制利用旋轉變換繪制齒輪的程序。編程實現變換矩陣算法,繪制給出形 體的三視圖。調試程序及分析運行結果。要求每位學生獨立完成該實驗,并上 傳實驗報告。二、
2、實驗原理和內容:.原理:圖像的幾何變換包括:圖像的空間平移、比例縮放、旋轉、仿射變換和圖像插值。圖像幾何變換的實質:改變像素的空間位置,估算新空間位置上的像素值。圖像幾何變換的一般表達式:u,v X(x,y),Y(x,y),其中,u,v為變換后圖像像素的笛卡爾坐標,x,y為原始圖像中像素的笛卡爾坐標。這樣就得到了原始圖像與變換后圖像的像素的對應關系。平移變換:若圖像像素點 (x,y)平移到(x x0,y y0),則變換函數為u X(x, y) x %,v Y(x, y) y y0 ,寫成矩陣表達式為:uxxo其中,xo和y0分別為x和y的坐標平移量。vyYo比例縮放:若圖像坐標 (x,y)縮放
3、到(sx,sy)倍,則變換函數為:usx 0 xc其中,Sx,Sy分別為x和y坐標的縮放因子,其大于 1表示放V0 Sy y大,小于1表示縮小。旋轉變換:將輸入圖像繞笛卡爾坐標系的原點逆時針旋轉角度,則變換后圖像坐標為:u cos sin x v sin cos y內容:1、對一個三角形分別實現平移,縮放旋轉等變化。.在方向、尺寸和形狀方面的變換是用改變對象坐標描述的幾何變換來完成 的。基本幾何變換都是相對于坐標原點和坐標軸進行的幾何變換,有平移、旋 轉、縮放、反射、錯切等。用直線命令畫出一個齒(或六邊形的一半)一利用旋轉變換或對稱變換矩陣 實現對其余部分的繪制一調試運行程序一輸出圖形一分析結
4、果一結束。編寫三維變換算法程序一檢查程序的正確性一分段調試程序一輸入給出的 三維形體各頂點的坐標一執行變換一對算法程序進行必要的調整 一更換不同的 形體數據繼續變換一結束。.用實驗一的方法解決這個問題,某三角形的三個點點坐標為5.0.0.25.0,150.0.25.0, 100.0.100.0,創建一個長度分別為 600,600的窗口,窗口的左 上角位于屏幕坐標(100,100)處。然后繪制一個由上述頂點所繪制的三角形, 實現該三角形進行下列幾何變換:首先使三角形沿著其中心的x軸和y軸方向縮小50%,然后沿著出示中心旋轉90度;最后沿著y軸平移100個單位。三、實驗代碼如下1實驗一#inclu
5、de #include Void init (void)glClearVolor (0.0,0.0,0.0,0.0);glShadeModel (GL-FLAT);Void draw_triangle(void).glBegin(GL_LINE_LOOP);glVertex2f(0.0,25.0);glVertex2f(25.0,-25.0);glVertex2f(-25.0,-25.0);glEnd();Void display(void)glClear (GL_COLOR_BUEFER_BIT);glColor3f(1.0,1.0,1.0);glLoadIdentity();glColor
6、3f(1.0,1.0,1.0);draw_triangle();glEnable (GL_LINE_STIPPLE);glLineStipple (1,0 xF0F0);glLoadIdentity();glTranslatef (-20.0,0.0,0.0);draw_triangle();glLineStipple (1,0 xff00);glLoadIdentity ();glScalef (1.5,0.5,1.0);draw_triangle ();glLineStipple (1,0 x8888);glLoadIdentity();glRotatef(90.0,0.0,0.0,1.0
7、);draw_triangle ();glDisable (GL_LINE_STIPPLE);glFlush();Void reshape (int w,nt h)glViewport (0,0,(GLsizei) w,(GLsizei) h); glMatrixMode (GL_PROJECTION);glLoadIdentity ();if (w=h)gluOrtho2D(-50.0,50.0,-50.0*(GLfloat)h/(GLfloat)w,50.0*(GLfloat)h/(GLfloat)w); glMatrixMode(GL_MODELVIEW);int main (int a
8、rgc,char*argv)glutInit(&argc,argv);glutInitDisplayMode (GLUT_SINGLE | GLUT_RGB);glutInitWindowSize (500,500);glutInitWindowPosition (100,100);glutCreatWindow (argv0);init ();glutDisplayFunc (display);glutReshapeFunc (reshape);glutMainLoop();return 0;實驗結果如下2實驗二代碼#include#includeinta144=30,0,0,1,30,40
9、,0,1,0,40,0,1,0,40,10,1,0,30,30,1, 0,0,30,1,30,0,30,1,30,10,30,1,10,10,30,1,10,30,30,1,10,40 ,10,1,10,10,10,1,30,10,10,1,30,40,10,1;float t44,p144;void a400()int i,j;for(i=0;i4;i+)for(j=0;j4;j+)tij=0;void a500() int k,i,j;for(i=0;i14;i+)for(j=0;j4;j+)pij=0;for(k=0;k4;k+)pij=pij+aik*tkj;pi0=pi0+280;p
10、i1=-pi1+180;setcolor(9);moveto(p00,p01);for(i=0;i14;i+)lineto(pi0,pi1);line(p60,p61,p00,p01);line(p70,p71,p120,p121);line(p80,p81,p110,p111); line(p90,p91,p40,p41);line(p100,p101,p30,p31);line(p130,p131,p100,p101);line(p10,p11,p130,p131);getch();main()int driver,mode,i,j;driver=DETECT;initgraph(&driver,&mode,d:tc);setbkc010r(3);a400();t00=0.7071*3;t01=-0.4082*3;t10=-0.7071*3;t11=-0.4082*3;t21=0.8165*3;t33=1;a500();c
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五有孩子無財產無欠債離婚協議書
- 租賃合同與物業協議約定條款不同
- 運動場地出租協議范文
- 五年級下科學教學設計-馬鈴薯在液體中的沉浮-教科版
- 二零二五版四合院使用權合同書轉讓
- 二零二五人力資源招聘合同范例
- 保安服務管理協議書合同書范例
- 二零二五簡單的貨物運輸合同模板
- 離婚房產分配協議二零二五年
- 人教版數學五年級上冊-5215練習十七-教學課件
- 衛生人才培養方案計劃
- 圖書館建筑設計規范講解課件
- 四川省教師資格認定體檢表
- 婚喪嫁娶事宜備案表
- 培養中班幼兒正確使用筷子的研究的結題報告
- 湘教版七年級上冊等高線地形圖
- 車間改造合同范文
- 風生水起博主的投資周記
- 賽艇賽事活動推廣方案
- (通用)中考數學總復習 第三章 函數 第4節 反比例函數課件 新人教
- 屋面開洞施工方案,好(全面完整版)
評論
0/150
提交評論