在VC++6.0中实现直线的扫描转换算法.doc
文本预览下载声明
宁夏师范学院数学与计算机科学学院
《》实验报告
实验序号:实验项目名称:
学号 姓名 专业、班 14计本一班 实验地点 指导教师 时间 一、实验目的:
学会使用MFC,能够运用直线的三种扫描算法即数值微分算法(DDA算法)、中点画线算法和Bresenham画线算法绘制直线,并熟悉掌握制作过程。
二、实验环境:
Windows 7
VC++ 6.0
实验内容:
打开vc6.0,点击新建—工程—MFC AppWizard [exe],创建项目名称(随便写),确定位置,然后点击确定。
选择创建的应用类型—单文档—完成。
点击确定。
DDA算法:
添加成员函数:
展开Wangyanyan classes—右击WangyanyanView—选择Add Member Funtion(添加成员函数)—函数类型定义为void,函数描述为:DDAline—点击确定
2.展开Wangyanyan classes—CWangyanyanView—在DDAline()函数里添加形参int x0,int y0,int x1,int y1,int color,CClientDC dc
3.双击CWangyanyanView,在public中添加代码:
void CWangyanyanjView::DDAline(int x0,int y0,int x1,int y1,int color,CClientDC dc);
记住最后加分号
4.展开CWangyanyan—双击OnDraw—添加代码:
CClientDC dc(this);
DDAline(8,12,20,20,RGB(255,145,200),dc);
双击DDAline,在函数体内编写如下代码:
void CDWangyanyanView::DDAline(int x0,int y0,int x1,int y1,int color,CClientDC dc)
{
CPen newpen(PS_SOLID,1,color);
dc.SelectObject(newpen);
int x,dx,dy,y,k;
dx=x1-x0;
dy=y1-y0;
k=dy/dx;
y=y0;
for(x=x0;x=x1;x++)
{
dc.SetPixel(x,int(y+0.5),color);
y=y+k;
}
}
调试程序:
运行结果:
中点画线算法:
添加成员函数
1.展开Wangyanyan classes—右击CWangyanyanView—选择Add Member Funtion(添加成员函数)—函数类型定义为void,函数描述为:MidpointLine—点击确定
2.展开classes—CWangyanyanview,在MidpointLine函数里添加形参int x0,int y0,int x1,int y1,int color,CClientDC dc
3.双击CWangyanyanView,在public中添加代码:
void CWangyanyanView::MidpointLine(int x0,int y0,int x1,int y1,int color,CClientDC dc);最后加分号
4.展开CWangyanyanView—双击OnDraw—添加代码:
MidpointLine(20,15,200,485,RGB(80,120,255), dc);
双击MidpointLine,在函数体内编写如下代码:
CPen newpen(PS_SOLID,1,color);
dc.SelectObject(newpen);
int a,b,delta1,delta2,d,x,y;
a=y0-y1;
b=x1-x0;
d=2*a+b;
delta1=2*a;
delta2=2*(a+b);
x=x0;
y=y0;
dc.SetPixel(x,y,color);
while(xx1)
{
if(d0)
{
x++;
y++;
d+=delta2;
}
else
{
x++;
d+=delta2;
}
dc.SetPixel(x,y,color);
}
调试程序:
运行结果:
Bresenham算法:
添加成员函数
1.展开Wangyanyan classes—右击CWangyanyanView—选择Add Member Funtion,函数类型定义为void,函
显示全部