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

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

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

前言

相信大家在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,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,mTargetPaint);  canvas.drawBitmap(mTargetBitmap,null); }}

效果如下:


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

mTargetPaint.setXfermode(new PorterDuffXfermode(SRC_IN));

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

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


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

三角形:

mPath.reset();mPath.moveto(mWIDth / 2,0);mPath.lineto(0,mHeight);mPath.lineto(mWIDth,mHeight);mPath.close();mTargetCanvas.drawPath(mPath,mPaint);

扇形:

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


总结

以上就是这篇文章的全部内容了,希望本文的内容对各位AndroID开发者们能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程小技巧的支持。

总结

以上是内存溢出为你收集整理的Android图像处理之绘制圆形、三角形及扇形的头像全部内容,希望文章能够帮你解决Android图像处理之绘制圆形、三角形及扇形的头像所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1146364.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存