直线的中点Bresenham算法的实现
一、实验目的
1.掌握在MFC中搭建图形绘制的基本框架的方法;
2.将直线的中点Bresenham算法转化成可执行代码。
二、实验内容
1. 通过分析具体数据在中点Bresenham算法上的执行过程,绘制算法执行流程图或N-S图,在MFC中实现该算法,要求编写函数实现任意给定两点绘制线段。
三、实验步骤
任意给定的两点所绘制的线段斜率k可能有四种情况,分别是:0<k<1,k>=1,-1<k<0,
k<=-1。下面对这四种情况分别进行分析。
(一) 当0<k<1时
1.算法原理的推导
(1)构造中点误差项为:

(2)中点误差的初始值是:

(3)推导di+1


2.算法执行的N-S图

3.算法执行的主要代码
void CExp2View::OnLButtonUp(UINT nFlags, CPoint point)
{
// TODO: Add your message handler code here and/or call default
p1=point;
CDC *pDC=this->GetDC();
COLORREF c;
DrawLine(pDC,p0,p1,c);
CView::OnLButtonUp(nFlags, point);
}
void CExp2View::OnLButtonDown(UINT nFlags, CPoint point)
{
// TODO: Add your message handler code here and/or call default
p0=point;
CView::OnLButtonDown(nFlags, point);
}
void CExp2View::DrawLine(CDC *pDC, CPoint p0, CPoint p1,COLORREF c)
{ ///*
//1.fabs(k)>0&&fabs(k)<1
double k=1.0*(p1.y-p0.y)/(p1.x-p0.x), d=0.5-k;
if(fabs(k)>) return;
int x,y;
for(x=p0.x,y=p0.y;x<=p1.x;x++){
if(d>=){
pDC->SetPixel(x,y,0xff0000);
d+=-k;
}
else{
y++;
pDC->SetPixel(x,y,0xff0000);
d+=-k;
}
}
//*/
}
4.执行结果
![]() |
(二) 当k>=1时
1.算法原理的推导
(1)构造中点误差项为:

(2)中点误差的初始值是:

(3)推导di+1


2.算法执行的N-S图

3.算法执行的主要代码
void CExp2View::OnLButtonUp(UINT nFlags, CPoint point)
{
// TODO: Add your message handler code here and/or call default
p1=point;
CDC *pDC=this->GetDC();
COLORREF c;
DrawLine(pDC,p0,p1,c);
CView::OnLButtonUp(nFlags, point);
}
void CExp2View::OnLButtonDown(UINT nFlags, CPoint point)
{
// TODO: Add your message handler code here and/or call default
p0=point;
CView::OnLButtonDown(nFlags, point);
}
void CExp2View::DrawLine(CDC *pDC, CPoint p0, CPoint p1,COLORREF c)
{ ///*
//2.fabs(k)>=1
double k=1.0*(p1.y-p0.y)/(p1.x-p0.x), d=-0.5*k;
if(fabs(k)>&&fabs(k)<) return;
int x,y;
for(x=p0.x,y=p0.y;x<=p1.x;y++){
if(d>=){
x++;
pDC->SetPixel(x,y,0x00ff00);
d+=-k;
}
else{
pDC->SetPixel(x,y,0x00ff00);
d+=;
}
}
}
4.执行结果

(三) 当-1<k<0时
1.算法原理的推导
(1)构造中点误差项为:

(2)中点误差的初始值是:

(3)推导di+1


2.算法执行的N-S图

