计算机图形学实验报告实验一、二技术之三维变换计算机图形学基础知识-三维变换变换是计算机图形学中重要概念,包括最基本的三维变换,即几何变换、投影变换、裁剪变换、视口变换。,所有的物体都是三维的。但是,这些三维物体在计算机世界中却必须以二维平面物体的形式表现出来。那么,这些物体是怎样从三维变换到二维的呢?下面我们采用相机(Camera)模拟的方式来讲述这个概念。实际上,从三维空间到二维平面,就如同用相机拍照一样,通常都要经历以下几个步骤(括号内表示的是相应的图形学概念):第一步,将相机置于三角架上,让它对准三维景物(视点变换,ViewingTransformation)。第二步,将三维物体放在适当的位置(模型变换,ModelingTransformation)。第三步,选择相机镜头并调焦,使三维物体投影在二维胶片上(投影变换,ProjectionTransformation)。第四步,决定二维像片的大小(视口变换,ViewportTransformation)。这样,一个三维空间里的物体就可以用相应的二维平面物体表示了,也就能在二维的电脑屏幕上正确显示了。,但在具体编程时,还必须了解三维图形世界中的几个特殊坐标系的概念,以及用这些概念表达的三维图形显示流程。计算机本身只能处理数字,图形在计算机内也是以数字的形式进行加工和处理的。大家都知道,坐标建立了图形和数字之间的联系。为了使被显示的物体数字化,要在被显示的物体所在的空间中定义一个坐标系。这个坐标系的长度单位和坐标轴的方向要适合对被显示物体的描述,这个坐标系称为世界坐标系。计算机对数字化的显示物体作了加工处理后,要在图形显示器上显示,这就要在图形显示器屏幕上定义一个二维直角坐标系,这个坐标系称为屏幕坐标系。这个坐标系坐标轴的方向通常取成平行于屏幕的边缘,坐标原点取在左下角,长度单位常取成一个象素的长度,大小可以是整型数。为了使显示的物体能以合适的位置、大小和方向显示出来,必须要通过投影。投影的方法有两种,即正射投影和透视投影。有时为了突出图形的一部分,只把图形的某一部分显示出来,这时可以定义一个三维视景体(ViewingVolume)。正射投影时一般是一个长方体的视景体,透视投影时一般是一个棱台形的视景体。只有视景体内的物体能被投影在显示平面上,其他部分则不能。在屏幕窗口内可以定义一个矩形,称为视口(Viewport),视景体投影后的图形就在视口内显示。为了适应物理设备坐标和视口所在坐标的差别,还要作一适应物理坐标的变换。这个坐标系称为物理设备坐标系。根据上面所述,三维图形的显示流程应如图所示。,上述所说的视点变换和模型变换本质上都是一回事,即图形学中的几何变换。只是视点变换一般只有平移和旋转,没有比例变换。当视点进行平移或旋转时,视点坐标系中的物体就相当于在世界坐标系中作反方向的平移或旋转。因此,从某种意义上讲,二者可以统一,只是各自出发点不一样而已。读者可以根据具体情况,选择其中一个角度去考虑,这样便于理解。、投影变换投影变换是一种很关键的图形变换,有两种投影方式,一种是正射投影,另一种是透视投影。事实上,投影变换的目的就是定义一个视景体,使得视景体外多余的部分裁剪掉,最终图像只是视景体内的有关部分。实验截图及主要代码:实验一:主要代码:voidrenderScene(void){glClear(GL_COLOR_BUFFER_BIT);glColor4f(,,,);//矩形脸glRectf(-,,,-);glColor3f(0,,0);glBegin(GL_TRIANGLES);//三角形鼻子glVertex3f(,-,);glVertex3f(0,,);glVertex3f(-,-,);glEnd();glColor3f(,,); //设置当前颜色为蓝色glRectf(,,,); //绘制一个矩形眼睛glRectf(-,,-,); //绘制一个矩形glColor3f(,,);//红色glBegin(GL_POLYGON);//在屏幕上绘制一个四边形嘴巴glVertex2f(-,-);glVertex2f(-,-); glVertex2f(,-); glVertex2f(,-);glEnd();glColor3f(,,
哈工大威海+计算机图形学实验报告 来自淘豆网m.daumloan.com转载请标明出处.