计算机图形学上机实验4_实现Bezier曲线与Bezier曲面的绘制.docVIP

计算机图形学上机实验4_实现Bezier曲线与Bezier曲面的绘制.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
昆 明 理 工 大 学 理 学 院 信息与计算科学专业 操作性实验报告 年级: 10级 姓名: 刘陈 学号: 201011101128 指导教师: 胡杰 实验课程名称: 计算机图形学程序设计 开课实验室: 理学院机房216 实验成绩: 学风(5) 观察能力(15) 操作能力(30) 调试能力(50) 其它 总分 实验内容: 1.实验/作业题目:用计算机高级语言VC++6.0实现计算机的基本图元绘制 2.实验/作业课时:2学时 3.实验过程(包括实验环境、实验内容的描述、完成实验要求的知识或技能): 实验环境:(1)硬件:每人一 台PC机 (2)软件:windows OS,VC++6.0或以上版本。 试验内容及步骤: (1)在VC++环境下创建MFC应用程序工程(单文档) (2)编辑菜单资源 (3)添加菜单命令消息处理函数 (4)添加成员函数 (5)编写函数内容 试验要求: (1)掌握Bezier曲线、Bezier曲面、及另一个曲面的算法。 (2)实现对Bezier曲线、Bezier曲面、及另一个曲面。 (3)试验中调试、完善所编程序,能正确运行出设计要求结果。 (4)书写试验报告上交。 4.程序结构(程序中的函数调用关系图) 5.算法描述、流程图或操作步骤: 在lab4iew.cpp文件中添加如下头文件及变量 int flag_2=0; int n_change; #define M 30 #define PI 3.14159 //圆周率 #include math.h //数学头文件 在lab4iew.h文件中的public内添加变量 : int move; int graflag; void Tiso(float p0[3],float x0, float y0, float p[3]); void OnBezierface(); 在lab4iew.h文件中的protected内添加变量: int n;//控制点数 const int N;//控制点数的上限 CPoint* a;//控制点存放的数组 double result[4][2]; 在lab4iew.cpp文件中的函数Clab4iew::OnDraw(CDC* pDC)下添加如下代码: int i,j; for(i=0;in;i++) {pDC-FillSolidRect(a[i].x-2,a[i].y-2,4,4,RGB(255,55,255)); } pDC-MoveTo(a[0]); for(j=0;jn;j++) { pDC-LineTo(a[j]); } if(n2) return;//如果控制点数少于2,则不用画 CPen pen(0,2,RGB(255,0,255)),*p1; p1=pDC-SelectObject(pen); …… 在Lab4iew.cpp文件中添加如下的各个消息处理函数及代码: void CLab4View::OnLButtonDown(UINT nFlags, CPoint point) { if(flag_2==0) //flag_2等于0,此时是输入控制点状态 { CClientDC dc(this); //实时输入一个控制点,在屏幕上显示此点 dc.FillSolidRect(point.x-2,point.y-2,4,4,RGB(0,0,255)); if(nN){a[n++]=point;} //给控制点数组a[]赋值 else {MessageBox(控制点太多!,waring,MB_OK|MB_ICONINFORMATION);} } else if(flag_2==1) //flag_2等于1,此时是修改控制点状态 { int i; for(i=0;in;i++) { if((abs(point.x-a[i].x)10)(abs(point.y-a[i].y)10)) //给定一个范围,如果在范围内,则选中该控制点 { n_change=i; } } CClientDC dc(this); //如果选中该点,则该

文档评论(0)

189****6140 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档