Android UI控制元件系列:ProgressBar(進度條)
Android在執行一些後臺操作的時候,比如載入遊戲,播放歌曲時,使用者根本不知道程式執行的進度情況,這時候,可以使用進度條來顯示這些進度。
Andorid系統提供兩種進度條,長條形進度條(progressBarStyleHorizontal)和圓形進度條(progressBarStyleLarge),Android平臺預設的進度條是第二種。另外,還可以在窗體的標題欄設定進度條,這就需要先對窗體的顯示風格進行設定“requestWindowFeature(Window.FEATURE_PROGRESS)”;如果要顯示這個進度條,還要使用setProgressBarVisibility(true);方法來使其顯示
下面是個例子,分別由標題欄進度條,長條形進度條和圓形進度條組成,並用執行緒控制。
注意:圓形進度條是不會顯示具體的進度的,而只是單純的旋轉
package org.hualang.progress; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.view.View; import android.view.Window; import android.widget.Button; import android.widget.ProgressBar; public class ProgressBarTest extends Activity { //宣告ProgressBar物件 private ProgressBar pro1; private ProgressBar pro2; private Button btn; protected static final int STOP_NOTIFIER = 000; protected static final int THREADING_NOTIFIER = 111; public int intCounter=0; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); //設定視窗模式,,因為需要顯示進度條在標題欄 requestWindowFeature(Window.FEATURE_PROGRESS); //設定標題欄上的進度條可見 setProgressBarVisibility(true); setContentView(R.layout.main); //取得ProgressBar pro1 = (ProgressBar) findViewById(R.id.progress1); pro2= (ProgressBar) findViewById(R.id.progress2); btn = (Button)findViewById(R.id.button); //設定進度條是否自動運轉,即設定其不確定模式,false表是不自動運轉 pro1.setIndeterminate(false); pro2.setIndeterminate(false); //當按鈕按下時開始執行, btn.setOnClickListener(new Button.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub //設定ProgressBar為可見狀態 pro1.setVisibility(View.VISIBLE); pro2.setVisibility(View.VISIBLE); //設定ProgressBar的最大值 pro1.setMax(100); //設定ProgressBar當前值 pro1.setProgress(0); pro2.setProgress(0); //通過執行緒來改變ProgressBar的值 new Thread(new Runnable() { public void run() { for (int i = 0; i < 10; i++) { try { intCounter = (i + 1) * 20; Thread.sleep(1000); if (i == 4) { Message m = new Message(); m.what = ProgressBarTest.STOP_NOTIFIER; ProgressBarTest.this.myMessageHandler.sendMessage(m); break; } else { Message m = new Message(); m.what = ProgressBarTest.THREADING_NOTIFIER; ProgressBarTest.this.myMessageHandler.sendMessage(m); } } catch (Exception e) { e.printStackTrace(); } } } }).start(); } }); } Handler myMessageHandler = new Handler() { // @Override public void handleMessage(Message msg) { switch (msg.what) { //ProgressBar已經是對大值 case ProgressBarTest.STOP_NOTIFIER: pro1.setVisibility(View.GONE); pro2.setVisibility(View.GONE); Thread.currentThread().interrupt(); break; case ProgressBarTest.THREADING_NOTIFIER: if (!Thread.currentThread().isInterrupted()) { // 改變ProgressBar的當前值 pro1.setProgress(intCounter); pro2.setProgress(intCounter); // 設定標題欄中前景的一個進度條進度值 setProgress(intCounter*100); // 設定標題欄中後面的一個進度條進度值 setSecondaryProgress(intCounter*100);// } break; } super.handleMessage(msg); } }; }
main.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="進度條例項演示" /> <ProgressBar android:id="@+id/progress1" style="?android:attr/progressBarStyleHorizontal"---設定進度條為長條形 android:layout_width="fill_parent" android:layout_height="wrap_content" android:visibility="gone"---設定其不可見 /> <ProgressBar android:id="@+id/progress2" style="?android:attr/progressBarStyleLarge"---設定進度條為圓形進度條 android:layout_width="wrap_content" android:layout_height="wrap_content" android:max="100"---設定其最大值 android:progress="50"---設定當前進度值 android:secondaryProgress="70"---設定次要進度值 android:visibility="gone" /> <Button android:id="@+id/button" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="啟動進度條" /> </LinearLayout>
執行結果如下:
點選啟動進度條按鈕後,進度條將自動執行
當結束時,自動退出進度條程式,返回第一個圖片的樣子
相關文章
- jquery ui進度條 progressbarjQueryUI
- JQuery UI之進度條——ProgressbarjQueryUI
- c#進度條progressbarC#
- Android之利用Handler實現ProgressBar進度條Android
- Android UI系列-----時間、日期、Toasts和進度條DialogAndroidUIAST
- C++ Qt開發:ProgressBar進度條元件C++QT元件
- C# 根據BackgroundWoker非同步模型和ProgressBar控制元件,自定義進度條控制元件C#非同步模型控制元件
- 【Dflying Chen 】使用ASP.NET Atlas編寫顯示真實進度的ProgressBar(進度條)控制元件ASP.NET控制元件
- android:ProgressBar控制元件Android控制元件
- Xamarin XAML語言教程構建進度條ProgressBar
- Android自定義控制元件系列之圓形進度條的實現Android控制元件
- 很實用的進度條外掛ProgressBar.jsJS
- 第一百九十八節,jQuery EasyUI,ProgressBar(進度條)元件jQueryUI元件
- [C#] (原創)一步一步教你自定義控制元件——04,ProgressBar(進度條)C#控制元件
- 直播平臺搭建原始碼,Android進度條ProgressBar顏色的漸變設定原始碼Android
- android自帶ProgressBar圓形進度條修改顏色的技巧方法無bug探索Android
- Android UI控制元件系列:Toast(提示)AndroidUI控制元件AST
- Android - 蝸牛進度條Android
- Android UI控制元件系列:Button(按鈕)AndroidUI控制元件
- Android UI控制元件系列:TextView(文字框)AndroidUI控制元件TextView
- 直播帶貨平臺原始碼,利用ProgressBar實現垂直、水平進度條原始碼
- Android Paint應用之自定義View實現進度條控制元件AndroidAIView控制元件
- 【新特性速遞】進度條,進度條,進度條
- Android UI控制元件系列:TableLayout(表格佈局)AndroidUI控制元件
- Android UI控制元件系列:Spinner(下拉選單)AndroidUI控制元件
- Android花樣loading進度條(三)-配文字環形進度條Android
- Android UI控制元件系列:Gallery(畫廊檢視)AndroidUI控制元件
- Android UI控制元件系列:TabWidget(切換卡)AndroidUI控制元件
- Android UI控制元件系列:WebView(網路檢視)AndroidUI控制元件WebView
- Android UI控制元件系列:AutoCompleteTextView(自動提示)AndroidUI控制元件TextView
- Android自定義圓形進度條Android
- 進度條和列表形式顯示的控制元件控制元件
- MFC在狀態列中使用進度條控制元件控制元件
- ajax進度條 非同步下載進度條非同步
- Android UI控制元件系列:Tab Layout(選項卡布局)AndroidUI控制元件
- Android UI控制元件系列:RelativeLayout(相對佈局)AndroidUI控制元件
- Android UI控制元件系列:GridView(網格佈局)AndroidUI控制元件View
- Android UI控制元件系列:Dialog(對話方塊)AndroidUI控制元件