breseham画直线算法

#include<graphics.h>

void main()
{
    int driver,mode;
    int xa,ya,xb,yb,c;
    int dx,dy,steps,k;
    int inc,tmp,const1,const2,p;
    int x,y;
    int wx,wy;
    driver=DETECT;
    k=1;
    mode=0;
    initgraph(&driver,&mode,"");
    printf("please enter the start point:/n");
    printf(" xa= ");
    scanf("%d",&xa);
    printf(" ya= ");
    scanf("%d",&ya);
    printf("please enter the end point:/n");
    printf(" xb= ");
    scanf("%d",&xb);
    printf(" yb= ");
    scanf("%d",&yb);
   
    dx=xb-xa;
    dy=yb-ya;

    if(abs(dx)>abs(dy))
    {
        if(dx*dy>=0)
            inc=1;
        else
            inc=-1;
        if(dx<0)
        {
            tmp=xa;
            xa=xb;
            xb=tmp;
            tmp=ya;
            ya=yb;
            yb=tmp;
            dx=-dx;
            dy=-dy;
        }
        p=2*dy-dx;
        const1=2*dy;
        const2=2*(dy-dx);
        x=xa;
        y=ya;
        putpixel(x,y,YELLOW);
        k++;
        while(x<xb)
        {
            x++;
            if(p<0)
                p+=const1;
            else
            {
                y+=inc;
                p+=const2;
            }
            putpixel(x,y,YELLOW);
            k++;
        }
    }
   
    else{
    if(dx*dy<=0)
        inc=1;
    else
        inc=-1;
        if(dy<0){
            tmp=xa;
            xa=xb;
            xb=tmp;
            tmp=ya;
            ya=yb;
            yb=tmp;
            dx=-dx;
            dy=-dy;
        }
        p=2*dx-dy;
        const1=2*dx;
        const2=2*(dx-dy);
        x=xa;
        y=ya;
        putpixel(x,y,YELLOW);
        k++;
        while(y<yb){
            y++;
            if(p>0)
                p+=const1;
            else{
                x+=inc;
                p+=const2;
            }
            printf("%d,",x);
            putpixel(x,y,YELLOW);
            k++;
        }
    }
    getch();
   
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值