版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、计算机图形学实验指导书暨实验报告湖北汽车工业学院实验报告班 级学 号姓 名课程名称完成日期实验二 实现直线的生成算法一、实验目的1、进一步熟悉CDC图形程序库;2、掌握数值微分直线生成算法;3、掌握中点画线算法;4、掌握Bresenham直线生成算法。二、实验性质验证性三、实验要求1、认真阅读本次实验的目的,了解本次实验要求掌握的内容;2、能够根据实验指导书的要求,完成相关的内容;3、根据实验指导书提供的基本思想,完成任意斜率直线的生成。四、实验内容(一)生成绘图应用程序的框架(二)在应用程序中增加菜单(三)在应用程序中增加一个直线参数设置的对话框(四)在绘图函数中添加代码1、利用数值微分算法
2、生成直线(算法的详细原理见教材)。void CDraw_LineView:OnDda() / TODO: Add your command handler code here InputLineInfo Dlg; Dlg.DoModal(); /打开直线参数设置对话框 CDC*pDC=GetDC();/得到绘图类指针 /RedrawWindow();/重绘窗口 int x,x0,y0,x1,y1;/(x0,y0)为直线的起点,(x1,y1)为直线的终点 float dx,dy,k,y; x0=Dlg.qidian_x,y0=Dlg.qidian_y; x1=Dlg.zhongdian_x,y1
3、=Dlg.zhongdian_y; dx=x1-x0; dy=y1-y0; k=dy/dx; y=y0; for(x=x0;x<=x1;x+) pDC->SetPixel(x,int(y+0.5),RGB(255,0,0); y=y+k; 2、利用中点画线算法生成直线(算法的详细原理见教材)。void CDraw_LineView:OnMid() / TODO: Add your command handler code here InputLineInfo Dlg; Dlg.DoModal(); /打开直线参数设置对话框 CDC*pDC=GetDC();/得到绘图类指针 /Red
4、rawWindow();/重绘窗口 int x0,y0,x1,y1;/(x0,y0)为直线的起点,(x1,y1)为直线的终点 int a,b,delta1,delta2,d,x,y; x0=Dlg.qidian_x,y0=Dlg.qidian_y; x1=Dlg.zhongdian_x,y1=Dlg.zhongdian_y; a=y0-y1; b=x1-x0; d=2*a+b; delta1=2*a; delta2=2*(a+b); x=x0; y=y0; pDC->SetPixel(x,y,RGB(0,0,255);/SetPixel为CDC类里面的画点函数,具体参数 while(x&
5、lt;x1) / 有3个,分别是点的坐标和画点所用的颜色。 if(d<0) x+;y+;d+=delta2; else x+;d+=delta1; pDC->SetPixel(x,y,RGB(0,255,0); 3、利用Bresenham画线算法生成直线(算法的详细原理见教材)void CDraw_LineView:OnBre() InputLineInfo Dlg; Dlg.DoModal(); /打开直线参数设置对话框 CDC*pDC=GetDC();/得到绘图类指针 /RedrawWindow();/重绘窗口 int x,y,x0,y0,x1,y1;/(x0,y0)为直线的起
6、点,(x1,y1)为直线的终点 int dx,dy; float k,e; x0=Dlg.qidian_x,y0=Dlg.qidian_y; x1=Dlg.zhongdian_x,y1=Dlg.zhongdian_y; dx=x1-x0; dy=y1-y0; k=float(dy)/dx; e=-0.5; x=x0; y=y0; for(int i=0;i<=dx;i+) pDC->SetPixel(x,y,RGB(0,0,255); x+; e=e+k; if(e>=0) y+; e-; 4、运行效果如图:5、以上的内容为本次实验的基本部分,我们给出的示例代码只能解决直线斜
7、率的绝对值不超过1的情形(|k|1)。当直线的斜率不满足这个条件的时候,如何处理,请同学们根据相关算法的思想,完成任意斜率直线的生成,上机调试通过,并撰写在实验报告书上。五、思考1、MFC开发绘图程序时,工作窗口坐标系是怎么样的,坐标原点在哪儿?2、实现任意斜率直线生成问题时,能不能使用模块化的思想,即将各个画线算法程序进一步分解,通过不同的函数来完成不同斜率的生成?3、三种不同的直线生成算法的分析和比较。六、实验总结湖北汽车工业学院实验报告班 级学 号姓 名课程名称完成日期实验三 实现圆的生成算法一、实验目的1、熟悉CDC图形程序库;2、掌握中点画圆生成算法;3、掌握Bresenham画圆算
8、法;二、实验性质验证性三、实验要求1、认真阅读本次实验的目的,了解本次实验要求掌握的内容;2、能够根据实验指导书的要求,完成相关的内容;四、实验内容(一)生成绘图应用程序的框架(如下图)(二)在应用程序中增加菜单(三)在应用程序中增加一个圆参数设置的对话框(四)在绘图函数中添加代码1、利用中点画圆算法实现圆的生成(算法的详细原理见教材)。void CDraw_CirView:OnMid() / TODO: Add your command handler code hereInputCircleInfo Dlg;Dlg.DoModal(); /打开圆参数设置对话框 CDC*pDC=GetDC(
9、);/得到绘图类指针RedrawWindow();/重绘窗口 int x,y,x0,y0;/圆的圆心为(x0,y0),半径为rfloat r,d;x0=Dlg.yuanxin_x;y0=Dlg.yuanxin_y;r=Dlg.yuan_r;x=0;y=r;d=1.25-r; pDC->SetPixel(x+x0,y+y0,RGB(255,0,0);pDC->SetPixel(y+x0,x+y0,RGB(255,0,0);pDC->SetPixel(y+x0,-x+y0,RGB(255,0,0);pDC->SetPixel(x+x0,-y+y0,RGB(255,0,0);
10、pDC->SetPixel(-x+x0,-y+y0,RGB(255,0,0);pDC->SetPixel(-y+x0,-x+y0,RGB(255,0,0);pDC->SetPixel(-y+x0,x+y0,RGB(255,0,0);pDC->SetPixel(-x+x0,y+y0,RGB(255,0,0);while(x<=y)if(d<0)d=d+2*x+3;x+;elsed=d+2*(x-y)+5;x+;y-;pDC->SetPixel(x+x0,y+y0,RGB(255,0,0); pDC->SetPixel(y+x0,x+y0,RGB(2
11、55,0,0); pDC->SetPixel(y+x0,-x+y0,RGB(255,0,0); pDC->SetPixel(x+x0,-y+y0,RGB(255,0,0); pDC->SetPixel(-x+x0,-y+y0,RGB(255,0,0); pDC->SetPixel(-y+x0,-x+y0,RGB(255,0,0); pDC->SetPixel(-y+x0,x+y0,RGB(255,0,0); pDC->SetPixel(-x+x0,y+y0,RGB(255,0,0);2、利用Bresenham算法生成圆(算法的详细原理见教材)。void CD
12、raw_CirView:OnBre() / TODO: Add your command handler code hereInputCircleInfo Dlg;Dlg.DoModal(); /打开圆参数设置对话框CDC*pDC=GetDC();/得到绘图类指针/RedrawWindow();/重绘窗口int x,y,x0,y0,r;/圆的圆心为(x0,y0),半径为rint delta,delta1,delta2,direction;x0=Dlg.yuanxin_x;y0=Dlg.yuanxin_y;r=Dlg.yuan_r;x=0;y=r;delta=2*(1-r);while(y>
13、;=0) pDC->SetPixel(x+x0,y+y0,RGB(0,0,255); pDC->SetPixel(x+x0,-y+y0,RGB(0,0,255); pDC->SetPixel(-x+x0,y+y0,RGB(0,0,255); pDC->SetPixel(-x+x0,-y+y0,RGB(0,0,255); if(delta<0) delta1=2*(delta+y)-1; if(delta<=0)direction=1; else direction=2; else if(delta>0) delta2=2*(delta-x)-1; if(delta2<=0)direction=2; else direction=3; else direction=2; switch(direction) case 1:x+; delta+=2*x+1;break; case 2:x+;y-; delta+=2*(x
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 单体药房采购制度范本
- 上海外国语大学《旅游资源管理》2025-2026学年期末试卷
- 上海海关学院《消费者行为学》2025-2026学年期末试卷
- 沈阳工业大学《初级财务管理》2025-2026学年期末试卷
- 沈阳音乐学院《商务阅读与写作》2025-2026学年期末试卷
- 山西铁道职业技术学院《侵权责任法》2025-2026学年期末试卷
- 上海工会管理职业学院《投资银行学》2025-2026学年期末试卷
- 山西工程科技职业大学《内科护理》2025-2026学年期末试卷
- 上海中侨职业技术大学《仓储与配送管理》2025-2026学年期末试卷
- 电力虚拟电厂运营员虚拟电厂调度考试题目及答案
- 六年级英语下册Unit9TheYear2050课件
- 食堂卫生工作检查表
- 人教版《图形的放大与缩小》完美版课件3
- 特种经济动物生产学 第七章 鹿课件
- 燃料电池原理及应用课件-002
- 《斐波那契数列》课件
- 质量在我心中,质量在我手中
- 2022年第39届全国中学生物理竞赛预赛试题(含参考答案)
- 绿色建造-绿色施工
- 起重设备安全安全操作规程
- 临沧市凤庆县大摆田水库工程环境影响报告书报批版
评论
0/150
提交评论