3.算法执行的主要代码
void CExp2View::OnLButtonUp(UINT nFlags, CPoint point)
{
// TODO: Add your message handler code here and/or call default
p1=point;
CDC *pDC=this->GetDC();
COLORREF c;
DrawLine(pDC,p0,p1,c);
CView::OnLButtonUp(nFlags, point);
}
void CExp2View::OnLButtonDown(UINT nFlags, CPoint point)
{
// TODO: Add your message handler code here and/or call default
p0=point;
CView::OnLButtonDown(nFlags, point);
}
void CExp2View::DrawLine(CDC *pDC, CPoint p0, CPoint p1,COLORREF c)
{ ///*
/*
//3.fabs(k)>-1&&fabs(k)<0
double k=1.0*(p1.y-p0.y)/(p1.x-p0.x), d=-0.5-k;
//if(fabs(k)>1||fabs(k)<-1||(fabs(k)>0&&fabs(k)<1)) return;
int x,y;
for(x=p0.x,y=p0.y;x<=p1.x;x++){
if(d>=0){
y=y-1;
pDC->SetPixel(x,y,0x0000ff);
d+=-1-k;
}
else{
pDC->SetPixel(x,y,0x0000ff);
d+=-k;
}
}
*/}
4.执行结果
![]() |
(四) 当k<=-1时
1.算法原理的推导
(1)构造中点误差项为:

(2)中点误差的初始值是:

(3)推导di+1


2.算法执行的N-S图

