android自定义imageview实现圆角图片

本文实例为大家分享了android自定义imageview实现圆角图片的具体代码,供大家参考,具体内容如下

自定义图片的属性,对图片进行圆角切割

实现效果图:

(1)在activity_main.xml文件布局,非常简单

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:app="http://schemas.android.com/apk/res-auto"
 android:orientation="vertical"
 android:layout_width="match_parent"
 android:layout_height="match_parent">
 <com.example.administrator.testz.CircleImageView
  android:layout_width="160dp"
  android:layout_marginLeft="20dp"
  android:layout_marginTop="20dp"
  android:layout_height="160dp"
  android:layout_centerInParent="true"
  android:src="@mipmap/icon"
  app:civ_border_width="2dp"
  app:civ_border_color="@color/colorAccent" />
</LinearLayout>

2.1注意添加attrs文件,设置图片的属性,然后在java代码中引用属性,在xml文件使用相关属性

<?xml version="1.0" encoding="utf-8"?>
<resources>
 <declare-styleable name="CircleImageView">
  <attr name="civ_border_width" format="dimension" />
  <attr name="civ_border_color" format="color" />
  <attr name="civ_border_overlay" format="boolean" />
  <attr name="civ_fill_color" format="color" />
  <attr name="civ_circle_background_color" format="color" />
 </declare-styleable>
</resources>

(2)MainActivity直接导入上面的布局即可,无需其他操作,如果要写监听或者其他操作,需要特别处理,这里仅仅提供显示

(3)开源的工具类,图片圆角转换工具类

package com.example.administrator.testz;

  import android.content.Context;
  import android.content.res.TypedArray;
  import android.graphics.Bitmap;
  import android.graphics.BitmapShader;
  import android.graphics.Canvas;
  import android.graphics.Color;
  import android.graphics.ColorFilter;
  import android.graphics.Matrix;
  import android.graphics.Outline;
  import android.graphics.Paint;
  import android.graphics.Rect;
  import android.graphics.RectF;
  import android.graphics.Shader;
  import android.graphics.drawable.BitmapDrawable;
  import android.graphics.drawable.ColorDrawable;
  import android.graphics.drawable.Drawable;
  import android.net.Uri;
  import android.os.Build;
  import android.support.annotation.ColorInt;
  import android.support.annotation.ColorRes;
  import android.support.annotation.DrawableRes;
  import android.support.annotation.RequiresApi;
  import android.util.AttributeSet;
  import android.view.MotionEvent;
  import android.view.View;
  import android.view.ViewOutlineProvider;
  import android.widget.ImageView;

public class CircleImageView extends ImageView {
 //参考网址:https://github.com/hdodenhof/CircleImageView
 private static final ScaleType SCALE_TYPE = ScaleType.CENTER_CROP;

 private static final Bitmap.Config BITMAP_CONFIG = Bitmap.Config.ARGB_8888;
 private static final int COLORDRAWABLE_DIMENSION = 2;

 private static final int DEFAULT_BORDER_WIDTH = 0;
 private static final int DEFAULT_BORDER_COLOR = Color.BLACK;
 private static final int DEFAULT_CIRCLE_BACKGROUND_COLOR = Color.TRANSPARENT;
 private static final boolean DEFAULT_BORDER_OVERLAY = false;

 private final RectF mDrawableRect = new RectF();
 private final RectF mBorderRect = new RectF();

 private final Matrix mShaderMatrix = new Matrix();
 private final Paint mBitmapPaint = new Paint();
 private final Paint mBorderPaint = new Paint();
 private final Paint mCircleBackgroundPaint = new Paint();

 private int mBorderColor = DEFAULT_BORDER_COLOR;
 private int mBorderWidth = DEFAULT_BORDER_WIDTH;
 private int mCircleBackgroundColor = DEFAULT_CIRCLE_BACKGROUND_COLOR;

 private Bitmap mBitmap;
 private BitmapShader mBitmapShader;
 private int mBitmapWidth;
 private int mBitmapHeight;

 private float mDrawableRadius;
 private float mBorderRadius;

 private ColorFilter mColorFilter;

