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

所属分类: 软件编程 / Android 阅读数: 32
收藏 0 赞 0 分享

本文实例为大家分享了Android Studio实现带边框的圆形头像的具体代码,供大家参考,具体内容如下

效果显示:

(没有边框的)

(有边框的)

1、创建自定义ImagView控件

(1)、没有边框的

package chenglong.activitytest.pengintohospital.utils;

import android.content.Context;
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.Rect;
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;

/**
 *
 * 圆形图片
 * Created by LICHENGLONG on 2017-10-09.
 */

public class mine_ImageViewPlus extends ImageView{
 private Paint mPaintBitmap = new Paint(Paint.ANTI_ALIAS_FLAG);
 private Paint mPaintBorder = new Paint(Paint.ANTI_ALIAS_FLAG);
 private Bitmap mRawBitmap;
 private BitmapShader mShader;
 private Matrix mMatrix = new Matrix();
 private float mBorderWidth = dip2px(15);
 private int mBorderColor = 0x80bebebe;

 public mine_ImageViewPlus(Context context, AttributeSet attrs) {
 super(context, attrs);
 }

 @Override
 protected void onDraw(Canvas canvas) {
 Bitmap rawBitmap = getBitmap(getDrawable());
 if (rawBitmap != null){
 int viewWidth = getWidth();
 int viewHeight = getHeight();
 int viewMinSize = Math.min(viewWidth, viewHeight);
 float dstWidth = viewMinSize;
 float dstHeight = viewMinSize;
 if (mShader == null || !rawBitmap.equals(mRawBitmap)){
 mRawBitmap = rawBitmap;
 mShader = new BitmapShader(mRawBitmap, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP);
 }
 if (mShader != null){
 mMatrix.setScale((dstWidth - mBorderWidth * 2) / rawBitmap.getWidth(), (dstHeight - mBorderWidth * 2) / rawBitmap.getHeight());
 mShader.setLocalMatrix(mMatrix);
 }
 mPaintBitmap.setShader(mShader);
 mPaintBorder.setStyle(Paint.Style.STROKE);
 mPaintBorder.setStrokeWidth(mBorderWidth);
 mPaintBorder.setColor(mBorderColor);
 float radius = viewMinSize / 2.0f;
 canvas.drawCircle(radius, radius, radius - mBorderWidth / 2.0f, mPaintBorder);
 canvas.translate(mBorderWidth, mBorderWidth);
 canvas.drawCircle(radius - mBorderWidth, radius - mBorderWidth, radius - mBorderWidth, mPaintBitmap);
 } else {
 super.onDraw(canvas);
 }
 }

 private Bitmap getBitmap(Drawable drawable){
 if (drawable instanceof BitmapDrawable){
 return ((BitmapDrawable)drawable).getBitmap();
 } else if (drawable instanceof ColorDrawable){
 Rect rect = drawable.getBounds();
 int width = rect.right - rect.left;
 int height = rect.bottom - rect.top;
 int color = ((ColorDrawable)drawable).getColor();
 Bitmap bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
 Canvas canvas = new Canvas(bitmap);
 canvas.drawARGB(Color.alpha(color), Color.red(color), Color.green(color), Color.blue(color));
 return bitmap;
 } else {
 return null;
 }
 }

 private int dip2px(int dipVal) {
 float scale = getResources().getDisplayMetrics().density;
 return (int)(dipVal * scale + 0.5f);
 }
}

(2)、有边框的

package chenglong.activitytest.pengintohospital.utils;

import android.content.Context;
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.Rect;
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;

/**
 *
 * 带边框的圆形图片
 * Created by LICHENGLONG on 2017-10-09.
 */

public class ImageViewPlus extends ImageView{
 private Paint mPaintBitmap = new Paint(Paint.ANTI_ALIAS_FLAG);
 private Paint mPaintBorder = new Paint(Paint.ANTI_ALIAS_FLAG);//
 private Bitmap mRawBitmap;
 private BitmapShader mShader;
 private Matrix mMatrix = new Matrix();
 private float mBorderWidth = dip2px(15);
 private int mBorderColor = 0xFF0080FF;//外边框的颜色

 public ImageViewPlus(Context context, AttributeSet attrs) {
 super(context, attrs);
 }

