Android图像处理之绘制圆形、三角形及扇形的头像

作者:Android杂货铺 时间:2022-10-13 14:01:48 

前言

相信大家在Android日常开发中,绘制圆形和绘制图片都是很容易的事情,但是绘制圆形图片就有点难倒人了。以前为了偷懒就直接去github上找一个开源项目,后来才发现绘制圆形图片其实也是很简单的事。

绘制圆形图片也需要两个步骤:

绘制圆形和绘制图片,只不过要让它们取并集,得到的结果就是一张圆形图片了。

直接上代码:


public class CircleImageView extends View {

private Paint mPaint;
private Paint mTargetPaint;
private Bitmap mSourceBitmap;
private Bitmap mTargetBitmap;
private Canvas mTargetCanvas;

private int mWidth;
private int mHeight;

public CircleImageView(Context context) {
 this(context, null);
}

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

public CircleImageView(Context context, AttributeSet attrs, int defStyleAttr) {
 super(context, attrs, defStyleAttr);
 init();
}

private void init() {
 mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
 mTargetPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
 mTargetPaint.setXfermode(new PorterDuffXfermode(SRC_IN));

mSourceBitmap = BitmapFactory.decodeResource(getResources(), R.drawable.xiaojiangshi);
 mTargetBitmap = Bitmap.createBitmap(mSourceBitmap.getWidth(), mSourceBitmap.getHeight(), Bitmap.Config.ARGB_8888);
 mTargetCanvas = new Canvas(mTargetBitmap);
}

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

@Override
protected void onDraw(Canvas canvas) {
 // 生成圆形Bitmap过程.
 int radius = Math.min(mWidth, mHeight) / 2;
 // 先绘制圆形
 mTargetCanvas.drawCircle(mWidth / 2, mHeight / 2, radius, mPaint);
 // 再绘制Bitmap
 mTargetCanvas.drawBitmap(mSourceBitmap, 0, 0, mTargetPaint);

canvas.drawBitmap(mTargetBitmap, 0, 0, null);
}
}

效果如下:

Android图像处理之绘制圆形、三角形及扇形的头像

代码中最关键的就是这句:


mTargetPaint.setXfermode(new PorterDuffXfermode(SRC_IN));

SRC_IN这种模式可以让两个绘制的效果取交集后展现出来,需要注意的是,dst需要先绘制,再绘制src,拿上面例子来说,就是要先绘制圆形,在绘制Bitmap,如果顺序颠倒了,你就只能看到一个圆形了。

除了SRC_IN这种模式外,还有其它15种模式。有兴趣的可以自己试试看效果。在官方提供的APIDemo中可以找到相应的代码。

Android图像处理之绘制圆形、三角形及扇形的头像

知道这个原理之后,我们就能绘制各种形状的图片了,只需要绘制不同的形状代替绘制圆形这一步骤就可以了。

三角形:


mPath.reset();
mPath.moveTo(mWidth / 2, 0);
mPath.lineTo(0, mHeight);
mPath.lineTo(mWidth, mHeight);
mPath.close();
mTargetCanvas.drawPath(mPath, mPaint);

Android图像处理之绘制圆形、三角形及扇形的头像

扇形:


RectF rectF = new RectF(0, 0, mWidth, mHeight);
mTargetCanvas.drawArc(rectF, 210, 120, true, mPaint);

Android图像处理之绘制圆形、三角形及扇形的头像

来源:http://www.jianshu.com/p/57025c3491c1

标签:android,扇形,圆形头像
0
投稿

猜你喜欢

  • .NET单点登陆的实现方法及思路

    2023-06-10 10:13:53
  • java struts2学习笔记之线程安全

    2022-08-07 00:13:07
  • Spring ComponentScan的扫描过程解析

    2023-01-04 08:49:58
  • Android自定义图片集合

    2022-06-24 11:34:52
  • C#中文件名或文件路径非法字符判断方法

    2023-12-01 14:14:21
  • Flutter实现手势识别功能详解方法

    2022-12-21 15:41:41
  • Android8.0适配前台定位服务service的示例代码

    2021-05-25 17:18:36
  • spring+hibernate 两种整合方式配置文件的方法

    2022-02-27 21:36:47
  • Java的反射机制---动态调用对象的简单方法

    2023-08-16 19:23:26
  • Android实现简单的文件下载与上传

    2022-02-25 00:00:14
  • flutter text组件使用示例详解

    2022-07-11 11:08:42
  • Android异常处理最佳实践

    2021-06-15 20:17:12
  • Android入门之实现手工发送一个BroadCast

    2023-08-10 13:54:16
  • 分享我的第一次java Selenium自动化测试框架开发过程

    2021-05-30 01:16:25
  • C#中var关键字用法分析

    2022-02-11 15:01:43
  • 探讨:android项目开发 统筹兼顾 需要考虑的因素

    2023-08-05 11:21:32
  • java servlet手机app访问接口(三)高德地图云存储及检索

    2022-08-14 10:15:49
  • Android实现彩信附件的添加与删除功能

    2023-04-14 01:02:28
  • 一文详解如何在控制台显示MyBatis的SQL语句

    2023-01-09 06:43:38
  • Spring boot + mybatis + Vue.js + ElementUI 实现数据的增删改查实例代码(一)

    2021-12-29 08:15:07
  • asp之家 软件编程 m.aspxhome.com