这篇文章主要介绍了Android编程绘制圆形图片的方法,结合实例形式较为详细的分析了Android通过自定义控件实现图形绘制的相关技巧,需要的朋友可以参考下
这篇文章主要介绍了Android编程绘制圆形图片的方法,结合实例形式较为详细的分析了Android通过自定义控件实现图形绘制的相关技巧,需要的朋友可以参考下
这篇文章主要介绍了Android编程绘制圆形图片的方法,结合实例形式较为详细的分析了Android通过自定义控件实现图形绘制的相关技巧,需要的朋友可以参考下
本文实例讲述了android编程绘制圆形图片的方法。分享给大家供大家参考,具体如下:
效果图如下:

第一步:新建roundview自定义控件继承view
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
package com.rong.activity;import com.rong.test.r;import android.content.context;import android.graphics.bitmap;import android.graphics.bitmap.config;import android.graphics.bitmapfactory;import android.graphics.canvas;import android.graphics.color;import android.graphics.paint;import android.graphics.porterduff;import android.graphics.porterduffxfermode;import android.util.attributeset;import android.widget.imageview;/** * 利用xfermode制作一个圆形图片 * * @author 徐荣 * */public class roundview extends imageview { /** * 画笔 */ private paint mpaint; /** * 原型图 */ private bitmap src; /** * 遮罩层 */ private bitmap mask; public roundview(context context, attributeset attrs) { super(context, attrs); // 初始化画笔 mpaint = new paint(); mpaint.setantialias(true); // 拿到原型图 src = bitmapfactory.decoderesource(getresources(), r.drawable.ml); } @override protected void onsizechanged(int w, int h, int oldw, int oldh) { super.onsizechanged(w, h, oldw, oldh); // 图片的遮罩,为什么要在这里面初始化遮罩层呢?因为在这个方法里width()和height()才被初始化了 mask = bitmap.createbitmap(getmeasuredwidth(), getmeasuredheight(), config.argb_4444); } @override protected void ondraw(canvas canvas) { super.ondraw(canvas); // 设置画布的颜色为透明 canvas.drawcolor(color.transparent); // 划出你要显示的圆 canvas cc = new canvas(mask); cc.drawcircle(getmeasuredwidth() / 2, getmeasuredheight() / 2, getmeasuredheight() / 2, mpaint); // 这个方法相当于ps新建图层,下面你要做的事就在这个图层上操作 canvas.savelayer(0, 0, getmeasuredwidth(), getmeasuredheight(), null, canvas.all_save_flag); // 先绘制遮罩层 canvas.drawbitmap(mask, 0, 0, mpaint); // 设置混合模式 mpaint.setxfermode(new porterduffxfermode(porterduff.mode.src_in)); // 再绘制src源图 canvas.drawbitmap(src, 0, 0, mpaint); // 还原混合模式 mpaint.setxfermode(null); // 还原画布,相当于ps的合并图层 canvas.restore(); }} |
第二步 新建布局文件activity_main.xml
|
1
2
3
4
5
6
7
8
9
10
11
|
<?xml version="1.0" encoding="utf-8"?><relativelayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#ffffff" android:orientation="vertical" > <com.rong.activity.roundview android:layout_width="160dp" android:layout_height="160dp" android:layout_centerinparent="true" /></relativelayout> |
运行!
希望本文所述对大家android程序设计有所帮助。
发表评论