




已阅读5页,还剩3页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
+ 实验 (二) 项目名称: B样条曲线几何原理演示1、 实验要求在屏幕上使用鼠标左键绘制任意点形成控制多边形,单击鼠标右键绘制三次B样条曲线的程序,同时在控制多边形的每一个控制三角形内显示曲线生成原理,效果如图。原理:2、 实验过程(有关主要代码如下:)bool Flag;/标志CPoint *pt;/顶点int CtrlPoint;/控制多边形顶点/绘制B曲线void CTestView:DrawBSpline()CClientDC dc(this);int i,rate=10;long lx,ly;double F03,F13,F23,F33;lx=ROUND(pt0.x+4.0*pt1.x+pt2.x)/6.0);ly=ROUND(pt0.y+4.0*pt1.y+pt2.y)/6.0);dc.MoveTo(lx,ly);CPen NewPen(PS_SOLID,1,RGB(0,0,255);CPen *OldPen=dc.SelectObject(&NewPen);for(i=1;i=CtrlPoint-3;i+)for(double t=0;t=1;t+=1.0/rate)F03=(-t*t*t+3*t*t-3*t+1)/6;/计算F0,3(t)F13=(3*t*t*t-6*t*t+4)/6;/计算F1,3(t)F23=(-3*t*t*t+3*t*t+3*t+1)/6;/计算F2,3(t)F33=t*t*t/6;/计算B3,3(t)lx=ROUND(pti-1.x*F03+pti.x*F13+pti+1.x*F23+pti+2.x*F33);ly=ROUND(pti-1.y*F03+pti.y*F13+pti+1.y*F23+pti+2.y*F33);dc.LineTo(lx,ly);Sleep(100);dc.SelectObject(OldPen);NewPen.DeleteObject();/绘制控制多边形void CTestView:DrawCharPolygon()CClientDC dc(this);CPen MyPen,*pOldPen;MyPen.CreatePen(PS_SOLID,3,RGB(0,0,0);pOldPen=dc.SelectObject(&MyPen);for(int i=0;iCtrlPoint;i+)if(i=0)dc.MoveTo(pti);dc.Ellipse(pti.x-2,pti.y-2,pti.x+2,pti.y+2);elsedc.LineTo(pti);dc.Ellipse(pti.x-2,pti.y-2,pti.x+2,pti.y+2);dc.SelectObject(pOldPen);MyPen.DeleteObject();/获得屏幕控制点坐标void CTestView:OnLButtonDown(UINT nFlags, CPoint point) / TODO: Add your message handler code here and/or call defaultCView:OnLButtonDown(nFlags, point);if(Flag)ptCtrlPoint.x=point.x;ptCtrlPoint.y=point.y;if(CtrlPointN_MAX_POINT-1)CtrlPoint+;elseFlag=false;DrawCharPolygon();/调用绘制函数void CTestView:OnRButtonDown(UINT nFlags, CPoint point) / TODO: Add your message handler code here and/or call defaultif(CtrlPoint!=0)Flag=false;DrawBSpline();CView:OnRButtonDown(nFlags, point);/绘制绘制几何生成原理图void CTestView:DrawStruct() CClientDC dc(this);CPen NewPen(PS_DOT,1,RGB(0,0,0);CPen *OldPen=dc.SelectObject(&NewPen);int x,y;for(int i=1;i=CtrlPoint-2;i+)x=(pti-1.x+pti+1.x)/2;y=(pti-1.y+pti+1.y)/2;dc.MoveTo(pti.x,pti.y);dc.LineTo(x,y);dc.MoveTo(pti-1.x,pti-1.y);dc.LineTo(pti+1.x,pti+1.y);dc.SelectObject(OldPen);NewPen.DeleteObject();/绘制曲线菜单函数void CTestView:OnMENUBCurve() / TODO: Add your command handler code hereRedrawWindow();MessageBox(单击左键绘制控制多边形,单击右键绘制曲线,提示,MB_OK);pt=new CPointN_MAX_POINT;Flag=true;CtrlPoint=0;/绘制几何结构菜单函
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年9月份黑龙江齐齐哈尔市碾子山区开发公益性岗位2人考试参考试题及答案解析
- 2025年崇仁县城区学校初中部公开选调教师【19人】备考练习题库及答案解析
- 2025中国电科36所校园招聘考试参考试题及答案解析
- 2025年颗粒系列行业研究报告及未来行业发展趋势预测
- 2025年打底裤行业研究报告及未来行业发展趋势预测
- 2025年度影视明星独家演出合同保密及竞业禁止协议
- 2025年可再生能源发电项目20%股权收购与市场推广合作合同
- 低能耗印染技术优化-洞察及研究
- 2025年绿色节能光纤通信网络建设协议书
- 直播家居收纳技巧创新创业项目商业计划书
- 2025年医疗质量管理质控培训考核试题(含答案)
- 深圳2025年重大项目计划申报
- 学生不住校申请书
- 2025年传动部件行业当前市场规模及未来五到十年发展趋势报告
- 小学科学新教科版二年级上册第一单元 造房子教案(共6课)(2025秋)
- 合同签订履行风险防范培训课件
- 《安装工程识图》中职技工全套教学课件
- ISO28000:2022供应链安全管理体系
- JIS G4305-2021 冷轧不锈钢板材、薄板材和带材
- 硬笔书法《浅谈书法》历史起源(课堂PPT)
- 员工自愿放弃社保公积金协议、自愿放弃社保协议书、自愿放弃社保声明书
评论
0/150
提交评论