我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android利用CircleImageView实现圆形头像的方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android利用CircleImageView实现圆形头像的方法

CircleImageView实现圆形头像代码分享,供大家参考,具体内容如下

一、创建属性文件(attrs.xml)

具体操作:
1、在项目的values文件底下创建一新的属性文件,文件名为attrs:New->XML->Values XML File:

 2、补充attrs.xml代码:


<?xml version="1.0" encoding="utf-8"?>
<resources>
 <declare-styleable name="CircleImageView">
 <attr name="border_width" format="dimension" />
 <attr name="border_color" format="color" />
 </declare-styleable>
</resources>

二、添加实现类(CircleImageView.java)

CircleImageView.java(可以直接引用,看不懂也没事):


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.Matrix;
import android.graphics.Paint;
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.util.AttributeSet;
import android.widget.ImageView;
public class CircleImageView extends ImageView {
 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 = 1;
 private static final int DEFAULT_BORDER_WIDTH = 0;
 private static final int DEFAULT_BORDER_COLOR = Color.BLACK;
 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 int mBorderColor = DEFAULT_BORDER_COLOR;
 private int mBorderWidth = DEFAULT_BORDER_WIDTH;
 private Bitmap mBitmap;
 private BitmapShader mBitmapShader;
 private int mBitmapWidth;
 private int mBitmapHeight;
 private float mDrawableRadius;
 private float mBorderRadius;
 private boolean mReady;
 private boolean mSetupPending;
 public CircleImageView(Context context) {
 super(context);
 }
 public CircleImageView(Context context, AttributeSet attrs) {
 this(context, attrs, 0);
 }
 public CircleImageView(Context context, AttributeSet attrs, int defStyle) {
 super(context, attrs, defStyle);
 super.setScaleType(SCALE_TYPE);
 TypedArray a = context.obtainStyledAttributes(attrs,
  R.styleable.CircleImageView, defStyle, 0);
 mBorderWidth = a.getDimensionPixelSize(
  R.styleable.CircleImageView_border_width, DEFAULT_BORDER_WIDTH);
 mBorderColor = a.getColor(R.styleable.CircleImageView_border_color,
  DEFAULT_BORDER_COLOR);
 a.recycle();
 mReady = true;
 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
 protected void onDraw(Canvas canvas) {
 if (getDrawable() == null) {
  return;
 }
 canvas.drawCircle(getWidth() / 2, getHeight() / 2, mDrawableRadius,
  mBitmapPaint);
 if (mBorderWidth != 0) {
  canvas.drawCircle(getWidth() / 2, getHeight() / 2, mBorderRadius,
  mBorderPaint);
 }
 }
 @Override
 protected void onSizeChanged(int w, int h, int oldw, int oldh) {
 super.onSizeChanged(w, h, oldw, oldh);
 setup();
 }
 public int getBorderColor() {
 return mBorderColor;
 }
 public void setBorderColor(int borderColor) {
 if (borderColor == mBorderColor) {
  return;
 }
 mBorderColor = borderColor;
 mBorderPaint.setColor(mBorderColor);
 invalidate();
 }
 public int getBorderWidth() {
 return mBorderWidth;
 }
 public void setBorderWidth(int borderWidth) {
 if (borderWidth == mBorderWidth) {
  return;
 }
 mBorderWidth = borderWidth;
 setup();
 }
 @Override
 public void setImageBitmap(Bitmap bm) {
 super.setImageBitmap(bm);
 mBitmap = bm;
 setup();
 }
 @Override
 public void setImageDrawable(Drawable drawable) {
 super.setImageDrawable(drawable);
 mBitmap = getBitmapFromDrawable(drawable);
 setup();
 }
 @Override
 public void setImageResource(int resId) {
 super.setImageResource(resId);
 mBitmap = getBitmapFromDrawable(getDrawable());
 setup();
 }
 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 (OutOfMemoryError e) {
  return null;
 }
 }
 private void setup() {
 if (!mReady) {
  mSetupPending = true;
  return;
 }
 if (mBitmap == null) {
  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);
 mBitmapHeight = mBitmap.getHeight();
 mBitmapWidth = mBitmap.getWidth();
 mBorderRect.set(0, 0, getWidth(), getHeight());
 mBorderRadius = Math.min((mBorderRect.height() - mBorderWidth) / 2,
  (mBorderRect.width() - mBorderWidth) / 2);
 mDrawableRect.set(mBorderWidth, mBorderWidth, mBorderRect.width()
  - mBorderWidth, mBorderRect.height() - mBorderWidth);
 mDrawableRadius = Math.min(mDrawableRect.height() / 2,
  mDrawableRect.width() / 2);
 updateShaderMatrix();
 invalidate();
 }
 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) + mBorderWidth,
  (int) (dy + 0.5f) + mBorderWidth);
 mBitmapShader.setLocalMatrix(mShaderMatrix);
 }
}

三、CircleImageView的使用

具体操作:

1、先把你想要的图片拷贝到项目的res->drawable底下:

2、直接在布局文件引用: 


 <com.example.suqh.drop.CircleImageView
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:class="lazy" data-src="@drawable/img3" />

3、编译程序:

引用新建的类会出现下面这种情况的问题,直接点击build去编译程序:

 4、还是不行的话重新编译程序:

5、效果图:

