本文实例讲述了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程序设计有所帮助。