双三次Bezier曲面的绘制_第1页
双三次Bezier曲面的绘制_第2页
双三次Bezier曲面的绘制_第3页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、Fi口neer tollegR.Inner Mongoba University课程名称:计算机图形学论文题目:双三次Bezier曲面的绘制教学部:年级班级学号姓名:摘 要:本文主要讨论了在 VC+中使用OpenGL绘制Bezier、NURB等典型曲面的一般性方法和OpenG的特点及功能,OpenG可以与Visual C+紧密接口,便于实现机械手的有关计算和图形算法,可保证算法的正确性和可靠性关键词:Bezier曲面;OpenGI;曲面绘制一、设计概述1设计要求1) 掌握双三次 Bezier 曲面定义 :Bezier 曲面与 Bezier 曲线有相同的性质, Bezier 曲面片是由特征多 面

2、体的顶点决定的, 利用两组正交的 Bezier 曲线逼近由控制点网格描述的 曲面。给定(n+1) * (m+1 个点 Pjk (i=0 , 1 n; j=0 , 1, .m ),则可 以生成一个n*m次的Bezier曲面片,其表示形式为mnQ(u,v)pi,j Bi,m(u)Bj,n(v)i0j0(u, v) 0,1其中Pij是Bezier曲面片的特征多面体。当 m=n=3时,特征多面体有 16个顶点,其相应的 Bezier 曲面片称为双三次 Bezier 曲面片。2) 实现矩阵相关运算;双三次 Bezier 曲面片的矩阵表示为Q(u,v) UMbGMbTV T其中U u 32 uu1V3v2

3、vv11331P11P12P13P143630P21P22P23P24MbG 21b3300P31P32P33P341000P41P42P43P442设计方案1)给定 16 个三维控制点如下:P00(200,20,0),P01(150,0,100),P02(50,-130,100),P03(0,-250,50)P10(150,100,100),P11(100,30,100),P12(50,-40,100),P13(0,-110,1 00);P20(140,280,90),P21(80,110,120),P22(30,30,130),P23(-50,-100,1 50);P30(150,350,

4、30),P31(50,200,150),P32(0,50,200),P33(-70,0,100)2)实现键盘控制曲面旋转效果、环境需求分析开发环境: Windows XP开发工具: Microsoft Visual Studio 2005运行环境:本系统是基于 OpenGL软件接口和VC+应用程序开发的一套 管理系统,本系统可以在装有 Windows 98 /2000/XP/NT 的操作系统下运行。1. OpenGL的特点及功能OpenGL是一个开放的三维图形软件包,它只是图形函数库( GLU,稳 定,可跨平台使用,它独立于窗口系统和操作系统,以它为基础开发的应用 程序可以十分方便地在各种平台

5、间移植;OpenGL可以与Visual C+紧密接 口,便于实现机械手的有关计算和图形算法, 可保证算法的正确性和可靠性; OpenGL使用简便,效率高。它具有七大功能:建模 变换 颜色模式设置 光照和材质设置 纹理映射 位图显示和图 象增强 双缓存动画2. OpenGL相关的函数库对于所有的OpenG应用程序,需要在每个文件中包含 gl.h头文件。几 乎所有的OpenG应用程序都使用GLU(前面所提到的OpenG工具函数库), 它要求包含glu.h头文件。因此,几乎所有的 OpenGL源代码文件都是以下 面这两行开头的:#include < GL/gl.h>#include &l

6、t; GL/glu.h>注意: Microsoft Windows 要求在 gl.h 或 glu.h 之前包含 windows.h 头文件,因为 Microsoft Windows 版本的 gl.h 和 glu.h 文件部所使用的一 些宏是在 windows.h 中定义的。绝大多数OpenGL应用程序还使用标准C函数库的系统调用,因此包含 与图形无关的头文件也非常常见,例如:#include <stdlib.h>#include <stdio.h>有关GLUT函数的一个子集介绍:1) 窗口管理GLUT用 5个函数执行初始化窗口所需要的任务: glut In it(

7、i nt *argc, char *argv)对 GLUT进行初始化,并处理任意命令行参数(对于 X系统,这将是类似-display 和-geometry这样 的选项)。glutInit() 应该在调用任何其他GLUT函数之 前被调用。 glutInitDisplayMode(unsigned int mode)指定使用 RGBA还是颜色索引模式。还可以指定使 用单缓冲还是双缓冲窗口(如果使用的是颜色 索引模式,需要把一些颜色载入到颜色映射表中,可以用 glutSetColor() 来完成这个任务)。最后,可以使用这个函数来表示希望窗口拥 有相关联 的深度、模版、多重采样和 / 或累积缓冲区。

