android圆形头像 demo,Android图像处理之绘制圆形头像
在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);
}
}
效果如下:
代码中最关键的就是这句:
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, 0, mWidth, mHeight);
mTargetCanvas.drawArc(rectF, 210, 120, true, mPaint);
android圆形头像 demo,Android图像处理之绘制圆形头像相关推荐
- android 自定义progressbar demo,Android自定义View――动态ProgressBar之模仿360加速球
在之前一篇文章中我们讲解了三种ProgressBar的做法,详见-><Android 自定义View--自定义ProgressBar >.这一节中我们模仿360加速球制作一个动态Pr ...
- android bitmap 饱和度 demo,实现类似QQ离线用户头像彩色变灰色的成效
实现类似QQ离线用户头像彩色变灰色的效果 头像由彩色变灰色有两种实现方式: 方法1把图片彩色图转换为纯黑白二色: /** * 将彩色图转换为纯黑白二色 * * @param 位图 * @return ...
- android bitmap 饱和度 demo,Android GPUImage实现多种图像滤镜效果
前言 GPUImage 是iOS下一个开源的基于GPU的图像处理库,提供各种各样的图像处理滤镜,并且支持照相机和摄像机的实时滤镜.GPUImage for Android是它在Android下的实现, ...
- android 谷歌定位demo,android实现定位与目的地的导航示例代码
今天无意中看到技术大神利用百度地图定位并实现目的地导航的Demo.觉得很不错,就转载过来一起分享,下面我们看实现效果: 进入后首先会得到当前位置,在地图上显示出来,在输入框中输入目的地后,就会在地图上 ...
- android 自定义progressbar demo,Android 自定义进度条ColorfulProgressbar,原理简单、效果还行...
效果图: demo效果演示 演示Demo 特性 与原生Progress相比,感觉更漂亮一点,可以显示进度值,背景凹凸感明显,进度条效果更加立体. 原理说明 额,挺简单的.不过感觉我的做法有点复杂了,我 ...
- android mvvm官方demo,Android MVVM实战Demo完全解析
最新 [重大更新说明] 感谢各位读者的阅读,这篇文章由于年代久远,存在一些错误的观点,再次向大家道歉,也做一个技术上的解释说明. 受限于当时的技术水平和网络论调,在那个时代,网上绝大多数人 都认为加了 ...
- android自动更新demo,Android程序自动更新功能模块的实现方法【附完整demo源码下载】...
本文实例讲述了Android程序自动更新功能模块的实现方法.分享给大家供大家参考,具体如下: 在程序启动的时候检测服务器上有没有对应版本更新,如果有更新,提示用户是否更新. 在程序启动的时候首先调用更 ...
- android 人脸识别demo,Android Camera 内置人脸识别的Demo
CameraFace Android Camera 内置人脸识别的Demo 通过Android源生API支持的人脸识别FaceDetection,获取到脸部矩形坐标,左右眼坐标,嘴坐标通过View动态 ...
- android xml解析demo,Android解析自定义xml文件--Sax解析xml文件,测试demo(方案二)...
转载请注明出处:http://blog.csdn.net/droyon/article/details/9346657 Sax解析xml 以下是测试Demo 运行程序类 public class Te ...
最新文章
- OO第三单元作业总结
- 天线3db波束宽度_天线的主瓣波束宽度越窄天线增益越高.PPT
- Chrome——我的Chrome插件
- 使用JAX-RS的HTTP缓存
- Linux入门学习(一)
- java编译异常有哪些_java 中 哪些异常必须声明并捕获,否则产生编译错误
- Windows7启动信息修改
- 给妹子讲python-S01E05字符串的基本用法详解
- sql---字段类型转换,sql获取当前时间,时间处理
- GridViewObjectDataSource新特性小记 懒人篇(一) 分页上路
- NumberFormat
- Css选择器权重排序详解+权重计算
- 网页设计中文标题h1~h4应用技巧
- 记录VS在线安装下载慢的解决
- CSS设置字体和文字样式
- h5破解网站图片防盗链
- 三维激光扫描后处理软件_地面三维激光扫描仪应用之一|云尚智造
- 帆软日期格式转换_自定义函数把阳历转换成阴历
- 用计算机刻录光盘,教你怎么用电脑刻录数据光盘
- 嵌入式--轮询调度模块