资源描述:
《计算机图形实验报告.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、.一、实验目的1、掌握中点Bresenham直线扫描转换算法的思想。2掌握边标志算法或有效边表算法进行多边形填充的基本设计思想。3掌握透视投影变换的数学原理和三维坐标系中几何图形到二维图形的观察流程。4掌握三维形体在计算机中的构造及表示方法二、实验环境Windows系统,VC6.0。三、实验步骤1、给定两个点的坐标P0(x0,y0),P1(x1,y1),使用中点Bresenham直线扫描转换算法画出连接两点的直线。实验基本步骤首先、使用MFCAppWizard(exe)向导生成一个单文档视图程序框架。其次、使用中点Br
2、esenham直线扫描转换算法实现自己的画线函数,函数原型可表示如下:Word资料.voidDrawLine(CDC*pDC,intp0x,intp0y,intp1x,intp1y);在函数中,可通过调用CDC成员函数SetPixel来画出扫描转换过程中的每个点。COLORREFSetPixel(intx,inty,COLORREFcrColor);再次、找到文档视图程序框架视图类的OnDraw成员函数,调用DrawLine函数画出不同斜率情况的直线,如下图:最后、调试程序直至正确画出直线。2、给定多边形的顶点的坐标P
3、0(x0,y0),P1(x1,y1),P2(x2,y2),P3(x3,y3),P4(x4,y4)…使用边标志算法或有效边表算法进行多边形填充。实验基本步骤首先、使用MFCAppWizard(exe)向导生成一个单文档视图程序框架。其次、实现边标志算法或有效边表算法函数,如下:voidFillPolygon(CDC*pDC,intpx[],intpy[],intptnumb);px:该数组用来表示每个顶点的x坐标py:该数组用来表示每个顶点的y坐标ptnumb:表示顶点个数注意实现函数FillPolygon可以直接通过窗
4、口的DC(设备描述符)来进行多边形填充,不需要使用帧缓冲存储。(边标志算法)Word资料.首先用画线函数勾画出多边形,再针对每条扫描线,从左至右依次判断当前像素的颜色是否勾画的边界色,是就开始填充后面的像素直至再碰到边界像素。注意对顶点要做特殊处理。通过调用GDI画点函数SetPixel来画出填充过程中的每个点。需要画线可以使用CDC的画线函数MoveTo和LineTo进行绘制,也可以使用实验一实现的画直线函数。CPointMoveTo(intx,inty);BOOLLineTo(intx,inty);实现边标志算法算
5、法需要获取某个点的当前颜色值,可以使用CDC的成员函数COLORREFGetPixel(intx,inty);再次、找到文档视图程序框架视图类的OnDraw成员函数,调用FillPolygon函数画出填充的多边形,如下:voidCTestView::OnDraw(CDC*pDC){CTestcoodtransDoc*pDoc=GetDocument();ASSERT_VALID(pDoc);//TODO:adddrawcodefornativedatahere//绘制之前先把整个窗口涂上背景色(白色)以便于下面的填充R
6、ECTRt;GetClientRect(&Rt);pDC->FillSolidRect(&Rt,RGB(255,255,255));Word资料.intptx[]={10,100,200,150,80};intpty[]={10,50,80,120,70};FillPolygon(pDC,ptx,pty,5);}截图如下3.在世界坐标系中定义一个立方体(由6个面组成),并给定观察点在世界坐标系中的位置(a,b,c)以及观察坐标系的方位角θ,俯仰角φ和姿态角α,另外再给定投影面离观察点的距离D,在屏幕上画出立方体的透视投
7、影图形。实验基本步骤首先、使用MFCAppWizard(exe)向导生成一个单文档视图程序框架。其次、由给定观察点在世界坐标系中的位置(a,b,c)以及观察坐标系的方位角Word资料.θ,俯仰角φ和姿态角α求出观察变换矩阵Tv.再次、将立方体的每一个面的顶点坐标与变换矩阵Tv相乘得到观察坐标系中的坐标,再由式(1)求得二维投影坐标。并用直线连接这些二维投影坐标点形成每一个面在投影面的图形,依次将立方体的6个面画出即可。核心代码如下:voidCTestView::OnDraw(CDC*pDC){CTestDoc*pDoc
8、=GetDocument();ASSERT_VALID(pDoc);//TODO:adddrawcodefornativedatahereCRectRect;GetClientRect(&Rect);intMaxX=Rect.right;intMaxY=Rect.bottom;pDC->SetMapMode(MM_ANISOTRO