欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

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

程序员文章站 2023-11-17 18:41:34
前言 相信大家在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, 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图像处理之绘制圆形、三角形及扇形的头像

总结

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