您可能感兴趣的文章:Android一行代码实现圆形头像Android仿QQ圆形头像个性名片Android 自定义圆形头像CircleImageView支持加载网络图片的实现代码Android自定义控件仿QQ编辑和选取圆形头像利用Android中BitmapShader制作自带边框的圆形头像Android使用CircleImageView实现圆形头像的方法Android中使用CircleImageView和Cardview制作圆形头像的方法Android应用中绘制圆形头像的方法解析Android实现本地上传图片并设置为圆形头像Android Studio实现带边框的圆形头像


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android利用CircleImageView实现圆形头像的方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android利用CircleImageView实现圆形头像的方法

CircleImageView实现圆形头像代码分享,供大家参考,具体内容如下 一、创建属性文件(attrs.xml)具体操作: 1、在项目的values文件底下创建一新的属性文件,文件名为attrs:New->XML->Values XML
2022-06-06

Android使用CircleImageView实现圆形头像的方法

有时我们在应用中会用到圆形头像,下面是利用CircleImageView实现圆形头像的演示,下面效果和代码,效果如图实现起来也比较简单,先在项目中建一个circleimageview包用来存放CircleImageView类,待会直接把Ci
2022-06-06

Android中使用CircleImageView和Cardview制作圆形头像的方法

圆形头像在我们的日常使用的app中很常见,因为圆形的头像比较美观. 使用圆形图片的方法可能有我们直接将图片裁剪成圆形再在app中使用,还有就是使用自定义View对我们设置的任何图片自动裁剪成圆形。 效果图:这里使用github上Circle
2022-06-06

Android 自定义圆形头像CircleImageView支持加载网络图片的实现代码

在Android开发中我们常常用到圆形的头像,如果每次加载之后再进行圆形裁剪特别麻烦。所以在这里写一个自定义圆形ImageView,直接去加载网络图片,这样的话就特别的方便。 先上效果图主要的方法 1.让自定义 CircleImageVie
2022-06-06

Android Studio实现带边框的圆形头像

本文实例为大家分享了Android Studio实现带边框的圆形头像的具体代码,供大家参考,具体内容如下效果显示: (没有边框的) (有边框的) 1、创建自定义ImagView控件 (1)、没有边框的package chenglong.a
2023-05-30

Android应用中绘制圆形头像的方法解析

要画这种圆形带阴影的头像,个人分解成三个图层 1,先画头像边缘的渐变RadialGradient gradient = new RadialGradient(j/2,k/2,j/2,new int[]{0xff5d5d5d,0xff5d5d
2022-06-06

利用Android中BitmapShader制作自带边框的圆形头像

效果如下:BitmapShader 的简单介绍 关于 Shader是什么,Shader的种类有哪几种以及如何使用不属于本文范畴,对这方面不是很了解的同学,建议先去学习一下 Shader 的基本使用。 BitmapShader主要的作用就是
2022-06-06

Android实现本地上传图片并设置为圆形头像

先从本地把图片上传到服务器,然后根据URL把头像处理成圆形头像。 因为上传图片用到bmob的平台,所以要到bmob(http://www.bmob.cn)申请密钥。 效果图:核心代码:代码如下: public class MainActiv
2022-06-06

Android实现圆角矩形和圆形ImageView的方式

Android中实现圆角矩形和圆形有很多种方式,其中最常见的方法有ImageLoader设置Option和自定义View。 1.ImageLoader加载图片public static DisplayImageOptions getRoun
2022-06-06

Android 实现切圆图作为头像使用实例

Android 切圆图 效果图如下:MyView 类public class MyView extends View {Bitmap bmp;Paint paint = new Paint();public MyView(Context c
2022-06-06

Android中实现圆形进度条的方法

本篇文章为大家展示了Android中实现圆形进度条的方法,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。主要思路是写一个继承ProgressBar的自定义View代码:package com.fun.
2023-05-31

android实现圆角矩形背景的方法

本文实例讲述了android实现圆角矩形背景的方法。分享给大家供大家参考。具体如下: 1. java代码如下:import android.graphics.Canvas; import android.graphics.Color; im
2022-06-06

Android实现动态圆环的图片头像控件

先看效果图:现在大部分的app上难免会使用到圆形头像,所以今天我给大家分享一个单独使用的,并且周围带有圆环动画的花哨圆形头像控件,本控件是在圆形头像控件基础上实现的,只是在其周围再画一些不同大小的圆而已,就可以实现如图的效果。圆形头像的基本
2022-06-06

Android实现圆形图片的两种方式

在项目中,我们经常会用到圆形图片,但是android本身又没有提供,那我只能我们自己来完成。 第一种方式,自定义CircleImageView:public class CircleImageView extends ImageView {
2022-06-06

如何实现pyqt5圆形label显示打开的摄像头功能

这篇文章主要介绍了如何实现pyqt5圆形label显示打开的摄像头功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。.在label显示打开的摄像头原理其实在label显示图片
2023-06-22

Android圆形头像拍照后“无法加载此图片”的问题解决方法(适配Android7.0)

Feature: 点击选择拍照或者打开相册,选取图片进行裁剪最后设置为圆形头像。Problem: 拍好照片,点击裁剪,弹Toast“无法加载此图片”。Solution: 在裁剪的class里加两行代码intent.addFlags(Inte
2023-05-30

Android自定义ViewGroup实现带箭头的圆角矩形菜单

本文和大家一起做一个带箭头的圆角矩形菜单,大概长下面这个样子: 要求顶上的箭头要对准菜单锚点,菜单项按压反色,菜单背景色和按压色可配置。 最简单的做法就是让UX给个三角形的图片往上一贴,但是转念一想这样是不是太low了点,而且不同分辨率也不
2022-06-06

Android 实现自定义圆形进度条的三种常用方法

这篇文章主要介绍了Android 实现自定义圆形进度条的三种常用方法的相关资料,需要的朋友可以参考下
2023-03-01

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录