8、例如,如果需要一个双缓冲、 RGBA 颜 色 模 式 以 及 一 个 深 度 缓 冲 区 的 窗 口 , 可 以 调 用 glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB | GLUT_DEPTH。) glutInitWindowPosition( int x, int y)指定了窗口左上角的屏幕位置。 glutInitWindowSize( int width, int size) 指定了窗口的大小 (以 像素为单位)。 int glutCreateWindow( char *string)创建了一个带有 OpenGL宣染环境的窗口。这个函数为 新窗口返回

9、一个唯一的标识符。注意:在调用 glutMainLoop() 函数之前,这个窗口并没有 被显示。2) 显示回调函数glutDisplayFunc(void (*func)(void) 是所看到的第一个也是最为重 要的事件回调函数。每当GLUT确定一个窗口的容需要重新显示时,通过glutDisplayFunc() 所注册的那个回调函数就会 被执行。因此,应该把重绘 场景所需要的所有代码都放在这个显示回调函数里。3) 运行程序最后,必须调用 glutMainLoop() 。所有已经创建的窗口将在此时显示, 对那些窗口的渲染也开始生效。事件处理开始启动,已注册的显示回调函数 被触发。一旦进入循环,它

10、就永远不会退出。4) 处理输入事件可以使用下面这些函数注册回调函数,当指定的事件发生时,这些函数 便会被调用: glutReshapeFunc( void(*func)int w, int h)表示当窗口的大小发生改变时应该采取什么行动。 glutKeyboardFunc(void(*func)(unsigned char key, int x, int y) 和 glutMouseFunc(void(*func)(int button, int state, int x, int y)允许把键盘上的一个键或鼠标上的一个按钮与一个 函数相关联,当这个键或按钮被按下或释 放时,这个函数就会被调用

11、。5) 管理后台进程可以在 glutIdleFunc(void(*func)(void)函数中指定一个函数, 如果不存在其他尚未完成的事件(例如,当事件循环处于空闲的时候),就执行这个函数。这个函数接受一个函数指针作为它的唯一参数三、调试后的正确程序清单程序实现代码:#include "stdafx.h"#include <windows.h>#include <glut.h>#include <stdio.h>#include <stdlib.h>#include <math.h>/ 数学头文件#define R

12、OUND(a) int (a+0.5) / 四舍五入 double Fei=0,Thta=0;struct P2Dint x,y;struct P3Dint x,y,z;P2D P2d44;P3D P3d44,T44;double MT44;void Init() / 读入控制多边形个顶点坐标glColor3f(1.0,1.0,1.0);P3d00.x=200;P3d00.y=20;P3d00.z=0; P3d01.x=150;P3d01.y=0;P3d01.z=100; P3d02.x=50;P3d02.y=-130;P3d02.z=100; P3d03.x=0;P3d03.y=-250;P

13、3d03.z=50;P3d10.x=150;P3d10.y=100;P3d10.z=100;P3d11.x=100;P3d11.y=30;P3d11.z=100;P3d12.x=50;P3d12.y=-40;P3d12.z=100;P3d13.x=0;P3d13.y=-110;P3d13.z=100;P3d20.x=140;P3d20.y=280;P3d20.z=90;P3d21.x=80;P3d21.y=110;P3d21.z=120; P3d22.x=30;P3d22.y=30;P3d22.z=130;P3d23.x=-50;P3d23.y=-100;P3d23.z=150;P3d30.x

14、=150;P3d30.y=350;P3d30.z=30;/P00/P01/P02/P03/P10/p11/p12/p13/P20/P21/P22/P23/P30/P31P3d31.x=50;P3d31.y=200;P3d31.z=150;/P32/P33P3d32.x=0;P3d32.y=50;P3d32.z=200;P3d33.x=-70;P3d33.y=0;P3d33.z=100;void Transform3DTo2D() / 三维坐标变换为二维坐标for (int i=0;i<4;i+)for (int j=0;j<4;j+)P2dij.x=P3dij.y-P3dij.x/

15、sqrtf(2);P2dij.y=-P3dij.z+P3dij.x/sqrtf(2);/ 保留矩M*P相乘void KeepOriginalMatrix(P3D Orig44,P3D Dest44) 阵函数for (int i=0;i<4;i+)for (int j=0;j<4;j+) Destij.x=Origij.x;Destij.y=Origij.y; Destij.z=Origij.z;void Calculate1( double M04,P3D P04) / 两个矩阵 KeepOriginalMatrix(P0,T);for (int i=0;i<4;i+) fo

16、r (int j=0;j<4;j+) P3dij.x=M0i0*T0j.x+M0i1*T1j.x+M0i2*T2 j.x+M0i3*T3j.x;P3dij.y=M0i0*T0j.y+M0i1*T1j.y+M0i2*T2 j.y+M0i3*T3j.y;P3dij.z=M0i0*T0j.z+M0i1*T1j.z+M0i2*T2 j.z+M0i3*T3j.z;void Calculate2(P3D P04, double M14)/ 两个矩阵 P*M相乘KeepOriginalMatrix(P0,T);for (int i=0;i<4;i+) for (int j=0;j<4;j+

17、) P3dij.x=Ti0.x*M10j+Ti1.x*M11j+Ti2.x*M12 j+Ti3.x*M13j;P3dij.y=Ti0.y*M10j+Ti1.y*M11j+Ti2.y*M1 2j+Ti3.y*M13j;P3dij.z=Ti0.z*M10j+Ti1.z*M11j+Ti2.z*M1 2j+Ti3.z*M13j;void MatrixRotate( double M04)/ 矩阵转置for (int i=0;i<4;i+) for (int j=0;j<4;j+) MTji=M0ij; void myDisplay( void )/ 绘制双次 Bezier 曲面 glCle

18、arColor(1.0,1.0,1.0,1.0); /glColor3f(1.0,1.0,1.0);double x,y,u,v,u1,u2,u3,u4,v1,v2,v3,v4; double M44;M00=-1;M01=3;M02=-3;M03=1; M10=3;M11=-6;M12=3;M13=0; M20=-3;M21=3;M22=0;M23=0; M30=1;M31=0;M32=0;M33=0; for (u=0;u<=1;u+=0.001)for (v=0;v<=1;v+=0.001)u1=u*u*u;u2=u*u;u3=u;u4=1;v1=v*v*v;v2=v*v;v

19、3=v;v4=1;x=(u1*P2d00.x+u2*P2d10.x+u3*P2d20.x+u4*P2d30.x )*v1+(u1*P2d01.x+u2*P2d11.x+u3*P2d21.x+u4*P2d31.x)*v2+(u1*P2d02.x+u2*P2d12.x+u3*P2d22.x+u4*P2d32.x)*v3+(u1*P2d03.x+u2*P2d13.x+u3*P2d23.x+u4*P2d33.x)*v4y=(u1*P2d00.y+u2*P2d10.y+u3*P2d20.y+u4*P2d30.y)*v1+(u1*P2d01.y+u2*P2d11.y+u3*P2d21.y+u4*P2d31

20、.y)*v2+(u1*P2d02.y+u2*P2d12.y+u3*P2d22.y+u4*P2d32.y)*v3+(u1*P2d03.y+u2*P2d13.y+u3*P2d23.y+u4*P2d33.y)*v4JglPointSize(3);glBegin(GL_POINTS);glColor3f(1.0f,0.0f,0.0f);glVertex2f(ROUND(1000/2+x),ROUND(2000/2+y);glutSwapBuffers();glEnd();glPopMatrix();glFlush();getchar();void SpecialKeys( int key, int x

21、, int y) / 键盘的上下左右键用来 旋转球体if (key = GLUT_KEY_UP) Fei-;if (key = GLUT_KEY_DOWN) Fei+;if (key = GLUT_KEY_LEFT) Thta-;if (key = GLUT_KEY_RIGHT) Thta+;/刷新窗口glutPostRedisplay();void reshape( int w, int h)glViewport(0, 0, (GLsizei) w, (GLsizei) h); glMatrixMode(GL_PROJECTION);glLoadIde ntity(); gluOrtho2D

22、(0.0, (GLdouble) w, 0.0, (GLdouble) h);int main( int argc, char *argv) Ini t();glutI nit(&argc, argv);glutInitDisplayMode(GLUT_RGB | GLUT_DOUBLE|GLUT_DEPTH); glutI nitWin dowPositio n(0, 0);glutI nitWin dowSize(1400,900); glutCreateWindow( "ShuangBezier!");Tran sform3DTo2D();glutDisplay Fun c(myDisplay); glutSpecialF un c(SpecialKeys); glutReshapeF un c

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论