zoukankan      html  css  js  c++  java
  • 设置ImageView圆角

    import android.content.Context;
    import android.graphics.Canvas;
    import android.graphics.Color;
    import android.graphics.Paint;
    import android.graphics.PorterDuff;
    import android.graphics.PorterDuffXfermode;
    import android.graphics.RectF;
    import android.util.AttributeSet;
    import android.widget.ImageView;
    
    public class RoundImageView extends ImageView {
        public RoundImageView(Context context, AttributeSet attrs) {
            super(context, attrs);
            init();
        }
    
        public RoundImageView(Context context) {
            super(context);
            init();
        }
    
        private final RectF roundRect = new RectF();
        private float rect_adius = 10;//控制圆角大小
        private final Paint maskPaint = new Paint();
        private final Paint zonePaint = new Paint();
    
        private void init() {
            maskPaint.setAntiAlias(true);
            maskPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
            //
            zonePaint.setAntiAlias(true);
            zonePaint.setColor(Color.WHITE);
            //
            float density = getResources().getDisplayMetrics().density;
            rect_adius = rect_adius * density;
        }
    
        public void setRectAdius(float adius) {
            rect_adius = adius;
            invalidate();
        }
    
        @Override
        protected void onLayout(boolean changed, int left, int top, int right,
                int bottom) {
            super.onLayout(changed, left, top, right, bottom);
            int w = getWidth();
            int h = getHeight();
            roundRect.set(0, 0, w, h);
        }
    
        @Override
        public void draw(Canvas canvas) {
            canvas.saveLayer(roundRect, zonePaint, Canvas.ALL_SAVE_FLAG);
            canvas.drawRoundRect(roundRect, rect_adius, rect_adius, zonePaint);
            //
            canvas.saveLayer(roundRect, maskPaint, Canvas.ALL_SAVE_FLAG);
            super.draw(canvas);
            canvas.restore();
        }
    
    }
  • 相关阅读:
    【个人博客设计】
    复杂多边形光栅化算法
    xmake 描述语法和作用域详解
    协程分析之context上下文切换
    tbox协程使用之切换与等待
    记boost协程切换bug发现和分析
    跨平台自动构建工具v1.0.2 发布
    xmake从入门到精通9:交叉编译详解
    xmake从入门到精通9:交叉编译详解
    跨平台c开发库tbox:内存库使用详解
  • 原文地址:https://www.cnblogs.com/yangcong/p/4086862.html
Copyright © 2011-2022 走看看