3.算法执行的主要代码
void CExp2View::OnLButtonUp(UINT nFlags, CPoint point)
{
// TODO: Add your message handler code here and/or call default
p1=point;
CDC *pDC=this->GetDC();
COLORREF c;
DrawLine(pDC,p0,p1,c);
CView::OnLButtonUp(nFlags, point);
}
void CExp2View::OnLButtonDown(UINT nFlags, CPoint point)
{
// TODO: Add your message handler code here and/or call default
p0=point;
CView::OnLButtonDown(nFlags, point);
}
void CExp2View::DrawLine(CDC *pDC, CPoint p0, CPoint p1,COLORREF c)
{ ///*
//1.fabs(k)>0&&fabs(k)<1
double k=1.0*(p1.y-p0.y)/(p1.x-p0.x), d=0.5-k;
if(fabs(k)>) return;
int x,y;
for(x=p0.x,y=p0.y;x<=p1.x;x++){
if(d>=){
pDC->SetPixel(x,y,0xff0000);
d+=-k;
}
else{
y++;
pDC->SetPixel(x,y,0xff0000);
d+=-k;
}
}
//*/
}
4.执行结果
![]() |
四、实验结果与讨论
根据任意给定的两点所绘制的线段斜率k可能有的四种情况,实验结果如下:
(一) 当0<k<1时:
![]() |
(二) 当k>=1时:
![]() |
(三) 当-1<k<0时:
![]() |
(四) 当k<=-1时:
![]() |
五、总结
(一)本次实验按时按量完成。
(二)通过本次实验,我掌握了在MFC中搭建图形绘制的基本框架的方法;掌握了如何将直线的中点Bresenham算法转化成可执行代码。
(三)在本次实验中,我通过分析具体数据在中点Bresenham算法上的执行过程,分四种情况绘制算法执行N-S图,并且在MFC中实现了该算法。
参见源码:https://github.com/shenxiaolinZERO/Resources/tree/master/Resources/Computer-Graphics/Bresenham
直线的中点Bresenham算法的实现的更多相关文章
- Bresenham算法的实现思路
条件已知两个点的坐标p1(x0,y0),p2(x1,y1)要求画出这条直线 之后的e代表每次的误差积累,初始值为0,可以计算出斜率为k=dy/dx=(y0-y1)/(x0-x1) 1.x为阶跃步长(直 ...
- 《图形学》实验四:中点Bresenham算法画直线
开发环境: VC++6.0,OpenGL 实验内容: 使用中点Bresenham算法画直线. 实验结果: 代码: //中点Bresenham算法生成直线 #include <gl/glut.h& ...
- Python使用DDA算法和中点Bresenham算法画直线
title: "Python使用DDA算法和中点Bresenham算法画直线" date: 2018-06-11T19:28:02+08:00 tags: ["图形学&q ...
- Bug2算法的实现(RobotBASIC环境中仿真)
移动机器人智能的一个重要标志就是自主导航,而实现机器人自主导航有个基本要求--避障.之前简单介绍过Bug避障算法,但仅仅了解大致理论而不亲自动手实现一遍很难有深刻的印象,只能说似懂非懂.我不是天才,不 ...
- 利用canvas实现的中点Bresenham算法
Bresenham提出的直线生成算法的基本原理是,每次在最大位移方向上走一步,而另一个方向是走步还是不走步取决于误差项的判别,具体的实现过程大家可以去问度娘.我主要是利用canvas画布技术实现了这个 ...
- Python八大算法的实现,插入排序、希尔排序、冒泡排序、快速排序、直接选择排序、堆排序、归并排序、基数排序。
Python八大算法的实现,插入排序.希尔排序.冒泡排序.快速排序.直接选择排序.堆排序.归并排序.基数排序. 1.插入排序 描述 插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得 ...
- 图像数据到网格数据-2——改进的SMC算法的实现
概要 本篇接上一篇继续介绍网格生成算法,同时不少内容继承自上篇.上篇介绍了经典的三维图像网格生成算法MarchingCubes,并且基于其思想和三角形表实现了对样例数据的网格构建.本篇继续探讨网格生成 ...
- 《图形学》实验七:中点Bresenham算法画椭圆
开发环境: VC++6.0,OpenGL 实验内容: 使用中点Bresenham算法画椭圆. 实验结果: 代码: #include <gl/glut.h> #define WIDTH 50 ...
- 《图形学》实验六:中点Bresenham算法画圆
开发环境: VC++6.0,OpenGL 实验内容: 使用中点Bresenham算法画圆. 实验结果: 代码: #include <gl/glut.h> #define WIDTH 500 ...
随机推荐
- 【Codeforces】【#295】【Div.2】
o(︶︿︶)o 唉跪烂了…… B题由于考虑的不周全WA了3次…… C题由于#include了<cmath>,而我函数声明的是pow(LL a,LL b)但调用的时候 [没!有!把!n!的! ...
- ActiveMQ使用示例之Queue
我们使用ActiveMQ为大家实现一种点对点的消息模型. 开发时候,要将apache-activemq-5.12.0-bin.zip解压缩后里面的activemq-all-5.12.0.jar包加入到 ...
- is-subsequence
public class Solution { public boolean isSubsequence(String s, String t) { int idx = 0; for (int i=0 ...
- Valid Parentheses leetcode java
题目: Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the ...
- FM遇到错误RQP-DEF-0354和QE-DEF-0144
版本:Cognos 10.2.1 系统:Win10 操作过程:在FM调用了一个存储过程,其中引用了前端page页面的参数如下图所示,在验证和保存查询主题的时候一直提示参数没有替换值,错误 信息如下图所 ...
- Discuz上传错误
换了服务器后,上传图片的时候,显示上传100%,然后报错:upload error: 500.怎么回事那? [解决方法] 原来是php上传文件的时候,会首先上传到一个临时目录.如果临时目录没有权限,就 ...
- Fusioncharts的导出图片訪问官网问题
Fusioncharts3.5使用自带的导出功能,须要訪问官网 问题描写叙述:使用fusioncharts自带的exportchart方法来导出图片的时候.要訪问export.api3.fusionc ...
- Ipad也怕冷?!
今天,说一Ipad充不了电,我想才没买好久,这么快电池就坏了呀.难道买到歪货了? 它的表现是充电线一接上去,电池指示有反应,也有"闪电"标志,就是充不进去电.本来想打客服的,还是先 ...
- MyEclipse中使用Junit插件进行单元测试
http://wenku.baidu.com/view/ec904a116bd97f192279e9a6.html
- uva 10670 Work Reduction(贪心)
题目连接:10670 - Work Reduction 题目大意:有tol的工作量,和要求达到的工作剩余量sur,然后是公司总数,对应每个公司提供两种服务,1.完成一个工作量,2.完成当前未完成工作量 ...