 private boolean mReady;
 private boolean mSetupPending;
 private boolean mBorderOverlay;
 private boolean mDisableCircularTransformation;

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

  init();
 }

 public CircleImageView(Context context, AttributeSet attrs) {
  this(context, attrs, 0);
 }

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

  TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.CircleImageView, defStyle, 0);

  mBorderWidth = a.getDimensionPixelSize(R.styleable.CircleImageView_civ_border_width, DEFAULT_BORDER_WIDTH);
  mBorderColor = a.getColor(R.styleable.CircleImageView_civ_border_color, DEFAULT_BORDER_COLOR);
  mBorderOverlay = a.getBoolean(R.styleable.CircleImageView_civ_border_overlay, DEFAULT_BORDER_OVERLAY);

  // Look for deprecated civ_fill_color if civ_circle_background_color is not set
  if (a.hasValue(R.styleable.CircleImageView_civ_circle_background_color)) {
   mCircleBackgroundColor = a.getColor(R.styleable.CircleImageView_civ_circle_background_color,
     DEFAULT_CIRCLE_BACKGROUND_COLOR);
  } else if (a.hasValue(R.styleable.CircleImageView_civ_fill_color)) {
   mCircleBackgroundColor = a.getColor(R.styleable.CircleImageView_civ_fill_color,
     DEFAULT_CIRCLE_BACKGROUND_COLOR);
  }

  a.recycle();

  init();
 }

 private void init() {
  super.setScaleType(SCALE_TYPE);
  mReady = true;

  if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
   setOutlineProvider(new OutlineProvider());
  }

  if (mSetupPending) {
   setup();
   mSetupPending = false;
  }
 }

 @Override
 public ScaleType getScaleType() {
  return SCALE_TYPE;
 }

 @Override
 public void setScaleType(ScaleType scaleType) {
  if (scaleType != SCALE_TYPE) {
   throw new IllegalArgumentException(String.format("ScaleType %s not supported.", scaleType));
  }
 }

 @Override
 public void setAdjustViewBounds(boolean adjustViewBounds) {
  if (adjustViewBounds) {
   throw new IllegalArgumentException("adjustViewBounds not supported.");
  }
 }

 @Override
 protected void onDraw(Canvas canvas) {
  if (mDisableCircularTransformation) {
   super.onDraw(canvas);
   return;
  }

  if (mBitmap == null) {
   return;
  }

  if (mCircleBackgroundColor != Color.TRANSPARENT) {
   canvas.drawCircle(mDrawableRect.centerX(), mDrawableRect.centerY(), mDrawableRadius, mCircleBackgroundPaint);
  }
  canvas.drawCircle(mDrawableRect.centerX(), mDrawableRect.centerY(), mDrawableRadius, mBitmapPaint);
  if (mBorderWidth > 0) {
   canvas.drawCircle(mBorderRect.centerX(), mBorderRect.centerY(), mBorderRadius, mBorderPaint);
  }
 }

 @Override
 protected void onSizeChanged(int w, int h, int oldw, int oldh) {
  super.onSizeChanged(w, h, oldw, oldh);
  setup();
 }

 @Override
 public void setPadding(int left, int top, int right, int bottom) {
  super.setPadding(left, top, right, bottom);
  setup();
 }

 @Override
 public void setPaddingRelative(int start, int top, int end, int bottom) {
  super.setPaddingRelative(start, top, end, bottom);
  setup();
 }

 public int getBorderColor() {
  return mBorderColor;
 }

 public void setBorderColor(@ColorInt int borderColor) {
  if (borderColor == mBorderColor) {
   return;
  }

  mBorderColor = borderColor;
  mBorderPaint.setColor(mBorderColor);
  invalidate();
 }

 /**
  * @deprecated Use {@link #setBorderColor(int)} instead
  */
 @Deprecated
 public void setBorderColorResource(@ColorRes int borderColorRes) {
  setBorderColor(getContext().getResources().getColor(borderColorRes));
 }

 public int getCircleBackgroundColor() {
  return mCircleBackgroundColor;
 }

 public void setCircleBackgroundColor(@ColorInt int circleBackgroundColor) {
  if (circleBackgroundColor == mCircleBackgroundColor) {
   return;
  }

  mCircleBackgroundColor = circleBackgroundColor;
  mCircleBackgroundPaint.setColor(circleBackgroundColor);
  invalidate();
 }

 public void setCircleBackgroundColorResource(@ColorRes int circleBackgroundRes) {
  setCircleBackgroundColor(getContext().getResources().getColor(circleBackgroundRes));
 }

 /**
  * Return the color drawn behind the circle-shaped drawable.
  *
  * @return The color drawn behind the drawable
  *
  * @deprecated Use {@link #getCircleBackgroundColor()} instead.
  */
 @Deprecated
 public int getFillColor() {
  return getCircleBackgroundColor();
 }

 /**
  * Set a color to be drawn behind the circle-shaped drawable. Note that
  * this has no effect if the drawable is opaque or no drawable is set.
  *
  * @param fillColor The color to be drawn behind the drawable
  *
  * @deprecated Use {@link #setCircleBackgroundColor(int)} instead.
  */
 @Deprecated
 public void setFillColor(@ColorInt int fillColor) {
  setCircleBackgroundColor(fillColor);
 }

 /**
  * Set a color to be drawn behind the circle-shaped drawable. Note that
  * this has no effect if the drawable is opaque or no drawable is set.
  *
  * @param fillColorRes The color resource to be resolved to a color and
  *      drawn behind the drawable
  *
  * @deprecated Use {@link #setCircleBackgroundColorResource(int)} instead.
  */
 @Deprecated
 public void setFillColorResource(@ColorRes int fillColorRes) {
  setCircleBackgroundColorResource(fillColorRes);
 }

 public int getBorderWidth() {
  return mBorderWidth;
 }

 public void setBorderWidth(int borderWidth) {
  if (borderWidth == mBorderWidth) {
   return;
  }

  mBorderWidth = borderWidth;
  setup();
 }

 public boolean isBorderOverlay() {
  return mBorderOverlay;
 }

 public void setBorderOverlay(boolean borderOverlay) {
  if (borderOverlay == mBorderOverlay) {
   return;
  }

  mBorderOverlay = borderOverlay;
  setup();
 }

 public boolean isDisableCircularTransformation() {
  return mDisableCircularTransformation;
 }

 public void setDisableCircularTransformation(boolean disableCircularTransformation) {
  if (mDisableCircularTransformation == disableCircularTransformation) {
   return;
  }

  mDisableCircularTransformation = disableCircularTransformation;
  initializeBitmap();
 }

 @Override
 public void setImageBitmap(Bitmap bm) {
  super.setImageBitmap(bm);
  initializeBitmap();
 }

 @Override
 public void setImageDrawable(Drawable drawable) {
  super.setImageDrawable(drawable);
  initializeBitmap();
 }

 @Override
 public void setImageResource(@DrawableRes int resId) {
  super.setImageResource(resId);
  initializeBitmap();
 }

 @Override
 public void setImageURI(Uri uri) {
  super.setImageURI(uri);
  initializeBitmap();
 }

 @Override
 public void setColorFilter(ColorFilter cf) {
  if (cf == mColorFilter) {
   return;
  }

  mColorFilter = cf;
  applyColorFilter();
  invalidate();
 }

 @Override
 public ColorFilter getColorFilter() {
  return mColorFilter;
 }

 private void applyColorFilter() {
  if (mBitmapPaint != null) {
   mBitmapPaint.setColorFilter(mColorFilter);
  }
 }

 private Bitmap getBitmapFromDrawable(Drawable drawable) {
  if (drawable == null) {
   return null;
  }

  if (drawable instanceof BitmapDrawable) {
   return ((BitmapDrawable) drawable).getBitmap();
  }

  try {
   Bitmap bitmap;

   if (drawable instanceof ColorDrawable) {
    bitmap = Bitmap.createBitmap(COLORDRAWABLE_DIMENSION, COLORDRAWABLE_DIMENSION, BITMAP_CONFIG);
   } else {
    bitmap = Bitmap.createBitmap(drawable.getIntrinsicWidth(), drawable.getIntrinsicHeight(), BITMAP_CONFIG);
   }

   Canvas canvas = new Canvas(bitmap);
   drawable.setBounds(0, 0, canvas.getWidth(), canvas.getHeight());
   drawable.draw(canvas);
   return bitmap;
  } catch (Exception e) {
   e.printStackTrace();
   return null;
  }
 }

 private void initializeBitmap() {
  if (mDisableCircularTransformation) {
   mBitmap = null;
  } else {
   mBitmap = getBitmapFromDrawable(getDrawable());
  }
  setup();
 }

 private void setup() {
  if (!mReady) {
   mSetupPending = true;
   return;
  }

  if (getWidth() == 0 && getHeight() == 0) {
   return;
  }

  if (mBitmap == null) {
   invalidate();
   return;
  }

  mBitmapShader = new BitmapShader(mBitmap, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP);

  mBitmapPaint.setAntiAlias(true);
  mBitmapPaint.setShader(mBitmapShader);

  mBorderPaint.setStyle(Paint.Style.STROKE);
  mBorderPaint.setAntiAlias(true);
  mBorderPaint.setColor(mBorderColor);
  mBorderPaint.setStrokeWidth(mBorderWidth);

  mCircleBackgroundPaint.setStyle(Paint.Style.FILL);
  mCircleBackgroundPaint.setAntiAlias(true);
  mCircleBackgroundPaint.setColor(mCircleBackgroundColor);

  mBitmapHeight = mBitmap.getHeight();
  mBitmapWidth = mBitmap.getWidth();

  mBorderRect.set(calculateBounds());
  mBorderRadius = Math.min((mBorderRect.height() - mBorderWidth) / 2.0f, (mBorderRect.width() - mBorderWidth) / 2.0f);

  mDrawableRect.set(mBorderRect);
  if (!mBorderOverlay && mBorderWidth > 0) {
   mDrawableRect.inset(mBorderWidth - 1.0f, mBorderWidth - 1.0f);
  }
  mDrawableRadius = Math.min(mDrawableRect.height() / 2.0f, mDrawableRect.width() / 2.0f);

  applyColorFilter();
  updateShaderMatrix();
  invalidate();
 }

 private RectF calculateBounds() {
  int availableWidth = getWidth() - getPaddingLeft() - getPaddingRight();
  int availableHeight = getHeight() - getPaddingTop() - getPaddingBottom();

  int sideLength = Math.min(availableWidth, availableHeight);

  float left = getPaddingLeft() + (availableWidth - sideLength) / 2f;
  float top = getPaddingTop() + (availableHeight - sideLength) / 2f;

  return new RectF(left, top, left + sideLength, top + sideLength);
 }

 private void updateShaderMatrix() {
  float scale;
  float dx = 0;
  float dy = 0;

  mShaderMatrix.set(null);

  if (mBitmapWidth * mDrawableRect.height() > mDrawableRect.width() * mBitmapHeight) {
   scale = mDrawableRect.height() / (float) mBitmapHeight;
   dx = (mDrawableRect.width() - mBitmapWidth * scale) * 0.5f;
  } else {
   scale = mDrawableRect.width() / (float) mBitmapWidth;
   dy = (mDrawableRect.height() - mBitmapHeight * scale) * 0.5f;
  }

  mShaderMatrix.setScale(scale, scale);
  mShaderMatrix.postTranslate((int) (dx + 0.5f) + mDrawableRect.left, (int) (dy + 0.5f) + mDrawableRect.top);

  mBitmapShader.setLocalMatrix(mShaderMatrix);
 }

 @Override
 public boolean onTouchEvent(MotionEvent event) {
  return inTouchableArea(event.getX(), event.getY()) && super.onTouchEvent(event);
 }

 private boolean inTouchableArea(float x, float y) {
  return Math.pow(x - mBorderRect.centerX(), 2) + Math.pow(y - mBorderRect.centerY(), 2) <= Math.pow(mBorderRadius, 2);
 }

 @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
 private class OutlineProvider extends ViewOutlineProvider {

  @Override
  public void getOutline(View view, Outline outline) {
   Rect bounds = new Rect();
   mBorderRect.roundOut(bounds);
   outline.setRoundRect(bounds, bounds.width() / 2.0f);
  }

 }

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • android 实现圆角图片解决方案

    现在我们就来看看怎么样把图片的四角都变成圆形的,为什么要这样做那,如果要是这样界面就会非常的美观,下面我们就来看看代码吧. java代码: 复制代码 代码如下: public static Bitmap toRoundCorner(Bitmap bitmap, int pixels) { Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(), Config.ARGB_8888); Canvas canv

  • Android中实现圆角图片的几种方法

    Android中实现圆角图片有多种姿势,不知你解锁了几种? 方法一:setXfermode法 此种方式就是再new一个相同尺寸的bitmap,然后使用paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));先画圆角矩形,再画原始bitmap,然后就得到了一个圆角的bitmap了. public static Bitmap getRoundedCornerBitmap(Bitmap bitmap, float roundPx) { Bitmap

  • Android关于Glide的使用(高斯模糊、加载监听、圆角图片)

    高斯模糊.加载监听.圆角图片这些相信大家都很熟悉,那如何实现这些效果,请大家参考本文进行学习. 1.引用 compile 'com.github.bumptech.glide:glide:3.7.0' 2.加载图片 2.1 基本加载 Glide.with(context)     .load(url)     .into(imageView); 2.2 设置加载中和加载失败的情况 Glide.with(context) .load(url) .placeholder(R.drawable.loa

  • Android实现带描边的圆角图片

    利用学过的BitmapShader渲染类,我们来实现一个带描边的圆角图片. 具体实现: 用来显示自定义的绘图类的布局文件 res/layout/main.xml: <?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http:

  • android 设置圆角图片实现代码

    复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/layout" android:orientation="vertical" android:layout_wi

  • Android 实现圆角图片的简单实例

    Android 实现圆角图片的简单实例 实现效果图: 本来想在网上找个圆角的例子看一看,不尽人意啊,基本都是官方的Demo的那张原理图,稍后会贴出.于是自己自定义了个View,实现图片的圆角以及圆形效果.效果图: Android 圆角图片的实现形式,包括用第三方.也有系统的.比如makeramen:roundedimageview,系统的cardview , glide .fresco . compile 'com.android.support:appcompat-v7:24.0.0' com

  • Android实现圆形图片或者圆角图片

    Android圆形图片或者圆角图片的快速实现,具体内容如下 话不多说直接上code xml文件布局 <LinearLayout android:id="@+id/ll_headpict" android:layout_width="match_parent" android:layout_height="97dp" android:layout_margin="13dp" android:background="

  • Android如何设置圆角图片

    在开发过程中有时需要将图片显示成圆角图片,一般我们可以通过在xml中设置drawable shape即可,但今天我给出另一种方法,用java代码动态去设置圆角,顺便做个简单的笔记. 主要原理是使用系统自带api: RoundedBitmapDrawableFactory 先上效果图: 由于比较简单,直接给出实现方式: public class MainActivity extends AppCompatActivity { private ImageView mImgRectRound; pri

  • Android中Glide加载圆形图片和圆角图片实例代码

    一.简介: 介绍两种使用 BitmapTransformation 来实现 Glide 加载圆形图片和圆角图片的方法.Glide 并不能直接支持 Round Pictures ,需要使用 BitmapTransformation 来进行处理. 二.网上的实现方式 这里介绍下网上常见的方式和使用 RoundedBitmapDrawable 两种方法,本质上是差不多的: 使用 Canvas 和 Paint 来绘制 使用 Android.support.v4.graphics.drawable.Rou

  • android自定义imageview实现圆角图片

    本文实例为大家分享了android自定义imageview实现圆角图片的具体代码,供大家参考,具体内容如下 自定义图片的属性,对图片进行圆角切割 实现效果图: (1)在activity_main.xml文件布局,非常简单 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android

  • Android自定义ImageView实现圆角功能

    使用自定义ImageView,实现圆角功能,供大家参考,具体内容如下 1.自定义属性attrs.xml <?xml version="1.0" encoding="utf-8"?> <resources> <declare-styleable name="RoundCornerImageView"> <attr name="radius" format="dimension&

  • Android自定义ImageView实现在图片上添加图层效果

    首先我们先看下效果图 实现思路 这是两张前后对比图,右边第二张图里面的已抢光标签图片当已经没有商品的时候就会显示了,在每个图片的中心位置,第一想法是在ImageView的外层再套一层RelativeLayout 实现方法 <RelativeLayout android:layout_width="match_parent" android:layout_height="wrap_content"> <SelectableRoundedImageVi

  • Android 自定义imageview实现图片缩放实例详解

    Android 自定义imageview实现图片缩放实例详解 觉得这个自定义的imageview很好用 性能不错  所以拿出来分享给大家  因为不会做gif图  所以项目效果 就不好贴出来了  把代码贴出来 1.项目结构图 2.Compat.class package com.suo.image; import android.os.Build.VERSION; import android.os.Build.VERSION_CODES; import android.view.View; pu

  • Android 自定义 HorizontalScrollView 打造多图片OOM 的横向滑动效果(实例代码)

    自从Gallery被谷歌废弃以后,Google推荐使用ViewPager和HorizontalScrollView来实现Gallery的效果.的确HorizontalScrollView可以实现Gallery的效果,但是HorizontalScrollView存在一个很大的问题,如果你仅是用来展示少量的图片,应该是没问题的,但是如果我希望HorizontalScrollView可以想ViewPager一样,既可以绑定数据集(动态改变图片),还能做到,不管多少图片都不会OOM(ViewPager内

  • 浅谈Android获取ImageView上的图片,和一个有可能遇到的问题

    1.在获取图片前先调用setDrawingCacheEnabled(true)这个方法: 举例:mImageView.setDrawingCacheEnabled(true); 2.之后可以通过getDrawingCache()获取图片 举例:Bitmap obmp = Bitmap.createBitmap(mImageView.getDrawingCache());  //获取到Bitmap的图片 3.获取完图片后记得调用setDrawingCacheEnabled(false) 举例:mI

  • Android自定义TextView实现文字图片居中显示的方法

    最近有个需求是这样的,人民币的符号"¥"因为安卓手机系统的不一致导致符号不是完全一样,所以用美工的给的图片代替,考虑到用的地方比较多,所以想着写一个继承于线性布局的组合控件,后来一想,安卓中不是有TextView吗,这个自带图片的控件,后来写了个demo,因为我是用的MatchParent,导致问题出现,人民币符号不是和文字一样的居中,因此才有了这篇博文,让我们来自定义TextView吧,这个场景用的比较多. 分析下TextView的源码 我们先来分析下TextView的源码,因为Te

  • Android实现自定义ImageView的圆角矩形图片效果

    android中的ImageView只能显示矩形的图片,这样一来不能满足我们其他的需求,比如要显示圆角矩形的图片,这个时候,我们就需要自定义ImageView了,其原理就是首先获取到图片的Bitmap,然后进行裁剪对应的圆角矩形的bitmap,然后在onDraw()进行绘制圆角矩形图片输出. 效果图如下: 自定义的圆形的ImageView类的实现代码如下: package com.xc.xcskin.view; import android.content.Context; import and

  • Android使用自定义ImageView实现圆形图片效果

    android中的ImageView只能显示矩形的图片,这样一来不能满足我们其他的需求,比如要显示圆形的图片,这个时候,我们就需要自定义ImageView了,其原理就是首先获取到图片的Bitmap,然后进行裁剪圆形的bitmap,然后在onDraw()进行绘制圆形图片输出. 效果图如下: 自定义的圆形的ImageView类的实现代码如下: package com.xc.xcskin.view; import android.content.Context; import android.grap

  • android自定义控件ImageView实现圆形图片

    android开发中常常涉及到一种情况,就是将用户上传的图片以圆形样式显示,但是用户上传的图片可以有直角.圆角.正方形等多种不确定样式,这时就用到了自定义ImageView控件,在安卓客户端使接收到的图片全部以圆形样式显示 CircleImageView.java public class CircleImageView extends ImageView { private static final ScaleType SCALE_TYPE = ScaleType.CENTER_CROP; p

随机推荐