自定义ImageView圆角

自定义ImageView为圆角的效果图:

代码实现:

 

public class BannerRadiusImageView extends android.support.v7.widget.AppCompatImageView {

    private float mRadus = getContext().getResources().getDimensionPixelSize(R.dimen.dp10);

    /*圆角的半径,依次为左上角xy半径,右上角,右下角,左下角*/
    private float[] rids = {mRadus, mRadus, mRadus, mRadus, mRadus, mRadus, mRadus, mRadus};

    public BannerRadiusImageView(Context context) {
        super(context);
    }

    public BannerRadiusImageView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public BannerRadiusImageView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }


    /**
     * 画图
     * @param canvas
     */
    protected void onDraw(Canvas canvas) {
        Path path = new Path();
        int w = this.getWidth();
        int h = this.getHeight();
        /*向路径中添加圆角矩形。radii数组定义圆角矩形的四个圆角的x,y半径。radii长度必须为8*/
        path.addRoundRect(new RectF(0,0,w,h),rids, Path.Direction.CW);
        canvas.clipPath(path);
        super.onDraw(canvas);
    }

    /**
     * 设置ImageView为正方形
     */
//    @Override
//    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
//        setMeasuredDimension(getDefaultSize(0, widthMeasureSpec), getDefaultSize(0, heightMeasureSpec));
//        int childWidthSize = getMeasuredWidth();
//        // 高度和宽度一样
//        heightMeasureSpec = widthMeasureSpec = MeasureSpec.makeMeasureSpec(childWidthSize, MeasureSpec.EXACTLY);
//        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
//    }
}

 

1、有想做副业,业余开店的,推荐“贝店”,

     应用市场下载“贝店”,注册,输入邀请码 1530973, 即可体验!

2、另外可以关注我的公众号“生活与认知”;

阅读更多
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/LXFX1108/article/details/80692716
文章标签: ImageView圆角
个人分类: Android升华
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭
关闭