Bresenham画直线,任意斜率

该代码段展示了使用Bresenham算法在MATLAB中绘制任意斜率直线的方法。根据直线的斜率,算法分为几个分支进行处理,确保在不同斜率条件下都能准确高效地画出直线。
摘要由CSDN通过智能技术生成
  function DrawLineBresenham(x1,y1,x2,y2)
%sort by x,sure x1<x2.
if x1>x2
    tmp=x1;
    x1=x2;
    x2=tmp;
    tmp=y1;
    y1=y2;
    y2=tmp;
end
dx=x2-x1;
dy=y2-y1;
twoDy=2*dy;
twoDy_Dx=2*(dy-dx);
twoDx=2*dx;
twoDx_Dy=2*(dx-dy);
twoDxPlusDy=2*(dx+dy);
%branch 1: k>0 ?
%k>0 <=> dy>0

if dy>0  %k>0
    if dx==0   %if k==INF
        for i=y1:y2
            plot(x1,i,'*');
            hold('on');
        end
        return ;
    end
    %branch 2:k=INF
    
    %branch 3: k<1 <=> dy<dx
    if dy<dx   %k<1
          p=  twoDy-dx;
          plot(x1,y1,'*');
          hold('on');
          while x1<x2
               x1=x1+1;
               if(p<0)
                   p=p+twoDy;
               else
                   y1=y1+1;
                   p=p+twoDy_
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值