查看: 48|回复: 2

Android开发之进度条ProgressBar

[复制链接]

0

主题

0

回帖

0

积分

热心网友

金币
0
阅读权限
220
精华
0
威望
0
贡献
0
在线时间
0 小时
注册时间
2010-7-14
发表于 2020-12-8 12:04:00 | 显示全部楼层 |阅读模式

 

说明

ProgressBar一般用于显示一个过程,例如数据加载过程,文件下载进度,音乐播放进度等。

默认形式ProgressBar

默认方式下,ProgressBar显示为圆形进度,循环转圈,不显示具体的进度值,控制其显隐藏即可,如下

 

 
默认

 

适用于界面加载

   //xml中
    <ProgressBar
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" />

   //代码中控制显隐藏
   mProgressBar = (ProgressBar) findViewById(R.id.progress_bar_main);
   mProgressBar.setVisibility(View.VISIBLE);

横向ProgressBar

横向带进度的进度条,通过设置ProgressBar的Style为style="?android:attr/progressBarStyleHorizontal"

 

 
image.png

 

max属性指定进度条总进度值,progress设置当前进度值,也可以说是初始进度值

    //xml中
   <ProgressBar
    android:id="@+id/progress_bar_h"
    style="?android:attr/progressBarStyleHorizontal"
    android:layout_width="85dp"
    android:layout_height="10dp"
    android:layout_gravity="center"
    android:max="100"
    android:progress="50"
    />

设进度条背景

系统自带的进度条的颜色比较单调,实际开发中使用较少,可以自定义进度条背景,新建一个progressbar_bg.xml文件

 <?xml version="1.0" encoding="UTF-8"?>
 <layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<!--  设置背景色  -->
<item android:id="@android:id/background"
    android:drawable="@mipmap/feed_grow_progress_bar">
</item>

<!--  设置进度条颜色  -->
<item android:id="@android:id/progress">
    <clip>
        <shape>

            <gradient
                android:endColor="#fff000"
                android:startColor="#fff000" />
        </shape>
    </clip>
</item>
</layer-list>

gradient可以设置进度条的渐变色, android:endColor和 android:startColor可以设置渐变开始和结束的颜色。定义完成以后,便可以使用

<ProgressBar
    android:id="@+id/progress_bar_healthy"
    style="?android:attr/progressBarStyleHorizontal"
    android:layout_width="85dp"
    android:layout_height="10dp"
    android:layout_marginTop="20dp"
    android:layout_gravity="center"
    android:max="100"
    android:progress="50"
    android:progressDrawable="@drawable/progressbar_bg"
    />

效果图,这里设置了黄色矩形背景,及黄色进度条

 

 
image.png

动态设置

在音乐进度,网络下载时,需动态加载进度条,默认情况下,设置进度条,使用setProgress()即可。但有时除了动态设置进度,仍需要动态设置进度条颜色

  private void setElectircProgress(int i, int color) {
    ClipDrawable drawable = new ClipDrawable(new ColorDrawable(color), Gravity.LEFT, ClipDrawable.HORIZONTAL);
    progressBarElectric.setProgressDrawable(drawable);
    progressBarElectric.setProgress(i);
}

音乐播放实例

通过MediaPlayer 播放音乐并获取进度,设置进度

 

 
image.png
musicProgressBar = (ProgressBar) findViewById(R.id.progress_bar_music);

    if (mPlayer != null) {
        mPlayer.release();
        mPlayer = null;
    }
    mPlayer = MediaPlayer.create(this, R.raw.summer);
    mPlayer.start();
    musicProgressBar.setMax(mPlayer.getDuration());
    if (timer != null) {
        timer = null;
        timerTask = null;
    }
    timer = new Timer();
    timerTask = new TimerTask() {
        @Override
        public void run() {
            if (mPlayer != null) {
                if (mPlayer.isPlaying()) {
                    runOnUiThread(new Runnable() {
                        @Override
                        public void run() {
                            musicProgressBar.setProgress(mPlayer.getCurrentPosition());
                        }
                    });
                }
            }
        }
    };
    timer.schedule(timerTask, 0, 1000);


来源:https://www.cnblogs.com/xgjblog/p/14101896.html
回复

使用道具 举报

0

主题

67

回帖

84

积分

琼殿精英

金币
17
阅读权限
220
精华
0
威望
0
贡献
0
在线时间
0 小时
注册时间
2010-9-27
发表于 昨天 11:31 | 显示全部楼层
感谢楼主的分享,这篇 ProgressBar 的教程写得很详细,从默认圆形到横向进度条,再到自定义背景和音乐播放实例都有涉及,对新老手都挺有帮助的!

稍微补充一点在实际开发中可能会碰到的小细节:  
- 动态设置进度时,如果是在子线程更新 UI,记得要切换到主线程,楼主在音乐播放示例里用 `runOnUiThread` 处理了,这个习惯很好,不然容易报 `CalledFromWrongThreadException`。  
- 自定义进度条背景时,除了 `layer-list` 和 `clip`,还可以用 `scale` 标签来做分段式效果,比如电池电量那种分段显示。  
- 如果进度条需要支持拖拽(比如音乐播放器可拖动改变进度),可以结合 `SeekBar` 实现,它继承自 `ProgressBar`,自带滑块,用起来更直接。

想问一下楼主,在音乐播放实例里,进度每秒更新一次,如果歌曲比较长,有没有考虑过用更平滑的更新方式,比如根据歌曲时长动态调整更新间隔,或者直接用 `Handler` 发送延迟消息来避免 Timer 可能带来的内存泄漏问题?

期待楼主后续更多 Android 开发的干货分享!
回复

使用道具 举报

0

主题

66

回帖

71

积分

琼殿精英

金币
5
阅读权限
220
精华
0
威望
0
贡献
0
在线时间
0 小时
注册时间
2012-4-30
发表于 昨天 11:31 | 显示全部楼层
楼主这篇教程太实用了!ProgressBar确实是日常开发里高频用到的控件,尤其是自定义样式和进度同步这块,之前我也踩过不少坑。补充几个小经验吧:


    []如果是做长列表里的进度条,建议用RecyclerView的ViewHolder复用机制,避免频繁findViewById导致卡顿。
    [
    ]自定义drawable时,注意padding和clip区域的匹配,不然进度条看起来会偏或者留白。
  • 对于需要精确控制进度的场景,可以试试结合ValueAnimator做平滑过渡动画,用户体验会好很多。


感谢分享,期待楼主更多Android实战干货!顶一个!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部