Android 動態增加控件

[b]核心提示:android控件動態使用 通常android裏的界面佈局都是在XML裏設定好的 也就是說 在程序中,不能更改界面上的元素數量等, 比如上圖所示的一個[/b]


android控件動態使用
[img]http://ajava.org/uploads/allimg/090902/1532564094-0.jpg[/img]

通常android裏的界面佈局都是在XML裏設定好的
也就是說
在程序中,不能更改界面上的元素數量等,
比如上圖所示的一個 聊天會話界面
當有人發言就要增加一個TextView,
這就是動態增加控件,
這就不能在XML裏事先佈局了!

不過還好,ANDROID使用控件也不是隻有XML這一種方式
[b]以下代碼就是動態生產控件的JAVA程序
實現效果如上圖[/b]

   1.  package com.fetion.android;   
2.
3. import android.app.Activity;
4. import android.content.Context;
5. import android.graphics.Color;
6. import android.os.Bundle;
7. import android.text.Layout;
8. import android.text.format.DateFormat;
9. import android.util.Log;
10. import android.view.KeyEvent;
11. import android.view.ViewGroup.LayoutParams;
12. import android.widget.*;
13.
14. import java.util.Calendar;
15.
16. /**
17. * 測試動態使用android控件
18. * @author gaolei by 20090827
19. */
20. public class fetion2009 extends Activity
21. {
22. /** Called when the activity is first created. */
23. ProgressBar pb; //進度條控件,但拿出來是爲了可控,動態改變其進度
24. //聊天對話的底色是間隔的
25. private static final int[] bg = { Color.WHITE, Color.GRAY };
26. private static int bgIndex=0; //聊天對話的底色 當前色應該是bg中的索引值
27.
28. //以下 佈局參數 標識當前控件的寬高情況FILL_PARENT=佔據全部父控件,WRAP_CONTENT=僅包裹控件中的內容//還有其他作用比如左右邊距,這裏我們使用默認的
29. private LinearLayout.LayoutParams LP_FF = new LinearLayout.LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT);
30. private LinearLayout.LayoutParams LP_FW = new LinearLayout.LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT);
31. private LinearLayout.LayoutParams LP_WW = new LinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
32.
33. @Override
34. public void onCreate( Bundle savedInstanceState )
35. {
36. super.onCreate( savedInstanceState );
37.
38. //聊天對白窗口需要滾動
39. ScrollView sv = new ScrollView(this);
40. sv.setLayoutParams( LP_FF );
41.
42. LinearLayout layout = new LinearLayout(this); //線性佈局方式
43. layout.setOrientation( LinearLayout.VERTICAL ); //控件對其方式爲垂直排列
44. layout.setBackgroundColor( 0xff00ffff ); //設置佈局板的一個特殊顏色,這可以檢驗我們會話時候是否有地方顏色不正確!
45.
46. //豐富聊天頁面,也順帶測試頁面滾動效果,增加了10個重複的對話內容
47. for( int i=0; i<10; i++ )
48. {
49. setSendMsg( layout, this, getCurrColor(), i+"聊天內容在這裏。。" );
50. }
51.
52. //發送文件效果1,圓環進度條,也是ProgressBar默認的效果
53. setSendFile( layout, this, getCurrColor(),"我的照片.jpg");
54.
55. //發送文件效果 2,矩行進度條,也是ProgressBar的風格設置成 style="?android:attr/progressBarStyleHorizontal"的效果
56. setSendFile2( layout, this, getCurrColor(),"我的照片.jpg");
57.
58. for( int i=0; i<10; i++ )
59. {
60. setSendMsg( layout, this, getCurrColor(), i+"聊天內容在這裏。。" );
61. }
62. sv.addView( layout ); //把線性佈局加入到ScrollView中
63. setContentView(sv); //設置當前的頁面爲ScrollView
64. }
65.
66. /**
67. * 獲取當前聊天對白的底色值
68. * @return 當前聊天對白的底色值
69. */
70. private int getCurrColor()
71. {
72. return bg[ (++bgIndex)% bg.length ];
73. }
74.
75. /**
76. * 動態增加一個聊天內容
77. * 這裏爲了簡化編程把 某人說 和 內容放到一個TextView中,可以根據設計文檔拆成2個TextView分別顯示,設置字體等
78. * @param layout TextView 控件欲添加到的目標layout
79. * @param context 構建View控件的必須參數 既View控件的環境
80. * @param bgColur TextView 控件的背景色
81. * @param MSG TextView 控件要現實的文本內容
82. */
83. private void setSendMsg(LinearLayout layout, Context context, int bgColur, String MSG)
84. {
85. TextView tv = new TextView(context); //普通聊天對話
86. //獲取一個全局的日曆實例,用於獲取當前系統時間並格式化成小時:分鐘形式,僅用於測試,這裏的時間應該是由其他程序提供
87. tv.setText( "某人 說: ["+DateFormat.format( "kk:mm" , Calendar.getInstance())+"]\n"+MSG );
88. tv.setBackgroundColor( bgColur );
89. layout.addView( tv );
90. }
91.
92. /**
93. * 動態增加一個發送文件的會話條目
94. * 這裏因爲是發送進度條與取消按鈕的水平對其方式,所以需要增加一個LinearLayout
95. * @param layout 欲添加到的目標layout
96. * @param context 構建 View控件的必須參數 既View控件的環境
97. * @param bgColur 控件的背景色
98. * @param MSG 控件要現實的文本內容
99. */
100. private void setSendFile(LinearLayout layout, Context context, int bgColur, String fileName)
101. {
102. //把 某人說 [時間]
103. //要發送的文件信息 全都交給 setSendMsg 繪製吧!
104. setSendMsg( layout, context, bgColur, "正在發送"+fileName );
105. //水平排列2個控件需要一個LinearLayout,排列方式默認的就是水平排列
106. LinearLayout myLayout = new LinearLayout(context);
107. //這個 LinearLayout控件的背景色需要設置,要不就會顯示出主LinearLayout的顏色了,即0xff00ffff
108. myLayout.setBackgroundColor( bgColur );
109.
110. //動態創建一個 ProgressBar,以默認屬性加入到myLayout中
111. ProgressBar pb = new ProgressBar(context);
112. pb.setLayoutParams( LP_WW );
113. myLayout.addView( pb );
114.
115. //動態創建一個 Button,以默認屬性加入到myLayout中
116. Button bt = new Button(context);
117. bt.setLayoutParams( LP_WW );
118. bt.setText( " 取消" );
119. myLayout.addView( bt );
120. //將水平佈局的 LinearLayout及其內如所有控件添加到主layout中
121. layout.addView( myLayout );
122. }
123.
124. /**
125. * 動態增加一個發送文件的會話條目
126. * 但爲了保障ProgressBar和 Button的底色符合設計要求,增加了一個LinearLayout,並設置其背景色
127. * @param layout 欲添加到的目標layout
128. * @param context 構建 View控件的必須參數 既View控件的環境
129. * @param bgColur 控件的背景色
130. * @param MSG 控件要現實的文本內容
131. */
132. private void setSendFile2(LinearLayout layout, Context context, int bgColur, String fileName)
133. {
134. setSendMsg( layout, context, bgColur, "正在發送"+fileName );
135.
136. LinearLayout myLayout = new LinearLayout(context);
137. myLayout.setBackgroundColor( bgColur );
138. myLayout.setOrientation( LinearLayout.VERTICAL );//控件對其方式爲垂直,默認爲水平
139.
140. //ProgressBar 的默認風格是圓環型,這裏需要設置她的風格爲Horizontal(水平線)
141. pb = new ProgressBar(context,null,android.R.attr.progressBarStyleHorizontal);
142. pb.setLayoutParams( LP_FW );
143. pb.setProgress( 45 ); // 設置第1進度爲45
144. pb.setSecondaryProgress( 0 ); //這裏我們不需要第2進度,所以爲0
145. myLayout.addView( pb );
146.
147. Button bt = new Button(context);
148. bt.setLayoutParams( LP_WW );
149. bt.setText( "取消" );
150. myLayout.addView( bt );
151.
152. layout.addView( myLayout );
153. }
154.
155. @Override
156. public boolean onKeyDown(int keyCode, KeyEvent event)
157. {
158. Log.d("onKeyDown:", " keyCode=" + keyCode + " KeyEvent=" + event);
159. switch (keyCode)
160. {
161. case KeyEvent.KEYCODE_DPAD_UP:
162.
163. break;
164. case KeyEvent.KEYCODE_DPAD_DOWN:
165.
166. break;
167. case KeyEvent.KEYCODE_DPAD_LEFT:
168. //右左按鍵可以控制第一進度的增減
169. pb.setProgress( pb.getProgress()-5 );
170. break;
171. case KeyEvent.KEYCODE_DPAD_RIGHT:
172. pb.setProgress( pb.getProgress()+5 );
173. break;
174. case KeyEvent.KEYCODE_DPAD_CENTER:
175.
176. break;
177. case KeyEvent.KEYCODE_0:
178. break;
179. }
180. return super.onKeyDown(keyCode, event);
181. }
182. }
發佈了43 篇原創文章 · 獲贊 0 · 訪問量 2669
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章