圆角图片RoundCornerImageView

 
package com.sclgxt.customimageview;

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;

/**
 * Created by Sclgxt on 2016/5/5.
 * Mind:圆角图片,如果不是wrapcontent,
 * 请注意加上这句话android:scaleType="centerCrop",防止图片撑不起来而留有空
 * 请注意setRoundCorner.
 */

public class RoundCornerImageView extends ImageView {    

private Paint roundPaint;    

private Paint maskPaint;    

private int size = 0;    

public RoundCornerImageView(Context context) {        

this(context, null);    

}    

public RoundCornerImageView(Context context, AttributeSet attrs, int defStyleAttr) {       

 super(context, attrs, defStyleAttr);   

 }    

public RoundCornerImageView(Context context, AttributeSet attrs) {       

 this(context, attrs, 0);       

 init();    

}    

private void init() {        

roundPaint = new Paint();        

roundPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_OVER));        

roundPaint.setAntiAlias(true);        

roundPaint.setColor(Color.WHITE);        

maskPaint = new Paint();        

maskPaint.setAntiAlias(true);       

maskPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));    

}   

 @Override    

protected void onDraw(Canvas canvas) {        

canvas.saveLayer(0, 0, getWidth(), getHeight(), 

roundPaint, Canvas.ALL_SAVE_FLAG);        

canvas.drawRoundRect(new RectF(0, 0, getWidth(), getHeight()), size, size, roundPaint);        

canvas.saveLayer(0, 0, getWidth(), getHeight(), maskPaint, Canvas.ALL_SAVE_FLAG);        

super.onDraw(canvas);    

}    

//设置圆角大小.这是一种写法,当然也可以自定义属性咯    

public void setRoundCorner(int size) {        

this.size = size;    

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值