计算机图形学_第1页
计算机图形学_第2页
计算机图形学_第3页
计算机图形学_第4页
计算机图形学_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

宁夏师范学院数学与计算机科学学院计算机图形学实验报告实验序号:2 实验项目名称:直线的扫描转换学 号2014210677 姓 名 王艳艳专业、班级 14计本一班实验地点 文科楼206 指导教师 罗晓丽 时间 2017.3.31一、实验目的: 学会使用MFC,运用中点画圆算法和Bresenham画圆算法以及椭圆的扫描转换算法绘制圆和椭圆,并熟悉掌握制作过程。二、实验环境:Windows 7VC+ 6.03、 实验内容:打开vc6.0,点击新建工程MFC AppWizard exe,创建项目名称(随便写),确定位置,然后点击确定。选择创建的应用类型单文档完成。点击确定。中点画园算法:添加成员函数:1. 展开Wangyanyan classes右击WangyanyanView选择Add Member Funtion(添加成员函数)函数类型定义为void,函数描述为:Midpoint_Circle点击确定2.展开Wangyanyan classesCWangyanyanView在Midpoint_Circle()函数里添加形参,int r,int color,CClientDC & dc3.双击CWangyanyanView,在public中添加代码:void CWangyanyanView: Midpoint_Circle (int y1,int r,int color,CClientDC & dc);记住最后加分号4.展开CWangyanyan双击OnDraw添加代码: CClientDC dc(this); DDAline(100,RGB(255,145,200),dc); 5. 双击DDAline,在函数体内编写如下代码:void CWangyanyanView:Midpoint_Circle(int r,int color,CClientDC & dc)CPen newpen(PS_SOLID,1,color); dc.SelectObject(&newpen);int x,y,d;x=0;y=r;d=1-r;while(xy)dc.SetPixel(x+r,y+r,color); dc.SetPixel(-x+r,y+r,color); dc.SetPixel(-x+r,-y+r,color); dc.SetPixel(x+r,-y+r,color); dc.SetPixel(y+r,x+r,color); dc.SetPixel(-y+r,x+r,color); dc.SetPixel(y+r,-x+r,color); dc.SetPixel(-y+r,-x+r,color);if(d右击CWangyanyanView选择Add Member Funtion,函数类型定义为void,函数描述为:Bresenham_Line点击确定2.点击classesCWangyanyanjview,在Bresenham_Circle函数里添加形参int r,int color,CClientDC & dc3.双击CWangyanyanView,在public中添加代码:void CWangyanyanView:Bresenham_Line(int r,int color,CClientDC & dc);最后加分号4.展开CWangyanyanView双击OnDraw添加代码:Bresenham_Circle(150,RGB(20,180,250), dc);5. 双击Bresenham_Circle,在函数体内编写如下代码: void CWangyanyanView:Bresenham_Circle(int r,int color,CClientDC & dc)CPen newpen(PS_SOLID,1,color); dc.SelectObject(&newpen);int x,y,delta,delta1,delta2,direction;x=0;y=r;delta=2*(1-r);while(y=0)dc.SetPixel(x+r,y+r,color); dc.SetPixel(-x+r,y+r,color); dc.SetPixel(-x+r,-y+r,color); dc.SetPixel(x+r,-y+r,color); dc.SetPixel(y+r,x+r,color); dc.SetPixel(-y+r,x+r,color); dc.SetPixel(y+r,-x+r,color); dc.SetPixel(-y+r,-x+r,color);if(delta0)delta1+=2*(delta+y)-1;if(delta10)delta2=2*(delta-x)-1;if(delta2右击WangyanyanView选择Add Member Funtion(添加成员函数)函数类型定义为void,函数描述为:Midpoint_Ellipse点击确定3. 点击classesCWangyanyanjview,在Midpoint_Ellipse函数里添加形参int a,int b,int color,CClientDC&dc 3.双击CWangyanyanView,在public中添加代码:void CWangyanyanView: Midpoint_Ellipse (int a,int b,int color, CClientDC &dc);最后加分号4. 展开CWangyanyanView双击OnDraw添加代码:CClientDC dc(this);Midpoint_Ellipse (50,100,150,RGB(20,180,250), dc);6. 双击Midpoint_Ellipse,在函数体内编写如下代码: void CLYYMidpointEllipseView:Midpoint_Ellipse(int a,int b,int color,CClientDC & dc) CPen newpen(PS_SOLID,1,color); dc.SelectObject(&newpen); int x,y; float d1,d2; x=0;y=b; d1=b*b+a*a*(-b+0.25); dc.SetPixel(x+a,y+b,color); dc.SetPixel(-x+a,y+b,color); dc.SetPixel(-x+a,-y+b,color); dc.SetPixel(x+a,-y+b,color); while(b*b*(x+1)a*a*(y-0.5) if(d10) if(d20) d2+=b*b*(2*x+2)+a*a*(-2*y+3); x+; y-; else d2+=a*a*(-2*y+3); y-;

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论