资源描述:
《二维图形变换.doc》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、宁夏师范学院数学与计算机科学学院《计算机图形学》实验报告实验序号:7 实验项目名称:二维图形变换学 号姓 名专业、班2011级计本班实验地点指导教师时间2014.11.20一、实验目的1、通过二维几何变换的数学模型,编写缩放、旋转、对称变换;2、实现图形变换的交互式操作:缩放、旋转、对称变换等;二、实验内容与步骤1、放大缩小变换放大缩小变换公式为:x’=x.Sx,y’=y.Sy;其中Sx,Sy分别为x,y方向的放缩比例系数。变换矩阵表达式为:Sx000Sy0001[x’y’1]=[xy1]可通过下面不同的比例系数来显示程序运行结
2、果。(1)Sx=Sy=1.5;等比例放大(2)Sx=Sy=0.5;等比例缩小2、对称变换包括以x轴对称、y轴对称和原点O对称三种。由于屏幕坐标只有第一象限,我们可以将原点平移到(500,240)处。在第一象限画出一个三角形,然后分别求出三个对称图形。3、旋转变换将图形上的点(x,y)旋转θ角度,得到新的坐标(x’,y’)为:x’=xcosθ-ysinθ,y’=xsinθ+ycosθ;cosθsinθ0-sinθcosθ0001变换矩阵表示为:[x’y’1]=[xy1]三、实验步骤1、通过二维几何变换的数学模型,编写缩放、旋转、对
3、称变换;2、以(500,240)为原点建立图形变换的参考坐标系;3、通过键盘按键控制图形的缩放、旋转、对称变换;4、变换图形设定为以Pt[0](540,220)、Pt[1](670,130)、Pt[2](560,120)为顶点的三角形。步骤:1.建立Trans工程文件;2.利用ResourceView设计菜单,如图所示;菜单菜单项ID值图形变换(&T)缩放(&Z)ID_TRANSFORM_SCALE图形变换(&T)旋转(&R)ID_TRANSFORM_ROTATE图形变换(&T)对称(&S)ID_TRANSFORM_SYMMET
4、RY4、在CTransView视图类中添加消息映射函数;对象消息函数ID_TRA
SFORM_SCALECOMMANDOnFigureCirleID_TRANSFORM_ROTATECOMMANDOnFigureEllipseID_TRANSFORM_SYMMETRYCOMMANDOnTransformSymmetry5、添加自定义的成员变量:CPointPt[3];//三角形定点数组floatdAngle;//每一次旋转的角度在视图类CPP文件的构造函数中初始化成员变量Pt[0].x=540;Pt[0].y=220;Pt[1]
5、.x=670;Pt[1].y=130;Pt[2].x=560;Pt[2].y=120;dAngle=0;6、在视图类的OnDraw()函数中加入下列代码,实现视图绘图。voidCTransView::OnDraw(CDC*pDC){CTransDoc*pDoc=GetDocument();ASSERT_VALID(pDoc);//TODO:adddrawcodefornativedatahere//绘出以以(540,220)、(670,130)、(560,120)为顶点的三角形。pDC->MoveTo(Pt[0]);pDC->L
6、ineTo(Pt[1]);pDC->LineTo(Pt[2]);pDC->LineTo(Pt[0]);//绘出以(500,240)为原点的坐标轴pDC->MoveTo(100,240);pDC->LineTo(900,240);pDC->MoveTo(500,5);pDC->LineTo(500,400);pDC->TextOut(900,235,"x轴");pDC->TextOut(500,400,"y轴");//控制信息pDC->TextOut(15,10,"对称变换:键盘方向键");pDC->TextOut(15,28,"
7、缩放变换:Z键缩小;X键放大");pDC->TextOut(15,46,"旋转变换:键盘R键");}7、添加预编译常量#definePI3.14159268、分别编写步骤3中向视图类中添加消息映射函数,程序如下:voidCTransView::OnTransformRotate(){//TODO:AddyourcommandhandlercodeherefloatdRadiusAngle=30.0*PI/180.0;for(inti=0;i<3;i++){Pt[i].x=Pt[i].x*cos(dRadiusAngle)-Pt[
8、i].y*sin(dRadiusAngle);Pt[i].y=Pt[i].x*sin(dRadiusAngle)+Pt[i].y*cos(dRadiusAngle);}RedrawWindow();}//实现图形旋转voidCTransView::OnTrans