本文實例分析了android重寫view并自定義屬性的方法。分享給大家供大家參考,具體如下:
這里通過自定義屬性 實現如下圖所示效果:
第一步:在res\values的目錄下新建一個文件attrs.xml
聲明一些自定義屬性
1
2
3
4
5
6
7
8
|
<?xml version= "1.0" encoding= "utf-8" ?> <resources> <declare-styleable name= "customviewstyle" > <attr name= "customtext" format= "string" /> <attr name= "customtextcolor" format= "color" /> <attr name= "customtextsize" format= "dimension" /> </declare-styleable> </resources> |
第二步:在layout目錄下新建布局文件activity_main.xml
特別注意要在外層控件加上這個聲明:
格式:xmlns:(你自定義名稱)="http://schemas.android.com/apk/(你應用的包名)"
1
|
xmlns:xr= "http://schemas.android.com/apk/res/com.rong.test" |
或者
1
|
xmlns:xr= "http://schemas.android.com/apk/res-auto" |
推薦使用第二種
在布局文件中加入這些自定義的屬性:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
<?xml version= "1.0" encoding= "utf-8" ?> <relativelayout xmlns:android= "http://schemas.android.com/apk/res/android" xmlns:xr= "http://schemas.android.com/apk/res/com.rong.test" android:layout_width= "match_parent" android:layout_height= "match_parent" android:background= "@android:color/black" android:orientation= "vertical" > <com.rong.activity.customview android:layout_width= "300dp" android:layout_height= "300dp" android:layout_centerinparent= "true" android:background= "#ff0000" xr:customtext= "自定義控件" xr:customtextcolor= "#000000" xr:customtextsize= "40sp" /> </relativelayout> |
第三部繼承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
69
70
71
72
73
|
package com.rong.activity; import com.rong.test.r; import android.content.context; import android.content.res.typedarray; import android.graphics.canvas; import android.graphics.color; import android.graphics.paint; import android.graphics.rect; import android.util.attributeset; import android.view.view; /** * 自定義控件 * * @author 徐榮 * */ public class customview extends view { /** * 自定義畫筆 */ private paint mpaint; /** * 文字范圍 */ private rect mbounds; /** * 自定義文字 */ private string customtext; /** * 自定義大小 */ private int customtextsize; /** * 自定義顏色 */ private int customtextcolor; public customview(context context, attributeset attrs) { super (context, attrs); typedarray typedarray = context.obtainstyledattributes(attrs, r.styleable.customviewstyle); // 獲取自定義文字 customtext = typedarray.getstring(r.styleable.customviewstyle_customtext); // 獲取自定義文字大小 customtextsize = typedarray.getdimensionpixelsize(r.styleable.customviewstyle_customtextsize, 28 ); // 或者自定義文字顏色 customtextcolor = typedarray.getcolor(r.styleable.customviewstyle_customtextcolor, color.white); // 要回收這個typedarray對象 typedarray.recycle(); initview(); } public void initview() { // 初始化畫筆 mpaint = new paint(); mpaint.setantialias( true ); mpaint.setstyle(paint.style.fill); mpaint.setcolor(customtextcolor); mpaint.settextsize(customtextsize); // 生成文字區域 mbounds = new rect(); } @override protected void ondraw(canvas canvas) { super .ondraw(canvas); // 獲取文字顯示區域mbounds mpaint.gettextbounds(customtext, 0 , customtext.length(), mbounds); //使文字寬居中顯示=控件的寬度/2 -文字的寬度/2 float helfwidth = getwidth() / 2 - mbounds.width() / 2 ; //使文字高居中顯示=控件的寬度/2 +文字的寬度/2 float helfheight = getheight() / 2 +mbounds.height()/ 2 ; //繪制文字 canvas.drawtext(customtext, helfwidth, helfheight, mpaint); } } |
運行!
希望本文所述對大家android程序設計有所幫助。