1.自定义CircleImageView,加载即可使用

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.net.Uri;
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 static final int CircleImageView_border_width = 0;public static final int CircleImageView_border_color = 1;public static final int[] CircleImageView = { 0x7f010000, 0x7f010001 };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, CircleImageView,defStyle, 0);mBorderWidth = a.getDimensionPixelSize(0, DEFAULT_BORDER_WIDTH);mBorderColor = a.getColor(CircleImageView_border_color,DEFAULT_BORDER_COLOR);a.recycle();init();}private void init() {super.setScaleType(SCALE_TYPE);mReady = true;if (mSetupPending) {setup();mSetupPending = false;}}@Overrideprotected 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);}}@Overrideprotected 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();}@Overridepublic void setImageBitmap(Bitmap bm) {super.setImageBitmap(bm);mBitmap = bm;setup();}@Overridepublic void setBackgroundResource(int resid) {super.setBackgroundResource(resid);mBitmap = getBitmapFromDrawable(getDrawable());setup();}@Overridepublic void setImageDrawable(Drawable drawable) {super.setImageDrawable(drawable);mBitmap = getBitmapFromDrawable(drawable);setup();}@Overridepublic void setImageResource(int resId) {super.setImageResource(resId);mBitmap = getBitmapFromDrawable(getDrawable());setup();}@Overridepublic void setImageURI(Uri uri) {super.setImageURI(uri);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);}
}

2.绘制现有图片

<span style="white-space:pre">   </span>private Bitmap cicleImage(int id) {// 加载现有图片Bitmap bitmap = BitmapFactory.decodeResource(getResources(), id);int width = bitmap.getWidth();int height = bitmap.getHeight();// 构造新图纸Bitmap output = Bitmap.createBitmap(width, height,Bitmap.Config.ARGB_8888);Canvas canvas = new Canvas(output);Paint paint = new Paint();paint.setAntiAlias(true); // 抗锯齿canvas.drawARGB(0, 0, 0, 0); // 将背景绘制成黑色// 画一个灰色的实心园paint.setColor(0xff424242);canvas.drawCircle(width / 2, height / 2, width / 2, paint);/* [Sa * Da, Sc * Da] */// 取两层绘制交集,显示上层,本例下层是刚绘制的实心园,上层是即将绘制// 的图片,两者的交集就是个园,显示上层,就把图片中的园形部分显示出来了paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));// 绘制现有图片Rect src = new Rect(0, 0, width, width);Rect dst = new Rect(0, 0, width, height);//Rect src: 是对图片进行裁截,若是空null则显示整个图片//Rect dst:是图片在Canvas画布中显示的区域,大于src则把src的裁截区放大, 小于src则把src的裁截区缩小。canvas.drawBitmap(bitmap, src, dst, paint);return output;}

android 绘制圆形图片相关推荐

  1. android绘制圆形图片、圆圈以及图片缩放

    这两天做开发,需要将图片资源做成圆形,并且要对图片进行缩放,研究了半天,终于整出来了,效果如下: 代码如下: package com.android.mywidget; import android. ...

  2. Android绘制圆形图片的方法

    1.使用Xfermode 相交模式 见:http://blog.csdn.net/zcn596785154/article/details/79180145 2.通过裁剪画布区域实现 Canvas类提 ...

  3. Android 自定义圆形图片 CircleImageView

    1.效果预览 1.1.布局中写自定义圆形图片的路径即可 1.2.然后看一看图片效果 1.3.原图是这样的 @mipmap/ic_launcher 2.使用过程 2.1.CircleImageView源 ...

  4. android xml 圆形图片,Android ImageView实现圆角,圆形图片

    UI设计中,为了有更好的效果,用户的头像很多以圆形方式显示,其实现的步骤 1 在res/values/attrs中添加 2 自定义View,CustomImageView.java package c ...

  5. UIImageView绘制圆形图片

    参考网上的资料,自实现了一个UIImageView绘制圆形图片功能. 先看效果: 代码如下: - (void)buttonAction:(id)sender { //方式1,见上图的方式1效果.通过i ...

  6. Android 绘制圆形进度条

    Android 绘制圆形进度条 最近项目上有一些需求,需要绘制圆形的进度条满足设计上和交互上的需求: 实现思路 在画布上直接绘制View,需要了解一下几点 1.需要画一个圆 2.圆圈上有不同进度的颜色 ...

  7. quartz2D 如何绘制圆形图片, 及圆环图片

    转载自:http://www.cnblogs.com/yuwei0911/p/5277886.html -(void)touchesBegan:(NSSet<UITouch *> *)to ...

  8. android绘制圆形、圆角、圆环图片

    android实际开发中,很多地方都会用到圆形的图片,比如说头像.某些需求里面还要求圆形头像外面有一圈透明的圆环. 本文讲述的就是如何构建圆形图片. 效果图:

  9. 《Android开发卷——设置圆形头像,Android截取圆形图片》

    在有一些程序开发中,有时候会用到圆形,截取一张图片的一部分圆形,作为头像或者其他. 本实例就是截图圆形,设置头像的.      首先讲解一些代码 <ImageView android:id=&q ...

最新文章

  1. 从零开始编译自己的Linux发行版 LFS简介
  2. gdb工作原理(二)
  3. 开发者成功使用机器学习的十大诀窍
  4. iReport中求和的问题
  5. DBUtils (30)
  6. TCP/IP(四):TCP 与 UDP 协议简介
  7. Java IO 节点流与处理流类型
  8. JavaFX UI控件教程(二十七)之File Chooser
  9. oracle 根据分隔符提取,oracle使用指定分隔符导出数据到文件
  10. Z-Stack Home Developer's Guide—4.Using the sample applications as base for new applications 中文翻译
  11. spark学习-61-源代码:ShutdownHookManager虚拟机关闭钩子管理器
  12. php model get set方法,创建数据库对象之__set方法
  13. 载winpcap4.1.1_搞不清电力电缆载流量?有这一份最新汇总就够了~
  14. java读取txt文件---,java读取TXT文件的方法
  15. 分享几个音乐下载神器,一键下载全网音乐
  16. [山东科技大学OJ]1653 Problem C: 藏头诗
  17. 模拟斗地主发牌功能的设计与实现
  18. UI(六) - 如何架构UI框架
  19. 电脑硬件:谈谈cpu后边数字及字母的意思
  20. 初秋最时髦好看的搭配,竟是风衣里面套裙子!

热门文章

  1. sql查看数据库查看表
  2. pyplot.scatter函数绘制散点图
  3. Vue中实现骨架屏的多种方式
  4. vue骨架屏实现方式(转载,作者:jrainlau)
  5. Xen中,使用XL还是XM?
  6. 100个让ChatGPT更听话的技巧之:提出更具体的问题
  7. 【C语言数组下标越界】数组下标越界引发的死循环
  8. MATLAB图像处理基础知识2 im2bw
  9. Farthest Point Sampling(最远点采样)
  10. flex换行并且中间间距相同