iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >Android利用CircleImageView实现圆形头像的方法
  • 851
分享到

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

方法Android 2022-06-06 07:06:30 851人浏览 泡泡鱼
摘要

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

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: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实现带边框的圆形头像


--结束END--

本文标题: Android利用CircleImageView实现圆形头像的方法

本文链接: https://www.lsjlt.com/news/23711.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • Android Studio实现带边框的圆形头像
    本文实例为大家分享了Android Studio实现带边框的圆形头像的具体代码,供大家参考,具体内容如下效果显示: (没有边框的)  (有边框的) 创建自定义ImagView控件 (1)、没有边框的package chenglon...
    99+
    2023-05-30
    android studio 圆形头像
  • Android实现用户圆形头像和模糊背景
    本文实例为大家分享了Android实现用户圆形头像和模糊背景的具体代码,供大家参考,具体内容如下 1、效果展示 2、在build.gradle(Module)中的dependenc...
    99+
    2024-04-02
  • Android图像处理之绘制圆形、三角形及扇形的头像
    前言相信大家在Android日常开发中,绘制圆形和绘制图片都是很容易的事情,但是绘制圆形图片就有点难倒人了。以前为了偷懒就直接去github上找一个开源项目,后来才发现绘制圆形图片其实也是很简单的事。绘制圆形图片也需要两个步骤:绘制圆形和绘...
    99+
    2023-05-31
    android 扇形 圆形头像
  • Android应用中如何将头像图片变圆形
    本篇文章为大家展示了Android应用中如何将头像图片变圆形,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。实现步骤1.自定义一个转换工具类package com.common.base.util;i...
    99+
    2023-05-31
    android roi
  • Android应用中在对头像进行圆形处理
    本篇文章给大家分享的是有关Android应用中在对头像进行圆形处理,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Glide实现圆形图像Glide.with(mContext) ...
    99+
    2023-05-31
    android roi
  • Android中实现圆形进度条的方法
    本篇文章为大家展示了Android中实现圆形进度条的方法,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。主要思路是写一个继承ProgressBar的自定义View代码:package com.fun....
    99+
    2023-05-31
    android roi %d
  • C# 获取指定QQ头像绘制圆形头像框GDI(Graphics)的方法
    效果图: 完全代码(下方有详细解读) private void textBox1_TextChanged(object sender, EventArgs e) ...
    99+
    2024-04-02
  • Cropper.js进阶之实现圆形头像裁剪功能示例
    目录引言准备工作页面结构添加样式编写JavaScript总结全部代码如下引言 在Web应用中,让用户上传并裁剪图片以创建个人头像是一项非常常见的需求。本文将介绍如何使用著名的图片裁剪...
    99+
    2023-05-19
    Cropper.js圆形头像裁剪 Cropper.js头像裁剪
  • Android圆形头像拍照后“无法加载此图片”的问题解决方法(适配Android7.0)
    Feature: 点击选择拍照或者打开相册,选取图片进行裁剪最后设置为圆形头像。Problem: 拍好照片,点击裁剪,弹Toast“无法加载此图片”。Solution: 在裁剪的class里加两行代码intent.addFlags(Inte...
    99+
    2023-05-30
    android 圆形 头像
  • 如何实现pyqt5圆形label显示打开的摄像头功能
    这篇文章主要介绍了如何实现pyqt5圆形label显示打开的摄像头功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。.在label显示打开的摄像头原理其实在label显示图片...
    99+
    2023-06-22
  • Android 实现自定义圆形进度条的三种常用方法
    目录一、通过帧动画实现二、通过自定义颜色实现第三种 使用有进度的UI图片:Android 自定义 进度条,一般有三种方式,最早一般使用UI给的图片使用帧动画,完成,后面两种,一种是使...
    99+
    2023-03-01
    Android 实现自定义圆形进度条 Android自定义view实现圆形进度条 Android圆形进度条的实现
  • 如何使用纯CSS实现圆形图像?
    小编给大家分享一下如何使用纯CSS实现圆形图像?,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!   SS可以实现网页中的很多效...
    99+
    2024-04-02
  • Android实现自定义圆形进度条的常用方法有哪些
    今天小编给大家分享一下Android实现自定义圆形进度条的常用方法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、通...
    99+
    2023-07-05
  • Android调用手机摄像头的方法
    本文实例为大家分享了Android调用手机摄像头的具体代码,供大家参考,具体内容如下 根据<第一行代码>进行改写: 布局文件,只有一个按钮,和一个Imageview,im...
    99+
    2024-04-02
  • Android编程实现摄像头临摹效果的方法
    本文实例讲述了Android编程实现摄像头临摹效果的方法。分享给大家供大家参考,具体如下:这篇文章结合本人的开发实例,介绍如何实现摄像头临摹效果,即将摄像头拍摄的画面作为临摹的物体投射到画纸上,用户可以在画纸上继续作画,效果如图1.主要可以...
    99+
    2023-05-30
    android 摄像头 roi
  • Android实现圆角图片的方法
    本文实例为大家分享了Android实现圆角图片的具体代码,供大家参考,具体内容如下 效果图 创建类CustomRoundAngleImageView public class ...
    99+
    2024-04-02
  • Android调用外置摄像头的方法
    本文实例为大家分享了Android调用外置摄像头的具体代码,供大家参考,具体内容如下 1、布局文件 <xml version="1.0" encoding="utf-8">...
    99+
    2024-04-02
  • C++利用Opencv实现多个圆形检测
    主要是利用霍夫圆检测、面积筛选等完成多个圆形检测,具体代码及结果如下。 第一部分是头文件(common.h): #pragma once #include<opencv2/op...
    99+
    2022-11-13
    C++ Opencv圆形检测 C++ 原型检测
  • 怎么用Android View实现圆形进度条
    本篇内容主要讲解“怎么用Android View实现圆形进度条”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用Android View实现圆形进度条”吧!主要涉及到下面几个方法://&nbs...
    99+
    2023-06-20
  • 怎么在Android中使用圆形控件实现画圆效果
    这篇文章给大家介绍怎么在Android中使用圆形控件实现画圆效果,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。package com.example.demo.util;import android...
    99+
    2023-06-15
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作