简单的圆形头像

package com.bwie.test;


import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.PaintFlagsDrawFilter;
import android.graphics.Path;
import android.util.AttributeSet;
import android.widget.ImageView;
import android.graphics.Region;


public class CircleImageView extends ImageView{


private PaintFlagsDrawFilter mpaintFlagsDrawFilter;//毛边过滤
Paint paint;
Path path;




public CircleImageView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
init();
}


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


public CircleImageView(Context context) {
super(context);
init();
}

//Path类可以预先在View上将N个点连成一条"路径",然后调用Canvas的drawPath(path,paint)即可沿着路径绘制图形
private void init() {
mpaintFlagsDrawFilter = new PaintFlagsDrawFilter(0, Paint.ANTI_ALIAS_FLAG|Paint.FILTER_BITMAP_FLAG);
paint = new Paint();
paint.setAntiAlias(true);
paint.setFilterBitmap(true);
// paint.setColor(Color.RED);

}

@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
setMeasuredDimension(150, 150);
}

@Override
protected void onDraw(Canvas canvas) {
//View的高宽
float h = getMeasuredHeight()-3.0f;
float w = getMeasuredWidth()-3.0f;
if(path==null){
path = new Path();
path.addCircle(w/2.0f,h/2.0f, (float)Math.min(w/2.0f, h/2.0f), Path.Direction.CCW);
path.close();
}
// Math.min(w/2.0f, h/2.0f)+1.f
canvas.drawCircle(w/2.0f, h/2.0f,50, paint);
int saveCount = canvas.getSaveCount();
canvas.save();
canvas.setDrawFilter(mpaintFlagsDrawFilter);
canvas.clipPath(path,Region.Op.REPLACE);
canvas.setDrawFilter(mpaintFlagsDrawFilter);
canvas.drawColor(Color.WHITE);
super.onDraw(canvas);
canvas.restoreToCount(saveCount);
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值