中点Brehensam画线算法
#include<stdio.h>
#include<stdlib.h>
#include"graphics.h"
//函数声明
void MidBrehansem(int x0, int y0, int x1, int y1); //中点MidBrehansem算法
void swap(int &x, int &y); //利用引用传递交换值
int main()
{
int gdriver = DETECT, gmode;
int x0, y0, x1, y1;
printf("Please input start point:\n");
scanf("%d%d", &x0, &y0);
printf("Please input end point:\n");
scanf("%d%d", &x1, &y1);
initgraph(&gdriver, &gmode, "");
MidBrehansem(x0, y0, x1, y1);
system("pause");
closegraph();
return ;
}
//中点MidBrehansem算法
void MidBrehansem(int x0, int y0, int x1, int y1)
{
int dx, dy,i,di;
double k;
if (x0 > x1)
{
swap(x0, x1);
swap(y0, y1);
}
int x = x0, y = y0; //定义到前面会从x1,y1开始画线
dx = x1 - x0;
dy = y1 - y0;
k = 1.0*dy / dx;
i = (abs(dy)>abs(dx)) ? abs(dy): abs(dx);
if (k >= )
{
di = * dx + dy;
while (i--)
{
putpixel(x, y, RED);
if (di >= )
{
di += * (dx - dy);
x++;
}
else
di += * dx;
y++;
}
}
else if (k >= && k < )
{
di = dx - * dy;
while (i--)
{
putpixel(x, y, YELLOW);
if (di < )
{
di += * (dx - dy);
y++;
}
else
di += (-)*dy;
x++;
}
}
else if (k >= - && k < )
{
di = -dx - * dy;
while (i--)
{
putpixel(x, y, YELLOW);
if (di >= )
{
di += (-)*(dx + dy);
y--;
}
else
di += (-)*dy;
x++;
}
}
else
{
di = - * (dx + dy);
while (i--)
{
putpixel(x, y, WHITE);
if (di < )
{
di += (-)*(dx + dy);
x++;
}
else
di += (-)*dx;
y--;
}
}
}
//利用引用传递交换值
void swap(int &x, int &y)
{
int t;
t = x;
x = y;
y = t;
}




中点Brehensam画线算法的更多相关文章
- 中点Brehensam画圆算法
#include<stdio.h> #include<stdlib.h> #include<graphics.h> #include<math.h> v ...
- 两种画线算法(DDA&Bersenham)
DDA(digital differential analyzer) 由直线的斜截式方程引入 对于正斜率的线段,如果斜率<=1,则以单位x间隔(δx=1)取样,并逐个计算每一个y值 Yk+1 = ...
- Bresenham画线算法
[Bresenham画线算法] Bresenham是一种光栅化算法.不仅可以用于画线,也可以用用画圆及其它曲线. 通过lower与upper的差,可以知道哪一个点更接近线段: 参考:<计算机图形 ...
- Bezier画线算法
编译器:VS2013 描述:Bezier画线是利用导数相同拼接曲线,使曲线十分光滑,而不是随意拼接观赏性很差 主函数段 #include "stdafx.h" #include&l ...
- 计算机图形学(二)输出图元_3_画线算法_2_DDA算法
DDA算法 数字微分分析仪(digital differential analyzer, DDA)方法是一种线段扫描转换算法.基于使用等式(3.4)或等式(3.5)计算的&x或& ...
- DDA画线算法
#include<stdio.h> #include"graphics.h" #include<math.h> #include<stdlib.h&g ...
- Bresenham直线算法与画圆算法
在我们内部开发使用的一个工具中,我们需要几乎从 0 开始实现一个高效的二维图像渲染引擎.比较幸运的是,我们只需要画直线.圆以及矩形,其中比较复杂的是画直线和圆.画直线和圆已经有非常多的成熟的算法了,我 ...
- 计算机图形学DDA画线法+中点画线法+Bresenham画线法
#include <cstdio> #include <cstring> #include <conio.h> #include <graphics.h> ...
- 画线函数Glib_Line算法的研究
在这里首先先简单把我对函数的功能的理解阐述一下,方便后面的分析:Glib_Line函数实现的功能是通过参数给定(x1,y1,x2,y2,color),来确定起点(x1,y1)和终点(x2,y2)两 ...
随机推荐
- Java——IO类,字符流写数据
body, table{font-family: 微软雅黑} table{border-collapse: collapse; border: solid gray; border-width: 2p ...
- Translate Exercises(4)
周五翻译课记录. ---------------------------------- (1)and it is imagined by many that the operations of the ...
- grafana的一些坑
坑1: 在设置alert的时候template中的变量是不被支持的,警告如下: 解决办法: 使用不带变量的具体sql查询 坑2: 时间轴的设置: 在更早的版本中时间轴的locale是无法设置的,就是说 ...
- web测试小结
今年5月份开始接触web测试,经过大半年的测试及学习,简单总结下 测试过程: 1.需求理解 2.测试策略.方案.用例编写及评审 3.测试环境搭建 4.测试执行 5.bug提单.问题跟踪 6.回归测试 ...
- RCNN、SPP-net、Fast-RCNN和Faster-RCNN
RCNN RCNN (Regions with CNN features) 的核心思想是把图像划分成N(2000)个独立的区域,分别提取每个区域的CNN特征,然后把这些特征使用SVM等分类器进行结果预 ...
- mos如何工作参考地址
https://wenku.baidu.com/view/c118c3fb360cba1aa811da9d.html?qq-pf-to=pcqq.c2c
- stm32 内部温度传感器的配置
STM32的内部温度传感器和ADCx—IN16输入通道相连接.且温度传感器推荐采样时间为17.1us,支持的温度范围为:-40~125度,精度比较差,± 5℃左右. 计算温度值:T(℃) ={(V25 ...
- 使用struts框架后的404错误
访问jsp界面后出现404错误,我开始以为是因为struts没有配置好,在网上找了很多解决方法, 试了一遍,无效, 最后在参考书上看到“struts2推荐把所有的视图界面存放在WEB-INF目录下,这 ...
- hdu1255 覆盖的面积 线段树-扫描线
矩形面积并 线段树-扫描线裸题 #include<stdio.h> #include<string.h> #include<algorithm> #include& ...
- TP3.2整合kindeditor
HTML <!-- KE图片上传 --> <link rel="stylesheet" href="__PUBLIC__/kindeditor/th ...