IT资讯

Android-超简单实现图片圆角

作者:admin 2021-09-26 我要评论

最近被图片圆角给折腾了,话说网上的很多方法图片圆角正正常常的。但放到我这后,圆角就有点尖了,点都不圆滑。 我用的是Glide获取的图片,这个Glide也有BitmapT...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

最近被图片圆角给折腾了,话说网上的很多方法图片圆角正正常常的。但放到我这后,圆角就有点尖了,点都不圆滑。 我用的是Glide获取的图片,这个Glide也有BitmapTransformation能拓展实现圆角,但表示我展示出来效果很不好。 最终我总结下来是因为Glide对图片像素压缩,分辨率降低,导致圆角效果差。 网上没找到办法,因此自己想办法。废话不多说,来看实现。

此方法只适合分辨率小的图片,分辨率太高了角度反而不圆

1.自定义ImageView,重写ondraw方法
2.代码如下:

  1. /**  
  2.  * 切除圆角  
  3.  */ public class RoundCornersImageView extends ImageView { private float radiusX; private float radiusY; public RoundCornersImageView(Context context) { super(context); init(); } public RoundCornersImageView(Context context, AttributeSet attrs) { super(context, attrs); init(); } public RoundCornersImageView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); init(); } /**  
  4.      *  
  5.      * @param rx x方向弧度  
  6.      * @param ry y方向弧度  
  7.      */ public void setRadius(float rx, float ry) { this.radiusX = rxthis.radiusY = ry; } private void init() { radiusX = 58radiusY = 58; } @Override protected void onDraw(Canvas canvas) { Path path = new Path(); Rect rect = new Rect(0, 0, getWidth(), getHeight()); RectF rectF = new RectF(rect); path.addRoundRect(rectF, radiusX, radiusY, Path.Direction.CCW); canvas.clipPath(path, Region.Op.REPLACE);//Op.REPLACE这个范围内的都将显示,超出的部分覆盖 super.onDraw(canvas); } } 

3.ok就那么点,思路就是取圆角矩形显示范围内的图形


本文转载自网络,原文链接:http://www.jianshu.com/p/0d303d703750

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • Android-超简单实现图片圆角

    Android-超简单实现图片圆角

  • iOS:聊聊Designated Initializer(指定

    iOS:聊聊Designated Initializer(指定

  • 微软全息眼镜Hololens开发者版发货 售1

    微软全息眼镜Hololens开发者版发货 售1

  • 刘明浩解析京东金融宙斯Zeus安全防御平

    刘明浩解析京东金融宙斯Zeus安全防御平

腾讯云代理商
海外云服务器