1 / 14
文档名称:

计算机图形学实验二报告.doc

格式:doc   大小:127KB   页数:14页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

计算机图形学实验二报告.doc

上传人:tswng35 2020/7/22 文件大小:127 KB

下载得到文件列表

计算机图形学实验二报告.doc

文档介绍

文档介绍:计算机科学与通信工程学院实验报告课程计算机图形学实验题目曲线拟合学生姓名学号专业班级指导教师日期成绩评定表评价内容具体内容权重得分论证分析方案论证与综合分析的正确、合理性20%算法设计算法描述的正确性与可读性20%编码实现源代码正确性与可读性30%程序书写规范标识符定义规范,程序书写风格规范20%报告质量报告清晰,提交准时10%(1)给定四个已知点P1—P4,以此作为控制顶点绘制一段三次Bezier曲线。(2)给定四个已知点P1—P4,以此作为曲线上的点绘制一段三次Bezier曲线。—P6,以此作为控制顶点绘制一条三次B样条曲线。:WindowsXP开发工具:+1个顶点(控制点)所构成的N根折线来定义一根N阶曲线。本次实验中的三次Bezier曲线有4个顶点,设它们分别为P0,P1,P2,P3,那么对于曲线上各个点Pi(x,y)满足下列关系:P(t)=[(-P0+3P1-3P2+3P3)t3+(3P0-6P1+3P2)t2+(-3P0+3P2)t+(P0+4P1+P2)]/6X(t)=[(-X0+3X1-3X2+3X3)t3+(3X0-6X1+3X2)t2+(-3X0+3X2)t+(X0+4X1+X2)]/6Y(t)=[(-Y0+3Y1-3Y2+3Y3)t3+(3Y0-6Y1+3Y2)t2+(-3Y0+3Y2)t+(Y0+4Y1+Y2)]/6其中P0、P1、P2、P3为四个已知的点,坐标分别为(X0、Y0)、(X1、Y1)、(X1、Y2)、(X3、Y3)。所以只要确定控制点的坐标,该曲线可通过编程即可绘制出来。:对于6个顶点,取P1、P2、P3、P44个顶点绘制在第一段三次样条曲线,再取P2、P3、P4、P5这4个顶点绘制在第二段三次样条曲线,总计可绘制3段光滑连接的三次样条曲线。//:View{……public://参数输入和提示对话框CDlgBezierdlgBezier;//Bezier曲线绘制中的参数输入对话框 CDlgBdlgB;//B样条曲线绘制中的参数输入对话框//绘图函数,需要实现voidDrawBezier1(POINTp[4]);//已知点作为控制点绘制Bezier曲线voidDrawBezier2(POINTp[4]);//已知点作为曲线上的点绘制Bezier曲线voidDrawBCurve(POINTp[6]);//绘制B样条曲线//::OnMenuDiamond(){ IsCutting=FALSE; if(()==IDOK) DrawDiamond(,,100);//调用绘制金刚石的函数 }voidCDiamondView::OnMenuBezier1(){ IsCutting=FALSE; if(()==IDOK) DrawBezier1();//调用已知点作为控制点绘制Bezier曲线的函数}//以已知的四个点为控制点绘制Bezier曲线//p:已知的四个控制点voidCDiamondView::DrawBezier1(POINTp[4]){}voidCDiamondView::OnMenuBezier2(){ IsCutting=FALSE; if(()==IDOK) DrawBezier2();//调用已知点作为曲线上的点绘制Bezier曲线的函数 }//以已知的四个点为Bezier曲线上的点来绘制Bezier曲线//p:已知的四个点voidCDiamondView::DrawBezier2(POINTp[4]){}voidCDiamondView::OnMenuB(){ IsCutting=FALSE; if(()==IDOK) DrawBCurve();//调用绘制B样条曲线的函数}//以已知的六个点为控制点来绘制B样条曲线//p:已知的六个控制点voidCDiamondView::DrawBCurve(POINTp[6]){}//以已知的四个点为控制点绘制Be