網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
介紹
Android里的ProgressBar默認(rèn)為一個(gè)不斷轉(zhuǎn)圈的圓,它也可以自定義,但是如我在上一篇里所述我們不追求專業(yè)的beautiful。我們求的是Android這本知識(shí)我們可以完整的體系化的學(xué)會(huì)。因此在本篇里我們就使用ProgressBar的默認(rèn)樣式了。
ProgressBar有一個(gè)屬性:
style="?android:attr/progressBarStyleHorizontal"
這個(gè)屬性會(huì)讓原來(lái)默認(rèn)的ProgressBar變成橫向的進(jìn)度條。
課程目標(biāo)
- 課程內(nèi)設(shè)置了兩個(gè)進(jìn)度條。一個(gè)默認(rèn)的轉(zhuǎn)圈類ProgressBar,一個(gè)橫向的ProgressBar。
- 點(diǎn)“顯示/隱藏效果演示“,可以隱藏或者顯示ProgressBar,此處的隱藏我們用的是事件是“GONE“,GONE的意思是不顯示同時(shí)這個(gè)組件在原界面也不占位。
- 點(diǎn)擊橫向的ProgressBar會(huì)顯示當(dāng)前進(jìn)度值,每點(diǎn)一下橫向的ProgressBar當(dāng)前的值會(huì)+5并顯示在下部的TextView內(nèi)。
我們先來(lá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個(gè)組件,從上到下依次排列。
核心代碼導(dǎo)讀:
- style="?android:attr/progressBarStyleHorizontal"代表這個(gè)ProgressBar為橫向進(jìn)度條狀;
- android:max="100",這邊設(shè)置了進(jìn)度條漲滿的值為100;
我們?cè)賮?lái)看我們的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;
}
}
});
}
}
請(qǐng)各位自己動(dòng)手去實(shí)現(xiàn)和運(yùn)行一下,體驗(yàn)一下這個(gè)效果吧。
原文鏈接:https://blog.csdn.net/lifetragedy/article/details/127767997
相關(guān)推薦
- 2022-12-28 Python?PyQt5中窗口數(shù)據(jù)傳遞的示例詳解_python
- 2022-07-03 kali安裝docker及搭建漏洞環(huán)境的詳細(xì)教程_docker
- 2023-03-19 Kotlin?WorkManager使用方法詳解_Android
- 2022-04-27 一篇文章了解正則表達(dá)式的替換技巧_正則表達(dá)式
- 2022-07-15 教你docker方式部署nacos_docker
- 2022-08-17 C語(yǔ)言堆結(jié)構(gòu)處理TopK問(wèn)題詳解_C 語(yǔ)言
- 2024-04-07 Linux如何查看當(dāng)前占用CPU和內(nèi)存最多的進(jìn)程
- 2022-05-25 @Service未注入、 @Autowired未自動(dòng)注入
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支