Android 自定义 —— View moveTo与 rMoveTo 的区别

moveTo 的作用:

将下一个轮廓的起点设置为点(x,y)

我们在使用lineTo的使用启动是(0,0)肯定不是每次都想从(0,0)点开始所以配合moveTo 移动之后的点在使用lineTo移动。

下面看下代码和效果图

  paint.setAntiAlias(true);
        // 设置画笔的style (Paint.Style.FILL填充,Paint.Style.STROKE描边,Paint.Style.FILL_AND_STROKE填充加描边  )
        paint.setStyle(Paint.Style.STROKE);
        // 设置画笔的颜色
        paint.setColor(Color.RED);
        //设置描边宽度
        paint.setStrokeWidth(10f);
        Path path = new Path();
        path.moveTo(300,300);
        path.lineTo(300,600);
        path.moveTo(300,300);
        path.lineTo(600,600);
        // 绘制线
        canvas.drawPath(path,paint);

效果图

rMoveTo 的作用:

相对于上一个轮廓上的最后一个点设置下一个轮廓的起点。如果没有以前的轮廓,则处理与moveTo()相同

这里最后一个点设置下一个轮廓的起点怎么理解呢下面上面的数据说下(注意上面的图我给出的划线的顺序)

  paint.setAntiAlias(true);
        // 设置画笔的style (Paint.Style.FILL填充,Paint.Style.STROKE描边,Paint.Style.FILL_AND_STROKE填充加描边  )
        paint.setStyle(Paint.Style.STROKE);
        // 设置画笔的颜色
        paint.setColor(Color.RED);
        //设置描边宽度
        paint.setStrokeWidth(10f);
        Path path = new Path();
        //前面的的轮廓,则处理与moveTo()相同这里就不再改为rMoveTo了
        path.moveTo(300,300);
        path.lineTo(300,600);
        path.rMoveTo(300,300);
        path.lineTo(600,600);
        // 绘制线
        canvas.drawPath(path,paint);

效果图如下

希望上图大家能理解最后一个点设置下一个轮廓的起点的意思。 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值