Android入門之ProgressBar的使用教程
介紹
Android里的ProgressBar默認(rèn)為一個不斷轉(zhuǎn)圈的圓,它也可以自定義,但是如我在上一篇里所述我們不追求專業(yè)的beautiful。我們求的是Android這本知識我們可以完整的體系化的學(xué)會。因此在本篇里我們就使用ProgressBar的默認(rèn)樣式了。
ProgressBar有一個屬性:
style="?android:attr/progressBarStyleHorizontal"
這個屬性會讓原來默認(rèn)的ProgressBar變成橫向的進(jìn)度條。
課程目標(biāo)

- 課程內(nèi)設(shè)置了兩個進(jìn)度條。一個默認(rèn)的轉(zhuǎn)圈類ProgressBar,一個橫向的ProgressBar。
- 點(diǎn)“顯示/隱藏效果演示“,可以隱藏或者顯示ProgressBar,此處的隱藏我們用的是事件是“GONE“,GONE的意思是不顯示同時這個組件在原界面也不占位。
- 點(diǎn)擊橫向的ProgressBar會顯示當(dāng)前進(jìn)度值,每點(diǎn)一下橫向的ProgressBar當(dāng)前的值會+5并顯示在下部的TextView內(nèi)。
我們先來看我們的主界面UI
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
android:orientation="vertical"
tools:context=".MainActivity">
<Button
android:id="@+id/displayBtn"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="顯示/隱藏效果演示"
android:textSize="20sp" />
<ProgressBar
android:id="@+id/pgBar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center" />
<ProgressBar
android:id="@+id/pgBarHorizontal"
style="?android:attr/progressBarStyleHorizontal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:max="100" />
<TextView
android:id="@+id/pgValueTextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="" />
</LinearLayout>它有4個組件,從上到下依次排列。
核心代碼導(dǎo)讀:
- style="?android:attr/progressBarStyleHorizontal"代表這個ProgressBar為橫向進(jìn)度條狀;
- android:max="100",這邊設(shè)置了進(jìn)度條漲滿的值為100;
我們再來看我們的JAVA端和界面交互代碼
MainActivity.java
package org.mk.android.demo.demoprogressbar;
import androidx.appcompat.app.AppCompatActivity;
import android.view.View;
import android.os.Bundle;
import android.widget.Button;
import android.widget.ProgressBar;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity {
private ProgressBar btnProgressBar;
private ProgressBar pgStyleHorizontal;
private TextView txtPgValueShow;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
txtPgValueShow = (TextView) findViewById(R.id.pgValueTextView);
//橫向進(jìn)度條,點(diǎn)一下加5
pgStyleHorizontal = (ProgressBar) findViewById(R.id.pgBarHorizontal);
pgStyleHorizontal.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.pgBarHorizontal:
//每點(diǎn)擊一次按鈕就可以獲取進(jìn)度條當(dāng)前的進(jìn)度
int progress = pgStyleHorizontal.getProgress();
progress = progress + 5;
pgStyleHorizontal.setProgress(progress);
StringBuffer currentValue = new StringBuffer();
currentValue.append("當(dāng)前進(jìn)度為: ").append(String.valueOf(progress));
txtPgValueShow.setText(currentValue.toString());
break;
default:
break;
}
}
});
//點(diǎn)一下顯示點(diǎn)一下隱藏圓形進(jìn)度條
Button button = (Button) findViewById(R.id.displayBtn);
btnProgressBar = (ProgressBar) findViewById(R.id.pgBar);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.displayBtn:
if (btnProgressBar.getVisibility() == View.GONE) {
btnProgressBar.setVisibility(View.VISIBLE);
} else {
btnProgressBar.setVisibility(View.GONE);
}
break;
default:
break;
}
}
});
}
}請各位自己動手去實(shí)現(xiàn)和運(yùn)行一下,體驗(yàn)一下這個效果吧。
到此這篇關(guān)于Android入門之ProgressBar的使用教程的文章就介紹到這了,更多相關(guān)Android ProgressBar內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android文本視圖TextView實(shí)現(xiàn)跑馬燈效果
這篇文章主要為大家詳細(xì)介紹了Android文本視圖TextView實(shí)現(xiàn)跑馬燈效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-05-05
淺析Android手機(jī)衛(wèi)士讀取聯(lián)系人
這篇文章主要介紹了淺析Android手機(jī)衛(wèi)士讀取聯(lián)系人的相關(guān)內(nèi)容,通過getContentResolver()方法獲取獲取ContentResolver內(nèi)容解析器對象,對android手機(jī)衛(wèi)士讀取聯(lián)系人相關(guān)知識感興趣的朋友參考下吧2016-04-04
Android中WebView圖片實(shí)現(xiàn)自適應(yīng)的方法
這篇文章主要介紹了Android中WebView圖片實(shí)現(xiàn)自適應(yīng)的方法,涉及Android操作圖片顯示的相關(guān)技巧,需要的朋友可以參考下2015-05-05
實(shí)現(xiàn)activity管理器一次退出所有activity
退出所有Activity網(wǎng)上有很多很多種說法,推薦的一種方法是自定義一個Activity管理器,來管理所有已打開的Activity,要退出的時候再通過這個管理器來退出所有Activity,下面是一個簡單的Activity管理器代碼2014-01-01
android textview設(shè)置字體的行距和字間距
這篇文章主要介紹了android textview設(shè)置字體的行距和字間距的方法,非常簡單實(shí)用,有需要的小伙伴可以參考下2016-05-05
Compose自定義View實(shí)現(xiàn)宇智波斑寫輪眼
這篇文章主要為大家介紹了Compose自定義View實(shí)現(xiàn)宇智波斑寫輪眼示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
如何調(diào)用百度地圖API實(shí)現(xiàn)手機(jī)自動定位
api手機(jī)自動定位,通過聲明地址解析器,獲取當(dāng)前坐標(biāo),如何調(diào)用百度地圖api實(shí)現(xiàn)手機(jī)自動定位呢?接下來,一起跟小編來學(xué)習(xí)吧。2015-09-09

