Bresenham的线描代码

时间:2013-09-12 10:13:46

标签: c vector-graphics turbo-c++ bresenham dosbox

我正在尝试使用Bresenham算法在C语言中绘制一条线。我在dosbox中使用turbo C ++来实现这个代码。虽然编译我没有得到任何错误但是当我运行代码时程序在获得2个坐标后终止。请帮助..

编译时的消息如下。 enter image description here

目录路径如下enter image description here

我的代码..

  # include <stdio.h>
  # include <conio.h>
  # include <graphics.h>

  void main()
  {
    int dx,dy,x,y,p,x1,y1,x2,y2;
    int gd,gm;

    clrscr();

    printf("\n\n\tEnter the co-ordinates of first point : ");
    scanf("%d %d",&x1,&y1);
    printf("\n\n\tEnter the co-ordinates of second point : ");
    scanf("%d %d",&x2,&y2);

    dx = (x2 - x1);
    dy = (y2 - y1);

    p = 2 * (dy) - (dx);

    x = x1;
    y = y1;

    detectgraph(&gd,&gm);
    initgraph(&gd,&gm,"e:\\tc\\bgi");
    putpixel(x,y,WHITE);

    while(x <= x2)
    {
      if(p < 0)
      {
        x=x+1;
        y=y;
        p = p + 2 * (dy);
      }
      else
      {
        x=x+1;
        y=y+1;
        p = p + 2 * (dy - dx);
     }
     putpixel(x,y,WHITE);
   }
   getch();
   closegraph();
}

4 个答案:

答案 0 :(得分:1)

OP应该发布已使用的输入。

发布的示例代码不起作用x1&gt; x2y1&gt; y2。这是一组可以突然停止例程的输入。要解决此问题,dxdy应基于绝对值和增量x&amp; y步骤需要独立+1 -1

输入3,4而不是3 4(逗号与空格)也会使例程陷入混乱。

在while循环中,推荐if(p <= 0)

OP的“...程序在获得2个坐标后终止。”不够详细,因为代码当然在获得2个坐标后的某个时间终止。但OP没有详细说明它过早终止的地方。

答案 1 :(得分:0)

这是启动调试器并逐步完成代码,观察任何变量的典型完美点。如果调试器不可用,则对控制台的printf调试是备用替代方案。

第一个提示是检查这些行是否不会产生错误/异常:

  detectgraph(&gd,&gm);
  initgraph(&gd,&gm,"e:\\tc\\bgi");
  putpixel(x,y,WHITE);

答案 2 :(得分:0)

解决问题的方法是根据屏幕截图中提到的地址更改initgraph函数中的路径。

             detectgraph(&gd,&gm);
             initgraph(&gd,&gm,"C:\\TURBOC3\\bgi");
             putpixel(x,y,WHITE);

答案 3 :(得分:0)

好的计划。但是,你没有初始化任何循环以及while循环中编码的行部分不正确。这是我的尝试: -

i = 1; // loop initialization
do {
    putpixel(x, y, 15);
    while(p >= 0) {
        y = y + 1;
        p = p - (2 * dx);
    }
    x = x + 1;
    p = p + (2 * dy);
    i = i + 1;
}
while(i <= dx);