zoukankan      html  css  js  c++  java
  • Canvas: canvas.clipRect()方法的作用

    该方法用于裁剪画布,也就是设置画布的显示区域
    调用clipRect()方法后,只会显示被裁剪的区域,之外的区域将不会显示
    该方法最后有一个参数Region.Op,表示与之前区域的区域间运算种类,如果没有这个参数,则默认为Region.Op.INTERSECT
    这几个参数的意义为:

    • DIFFERENCE 是第一次不同于第二次的部分显示出来
    • REPLACE  是显示第二次的
    • REVERSE_DIFFERENCE 是第二次不同于第一次的部分显示
    • INTERSECT  交集显示
    • UNION 全部显示
    • XOR补集 就是全集的减去交集生育部分显示

    下面以一个例子说明:

    Layout:

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".CanvasSaveAndRestore">
    
      
        <com.yongdaimi.android.androidapitest.view.CanvasClipView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            />
    
    </LinearLayout>

    自定义View:

    package com.yongdaimi.android.androidapitest.view;
    
    import android.content.Context;
    import android.graphics.Canvas;
    import android.graphics.Color;
    import android.graphics.Paint;
    import android.graphics.Region;
    import android.util.AttributeSet;
    
    import androidx.annotation.Nullable;
    
    public class CanvasClipView extends android.view.View {
    
    
        public CanvasClipView(Context context) {
            this(context, null);
        }
    
        public CanvasClipView(Context context, @Nullable AttributeSet attrs) {
            this(context, attrs, 0);
        }
    
        public CanvasClipView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
            super(context, attrs, defStyleAttr);
            init();
        }
    
        private Paint mPaint;
    
        private void init() {
            mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
            mPaint.setColor(Color.BLACK);
        }
    
        @Override
        protected void onDraw(Canvas canvas) {
            super.onDraw(canvas);
    
            canvas.drawColor(Color.GRAY);
    
            canvas.drawRect(400, 400, 600, 600, mPaint);
    
            canvas.drawRect(400, 700, 600, 900, mPaint);
    
    
            canvas.clipRect(100, 100, 350, 600, Region.Op.INTERSECT);
            canvas.drawColor(Color.RED);
    
            canvas.drawCircle(100, 100, 100, mPaint);
    
        }
    
    }

    上面先将画布颜色设置成灰色,然后分别在(400, 400, 600, 600) 和 (400, 700, 600, 900)的位置绘制了两个矩形,紧接着对画布进行裁剪,裁剪区域为(100, 100, 350, 600), 裁剪完毕后重新设置画布颜色为红色,最后绘制了一个圆形,圆心坐标是(100, 100), 半径是100,最终效果如下:

    我们在布局文件里面设置的View的尺寸是铺满全屏,可以看到虽然对画布进行裁剪,但是之前绘制的形状依旧可以显示;画布裁剪完毕后,再去绘制圆,但圆心的坐标却仍然以最开始的坐标为准。

    下面对绘制的Code进行修改:

    package com.yongdaimi.android.androidapitest.view;
    
    import android.content.Context;
    import android.graphics.Canvas;
    import android.graphics.Color;
    import android.graphics.Paint;
    import android.graphics.Region;
    import android.util.AttributeSet;
    
    import androidx.annotation.Nullable;
    
    public class CanvasClipView extends android.view.View {
    
    
        public CanvasClipView(Context context) {
            this(context, null);
        }
    
        public CanvasClipView(Context context, @Nullable AttributeSet attrs) {
            this(context, attrs, 0);
        }
    
        public CanvasClipView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
            super(context, attrs, defStyleAttr);
            init();
        }
    
        private Paint mPaint;
    
        private void init() {
            mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
            mPaint.setColor(Color.BLACK);
        }
    
        @Override
        protected void onDraw(Canvas canvas) {
            super.onDraw(canvas);
    
            canvas.drawColor(Color.GRAY);
    
            canvas.drawRect(400, 400, 600, 600, mPaint);
    
            // 注释掉此段code
            // canvas.drawRect(400, 700, 600, 900, mPaint);
    
            canvas.clipRect(100, 100, 350, 600, Region.Op.INTERSECT);
            canvas.drawColor(Color.RED);
    
            canvas.drawCircle(100, 100, 100, mPaint);
    
            // 将绘制第二个矩形的code移动到此处
            canvas.drawRect(400, 700, 600, 900, mPaint);
        }
    
    }

    再次运行:

    发现最后绘制的那个矩形看不到了,说明调用clipRect()方法后,显示区域已经被修改成(100, 100, 350, 600)了,在这个区域其它位置绘制的形状就再也看不到了。

    综上:

    1. 调用clipRect()方法后,画布只会显示传入的矩形参数所在的区域,在此之后绘制的其它形状如果不在这个区域内,将不会显示。

    2. clipRect() 只会影响在调用此方法之后绘制的形状,先前绘制的形状不会受到影响。

    参考链接:

    https://blog.csdn.net/lovexieyuan520/article/details/50698320

  • 相关阅读:
    CS027th: 6papers
    MATH026th: 《矩斋筹算丛刻》
    MATH026th: 《古今算学丛书》目录
    Compiler25th005: Excel Compiler
    AIIE25th004: 2020aiie在合肥举办
    AIIE21th003: 2021年第二届国际工业工程和人工智能大会(IEAI 2021)
    ComPiler200004:Library-Oriented Programming
    ComPiler200003:Story-Oriented Programming
    ComPiler200002:Growing a Compiler
    conda
  • 原文地址:https://www.cnblogs.com/yongdaimi/p/13161840.html
Copyright © 2011-2022 走看看