自定义View-剪切区

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_32113133/article/details/66970882
Canvas 提供了剪切区的功能,剪切区可以是一个 Rect 或者是一个 Path,两个剪切区还能进
行图形运算,得到更加复杂的剪切区。我们来看看相关的方法:
public boolean clipRect(Rect rect)
public boolean clipRect(RectF rect)
public boolean clipRect(float left,float top,float right,float bottom)
public boolean clipRect(int left,int top,int right,int bottom)

以上 4 个方法定义一个矩形的剪切区


public boolean clipPath(Path path)

以上方法定义一个 Path 剪切区,用于定义更加复杂的区域。


MainActivity:

public class ClipView extends View {
    public ClipView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        Bitmap bmpDog = BitmapFactory.decodeResource(getResources(), R.mipmap.tiger);
        //绘制老虎完整照片
        canvas.drawBitmap(bmpDog, 0, 0, null);
        //平移坐标
        canvas.translate(0, 300);//先把整个画布向下移动300个单位
        //定义剪切区
        canvas.clipRect(new Rect(0, 0, 200, 200));//调用clipRect()方法后,只会显示被裁剪的区域,之外的区域将不会显示
        //再次绘制老虎照片
        canvas.drawBitmap(bmpDog, 0, 0, null);//把裁剪后的图像画出来
    }
}

结果:


注意:最后运行结果第一张和第二张之间有300个单位

猜你喜欢

转载自blog.csdn.net/qq_32113133/article/details/66970882