Android Image 圆角图片与圆形图片 ImageView

项目开发中遇到联系头像需要设置成圆角或者圆形图片

技术实现,自定义继承自ImageView 的子类,Override Ondraw

private Path clipPath =new Path();

// 圆角图

protected void onDraw(Canvas canvas) {
    clipPath.addRoundRect(new RectF(0, 0, getWidth(), getHeight()), 10.0f, 10.0f, Path.Direction.CW);
    canvas.clipPath(clipPath);
    super.onDraw(canvas);
}

其中10.0f 为圆角半径

如果是一张正方形的图片设置其值为getWidth()/2 实现效果是可以实现一个圆形图片效果的



// 圆形图

protected void onDraw(Canvas canvas) {
    clipPath.addCircle(getWidth()/2,getHeight()/2,getWidth()/2,Path.Direction.CCW);
    //clipPath.addRoundRect(new RectF(0, 0, getWidth(), getHeight()), 10.0f, 10.0f, Path.Direction.CW);
    canvas.clipPath(clipPath);
    super.onDraw(canvas);
}

也就是说在正方形图的基础上:
clipPath.addCircle(getWidth()/2,getHeight()/2,getWidth()/2,Path.Direction.CCW);
clipPath.addRoundRect(new RectF(0, 0, getWidth(), getHeight()), getWidth()/2, getHeitght()/2, Path.Direction.CW);
达到的效果一致,都可以实现一个圆图,

但是这样实现的圆图是有毛边的,
要继续优化界面,办法是有的:Canvas 在上面圆图的基础上再画一个圆边

//是Paint.Style.STROKE 不是FILL 不然就覆盖成一块饼了

private final Paint mButtonPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
mButtonPaint.setStyle(Paint.Style.STROKE);
mButtonPaint.setColor(mColor);


// 圆形图

protected void onDraw(Canvas canvas) {
    clipPath.addCircle(getWidth()/2,getHeight()/2,getWidth()/2,Path.Direction.CCW);

    //clipPath.addRoundRect(new RectF(0, 0, getWidth(), getHeight()), 10.0f, 10.0f, Path.Direction.CW);
    canvas.clipPath(clipPath);
    super.onDraw(canvas);
    canvas.drawCircle(getWidth() / 2, getHeight() / 2, (float) (getWidth() / 2), mButtonPaint);

}

效果图:




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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值