 @Override
 protected void onDraw(Canvas canvas) {
 Bitmap rawBitmap = getBitmap(getDrawable());
 if (rawBitmap != null){
 int viewWidth = getWidth();
 int viewHeight = getHeight();
 int viewMinSize = Math.min(viewWidth, viewHeight);
 float dstWidth = viewMinSize;
 float dstHeight = viewMinSize;
 if (mShader == null || !rawBitmap.equals(mRawBitmap)){
 mRawBitmap = rawBitmap;
 mShader = new BitmapShader(mRawBitmap, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP);
 }
 if (mShader != null){
 mMatrix.setScale((dstWidth - mBorderWidth * 2) / rawBitmap.getWidth(), (dstHeight - mBorderWidth * 2) / rawBitmap.getHeight());
 mShader.setLocalMatrix(mMatrix);
 }
 mPaintBitmap.setShader(mShader);
 mPaintBorder.setStyle(Paint.Style.STROKE);
 mPaintBorder.setStrokeWidth(mBorderWidth / 5.0f);//外边框的大小
 mPaintBorder.setColor(mBorderColor);//添加外边框
 float radius = viewMinSize / 2.0f;
 canvas.drawCircle(radius, radius, radius - mBorderWidth / 6.0f, mPaintBorder);
 canvas.translate(mBorderWidth, mBorderWidth);
 canvas.drawCircle(radius - mBorderWidth, radius - mBorderWidth, radius, mPaintBitmap);
 } else {
 super.onDraw(canvas);
 }
 }

 private Bitmap getBitmap(Drawable drawable){
 if (drawable instanceof BitmapDrawable){
 return ((BitmapDrawable)drawable).getBitmap();
 } else if (drawable instanceof ColorDrawable){
 Rect rect = drawable.getBounds();
 int width = rect.right - rect.left;
 int height = rect.bottom - rect.top;
 int color = ((ColorDrawable)drawable).getColor();
 Bitmap bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
 Canvas canvas = new Canvas(bitmap);
 canvas.drawARGB(Color.alpha(color), Color.red(color), Color.green(color), Color.blue(color));
 return bitmap;
 } else {
 return null;
 }
 }

 private int dip2px(int dipVal) {
 float scale = getResources().getDisplayMetrics().density;
 return (int)(dipVal * scale + 0.5f);
 }
}

2、创建页面xml代码

<chenglong.activitytest.pengintohospital.utils.ImageViewPlus
 android:id="@+id/mine_iv_headportrait"
 android:layout_width="150dp"
 android:layout_height="150dp"
 android:src="@mipmap/hospital" />

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

更多精彩内容其他人还在看

Android异常 java.lang.IllegalStateException解决方法

这篇文章主要介绍了Android异常 java.lang.IllegalStateException解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android中Split()字符串分割特殊用法案例详解

本文通过案例的形式给大家详细介绍了android中split()字符串分割特殊用法的知识,非常不错具有参考借鉴价值,感兴趣的朋友参考下
收藏 0 赞 0 分享

Android仿新浪微博启动界面或登陆界面(1)

这篇文章主要为大家详细介绍了Android仿新浪微博启动界面或登陆界面的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android仿新浪微博oauth2.0授权界面实现代码(2)

这篇文章主要为大家详细介绍了Android仿新浪微博oauth2.0授权界面实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android开发中使用sqlite实现新闻收藏和取消收藏的功能

本篇文章主要介绍了sqlite实现新闻收藏和取消收藏功能,主要涉及到oracle数据库方面的内容,对于Android开发sqlite实现收藏和取消功能感兴趣的朋友可以参考下本文
收藏 0 赞 0 分享

Android仿新浪微博分页管理界面(3)

这篇文章主要为大家详细介绍了Android仿新浪微博分页管理界面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android UI自定义ListView实现下拉刷新和加载更多效果

这篇文章主要介绍了Android UI自定义ListView实现下拉刷新和加载更多效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android—基于微信开放平台v3SDK开发(微信支付填坑)

这篇文章主要介绍了Android—基于微信开放平台v3SDK开发(微信支付填坑),具有一定的参考价值,有需要的可以了解一下。
收藏 0 赞 0 分享

Android仿新浪微博自定义ListView下拉刷新(4)

这篇文章主要为大家详细介绍了Android仿新浪微博自定义ListView下拉刷新,重点介绍了Adapter的详细代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android控件之使用ListView实现时间轴效果

这篇文章主要介绍了Android基础控件之使用ListView实现时间轴效果的相关资料,本文是以查看物流信息为例,给大家介绍了listview时间轴的实现代码,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多