Android進(jìn)度條ProgressBar的實(shí)現(xiàn)代碼
ProgressBar進(jìn)度條
當(dāng)一個(gè)應(yīng)用在后臺(tái)執(zhí)行時(shí),前臺(tái)界面不會(huì)有任何信息,這時(shí),用戶根本不知道程序是否在執(zhí)行以及執(zhí)行的進(jìn)度等, 因此需要使用進(jìn)度條來(lái)提示程序執(zhí)行的進(jìn)度。
而ProgressBar就是來(lái)做這個(gè)事情的。
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.amy.processbartest.MainActivity">
<!--水平進(jìn)度條 -->
<ProgressBar
android:id="@+id/progressBar1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:max="100"
style="@android:style/Widget.ProgressBar.Horizontal" />
<!-- 圓形進(jìn)度條 -->
<ProgressBar
android:id="@+id/progressBar2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
style="?android:attr/progressBarStyleLarge"/>
</android.support.constraint.ConstraintLayout>
MainActivity.java
package com.amy.processbartest;
import android.os.Handler;
import android.os.Message;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.ProgressBar;
import android.widget.Toast;
import static android.R.attr.id;
public class MainActivity extends AppCompatActivity {
//定義水平進(jìn)度條
private ProgressBar horizonP;
//定義圓形進(jìn)度條
private ProgressBar circleP;
//完成進(jìn)度
private int mProcessStatus = 0;
//聲明一個(gè)用于處理消息的Handler類的對(duì)象
private Handler mHandler;
/**
* 在主活動(dòng)onCreate方法中,首先獲得水平進(jìn)度條和圓形進(jìn)度條,
* 然后通過(guò)匿名內(nèi)部類實(shí)例化處理消息的Handler類的對(duì)象,并重寫其handlerMessage方法,
* 實(shí)現(xiàn)當(dāng)好吃操作沒(méi)有完成時(shí)更新進(jìn)度,否則設(shè)置進(jìn)度條不顯示。
* @param savedInstanceState
*/
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
horizonP = (ProgressBar) findViewById(R.id.progressBar1);
circleP = (ProgressBar) findViewById(R.id.progressBar2);
mHandler = new Handler(){
@Override
public void handleMessage(Message msg) {
if (msg.what == 0x111) {
horizonP.setProgress(mProcessStatus);//更新進(jìn)度
} else {
Toast.makeText(MainActivity.this,"耗時(shí)操作已經(jīng)完成",Toast.LENGTH_SHORT).show();
horizonP.setVisibility(View.GONE);
circleP.setVisibility(View.GONE);
}
}
};
//開(kāi)個(gè)線程用語(yǔ)模擬耗時(shí)操作
new Thread(new Runnable() {
@Override
public void run() {
while (true) {
mProcessStatus = doWork();//獲取耗時(shí)操作完成的百分比
Message msg = new Message();
if (mProcessStatus<100) {
msg.what = 0x111;
mHandler.sendMessage(msg);//發(fā)送消息
} else {
msg.what = 0x110;
mHandler.sendMessage(msg);//發(fā)送消息
break;
}
}
}
//模擬一個(gè)耗時(shí)操作
private int doWork() {
mProcessStatus += Math.random()*10;//改變完成進(jìn)度
try {
Thread.sleep(200);//每隔200毫秒進(jìn)度改變一次
} catch (InterruptedException e) {
e.printStackTrace();
}
return mProcessStatus;//返回新的進(jìn)度
}
}).start();//開(kāi)啟一個(gè)新的線程
}
}
效果圖:

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- android ListView和ProgressBar(進(jìn)度條控件)的使用方法
- Android編程之ProgressBar圓形進(jìn)度條顏色設(shè)置方法
- Android三種方式實(shí)現(xiàn)ProgressBar自定義圓形進(jìn)度條
- Android ProgressBar進(jìn)度條使用詳解
- Android ProgressBar進(jìn)度條和ProgressDialog進(jìn)度框的展示DEMO
- Android ProgressBar直線進(jìn)度條的實(shí)例代碼
- Android進(jìn)度條控件progressbar使用方法詳解
- Android開(kāi)發(fā)之ProgressBar字體隨著進(jìn)度條的加載而滾動(dòng)
- Android編程實(shí)現(xiàn)類似于圓形ProgressBar的進(jìn)度條效果
- Android UI控件之ProgressBar進(jìn)度條
- Android progressbar實(shí)現(xiàn)帶底部指示器和文字的進(jìn)度條
- Android開(kāi)發(fā)使用ProgressBar實(shí)現(xiàn)進(jìn)度條功能示例
相關(guān)文章
Android實(shí)現(xiàn)recyclerview城市字母索引列表
大家好,本篇文章主要講的是Android實(shí)現(xiàn)recyclerview城市字母索引列表,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01
android?Service基礎(chǔ)(啟動(dòng)服務(wù)與綁定服務(wù))
大家好,本篇文章主要講的是android?Service基礎(chǔ)(啟動(dòng)服務(wù)與綁定服務(wù)),感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12
Android利用ContentProvider獲取本地?cái)?shù)據(jù)的方法
這篇文章主要介紹了Android利用ContentProvider獲取本地?cái)?shù)據(jù)的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04
Android?ScrollView實(shí)現(xiàn)滾動(dòng)超過(guò)邊界松手回彈
這篇文章主要為大家詳細(xì)介紹了Android?ScrollView實(shí)現(xiàn)滾動(dòng)超過(guò)邊界松手回彈,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
android效果TapBarMenu繪制底部導(dǎo)航欄的使用方式示例
本篇文章主要介紹了android效果TapBarMenu繪制底部導(dǎo)航欄的使用方式,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-01-01
Android使用Scrolling機(jī)制實(shí)現(xiàn)Tab吸頂效果
app 首頁(yè)中經(jīng)常要實(shí)現(xiàn)首頁(yè)頭卡共享,tab 吸頂,內(nèi)容區(qū)通過(guò) ViewPager 切換的需求,以前往往是利用事件處理來(lái)完成,但是這些也有一定的弊端和滑動(dòng)方面不如意的地方,本文我們利用NestedScrolling機(jī)制來(lái)實(shí)現(xiàn),感興趣的朋友可以參考下2024-01-01
Android Data Binding數(shù)據(jù)綁定詳解
本文主要介紹Android Data Binding數(shù)據(jù)綁定的知識(shí),這里整理了詳細(xì)的資料及簡(jiǎn)單示例代碼幫助大家學(xué)習(xí)理解此部分知識(shí),有需要的小伙伴可以參考下2016-09-09
揭秘雙十一手機(jī)淘寶圖標(biāo)如何被動(dòng)態(tài)更換
這篇文章主要介紹了每到雙十一十二的時(shí)候Android手機(jī)動(dòng)態(tài)更換手機(jī)圖標(biāo)的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08

