[关闭]
@946898963 2019-10-04T16:38:28.000000Z 字数 3072 阅读 2101

Android中的圆形和圆角矩形的效果的实现

Android学习笔记 Android绘图


在实际开发中我们经常会对图片进行圆角和圆形处理,这里做一个总结。

图片的圆角和圆形显示,从实现方法上讲分为两种做法:

  1. 在图片上做
  2. 在控件上做

圆角和圆形的处理方式可以统一成一种,当圆角大小等于图片宽的一半时候,就变成了圆形。

在控件上做

图层叠加

图层叠加原理很简单,就是在一张图片上面叠加一层图,覆盖部分,让图片展示成圆角。

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout
  3. xmlns:android="http://schemas.android.com/apk/res/android"
  4. android:layout_width="match_parent"
  5. android:layout_height="match_parent"
  6. android:paddingBottom="@dimen/activity_vertical_margin"
  7. android:paddingLeft="@dimen/activity_horizontal_margin"
  8. android:paddingRight="@dimen/activity_horizontal_margin"
  9. android:paddingTop="@dimen/activity_vertical_margin">
  10. <FrameLayout
  11. android:layout_width="100dp"
  12. android:layout_height="100dp"
  13. android:background="@drawable/demo_icon_android_logo">
  14. <ImageView
  15. android:layout_width="match_parent"
  16. android:layout_height="match_parent"
  17. android:src="@drawable/demo_icon_shader"/>
  18. </FrameLayout>
  19. </RelativeLayout>

效果图:
此处输入图片的描述

缺点:

  1. 要准备两张图片,会增加额外的包体积;
  2. 图片叠加一起,必然导致过度绘制;
  3. 该方法太死板,使用时候要考虑图片大小,控件大小,以及蒙层图圆角锯齿效果,非常不灵。

所以这种方法不建议使用,了解即可。

系统控件

通过CardView和ViewOutlineProvider来圆角圆形需求,而且这两种方式主要是针对控件。

CardView是Android 5.0引入的卡片显示控件,可以实现阴影和圆角。

ViewOutlineProvider是Android 5.x引入的新特性,用于实现View的阴影和轮廓。

ViewOutlineProvider

ViewOutlineProvider实现圆角

  1. roundImage.setOutlineProvider(new ViewOutlineProvider() {
  2. @Override
  3. public void getOutline(View view, Outline outline) {
  4. outline.setRoundRect(0, 0, view.getWidth(), view.getHeight(), 30);
  5. }
  6. });
  7. roundImage.setClipToOutline(true);

ViewOutlineProvider实现圆形

  1. circleImage.setOutlineProvider(new ViewOutlineProvider() {
  2. @Override
  3. public void getOutline(View view, Outline outline) {
  4. outline.setOval(0, 0, view.getWidth(), view.getHeight());
  5. }
  6. });
  7. circleImage.setClipToOutline(true);

setClipToOutline方法可以在前设置也可以在为设置,如果设置为false则表示禁止裁剪,setOutlineProvider方法将无效。

CardView

CardViews实现圆形

  1. <android.support.v7.widget.CardView
  2. android:layout_width="100dp"
  3. android:layout_height="100dp"
  4. android:layout_gravity="center"
  5. android:layout_marginTop="10dp"
  6. app:cardCornerRadius="50dp">
  7. <ImageView
  8. android:layout_width="100dp"
  9. android:layout_height="100dp"
  10. android:scaleType="centerCrop"
  11. android:src="@drawable/girl" />
  12. </android.support.v7.widget.CardView>

CardViews实现圆角矩形

  1. <android.support.v7.widget.CardView
  2. android:layout_width="100dp"
  3. android:layout_height="100dp"
  4. android:layout_gravity="center"
  5. android:layout_marginTop="10dp"
  6. app:cardCornerRadius="10dp">
  7. <ImageView
  8. android:layout_width="100dp"
  9. android:layout_height="100dp"
  10. android:scaleType="centerCrop"
  11. android:src="@drawable/girl" />
  12. </android.support.v7.widget.CardView>

上面两种方式主要是设置CardView的cardCornerRadius属性,如果要展示指定的圆角,把这个值设置成你想要的圆角值就行,如果展示为圆形,首先要设置CardView长宽等值,而且cardCornerRadius为长宽的一半。

注意:

  1. 如果我们的应用设置了android:hardwareAccelerated="false",CardView和ViewOutlineProvider两种方式都将无效。
  2. CardView和ViewOutlineProvider两种方式只适合在Android 5.0及其以上的系统中,对于Android 5.0以下是不可以的,所以如果我们的应用需要运行在Android 5.0以下的系统上,我们需要做兼容工作。

下面我们介绍的两种方式实现的效果在各个版本的Android系统上都是相同的,不需要我们做兼容处理。

Xfermode方式

自定义圆形的ImageView&&自定义圆角矩形的ImageView

BitmapShader方式

自定义圆形的ImageView&&自定义圆角矩形的ImageView

画布裁剪方式

自定义圆形的ImageView&&自定义圆角矩形的ImageView

在图片上做

Xfermode方式

图片的圆形效果&&图片的圆角矩形效果

BitmapShader方式

图片的圆形效果&&图片的圆角矩形效果

画布裁剪方式

图片的圆形效果&&图片的圆角矩形效果

Demo链接:ImageViews

参考链接:

你不知道的圆形圆角处理方式

Android - 实现图片圆角显示的几种方式

Android绘制圆形图片的方法总结

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注