Android开发使用ProgressBar实现进度条功能示例

 更新时间:2019年03月23日 11:41:35   作者:水中鱼之1999  
这篇文章主要介绍了Android开发使用ProgressBar实现进度条功能,结合实例形式分析了Android进度条ProgressBar的具体样式、布局与功能实现技巧,需要的朋友可以参考下

本文实例讲述了Android开发使用ProgressBar实现进度条功能。分享给大家供大家参考,具体如下:

进度条ProgressBar的使用主要有两种方向;

1.使用官方默认样式

2.使用自定义样式

先看效果:

详细代码实现文末给出

关于系统自带样式:

style="@android:style 中有许多系统自带样式,大家可以更具自身喜好选择。

如果不选择 style 系统会默认使用上图中红色的样式。

关于自定义样式:

这里我们最好看看源码 很容易理解

主要分为三个部分:当前进度、缓冲进度、以及背景 三个属性

这里我们通过在drawable里新建my_bar.xml来实现

这里有个注意点 很多人写了xml后发现 直接就显示满进度 而不是缓慢增长

由于是替换系统自带样式,所以id必须与系统保持一致:(如:android:id="@android:id/background"

<?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="@drawable/no"/>
  <!--定义轨道上已完成部分的样式-->
  <item android:id="@android:id/progress"
    android:drawable="@drawable/ok"/>
</layer-list>

这里对比下系统源码就很好理解了:

这里的模拟方法采用的是线程结合Handler

由于线程不能直接改变控件属性 所以需要用Handler来接受线程发出的Message

具体方法如下:

public class MainActivity extends Activity {
  //记录ProgressBar的完成进度
  private int sum1=0,sum2 = 0 ;
  ProgressBar bar1,bar2;
  //创建一个负责更新进度的Handler
  Handler mHandler = new Handler(){
    @Override
    public void handleMessage(Message msg) {
      //表明消息是本程序发送的
      if (msg.what == 0x111){
        bar1.setProgress(sum1);
        bar2.setProgress(sum2);
      }
    }
  };
  //模拟耗时
  Thread thread = new Thread(){
    @Override
    public void run() {
      while (sum2 < 100){
        //bar1获取完成工作的百分比
        if (sum1 > 100){
          sum1 = 100;
          if (sum2<100){
            sum2 += (int) (Math.random()*25);
          }else {
            sum2 = 100;
            thread.stop();
          }
          sum1=0;
        }else {
          sum1 = sum1 + (int) (Math.random()*25);
        }
        try{
          Thread.sleep(1000);
        }catch (InterruptedException e){
          e.printStackTrace();
        }
        //更新ProgressBar
        mHandler.sendEmptyMessage(0x111);
      }
    }
  };
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    bar1 = (ProgressBar) findViewById(R.id.bar);
    bar2 = (ProgressBar) findViewById(R.id.bar2);
    thread.start();
  }
}

最后在给出布局文件:

<?xml version="1.0" encoding="utf-8" ?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  xmlns:app="http://schemas.android.com/apk/res-auto"
  android:orientation="vertical">
  <android.support.v7.widget.Toolbar
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    app:contentInsetStart="0dp"
    android:background="#9FB6CD">
    <RelativeLayout
      android:layout_width="match_parent"
      android:layout_height="wrap_content">
      <ProgressBar
        android:id="@+id/toolbar_progress"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentEnd="true"
        android:layout_alignParentRight="true" />
    </RelativeLayout>
  </android.support.v7.widget.Toolbar>
  <LinearLayout
    android:orientation="horizontal"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">
    <!--定义一个大环型进度条-->
    <ProgressBar
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      style="@android:style/Widget.ProgressBar.Large"/>
    <!--定义一个中等大小环形进度条-->
    <ProgressBar
      android:layout_width="wrap_content"
      android:layout_height="wrap_content" />
    <!--定义一个小进度条-->
    <ProgressBar
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      style="@android:style/Widget.ProgressBar.Small"/>
  </LinearLayout>
  <TextView
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:text="任务完成的进度"/>
  <!--定义一个大水平进度条-->
  <ProgressBar
    android:id="@+id/bar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:max="100"
    style="@android:style/Widget.ProgressBar.Horizontal"/>
  <!--顶一个水平进度条,并改变轨道外观-->
  <ProgressBar
    android:id="@+id/bar2"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:max="100"
    android:progressDrawable="@drawable/my_bar"
    style="@android:style/Widget.ProgressBar.Horizontal"/>
</LinearLayout>

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android控件用法总结》、《Android开发入门与进阶教程》、《Android视图View技巧总结》、《Android编程之activity操作技巧总结》、《Android数据库操作技巧总结》及《Android资源操作技巧汇总

希望本文所述对大家Android程序设计有所帮助。

相关文章

  • Android自定义可左右滑动和点击的折线图

    Android自定义可左右滑动和点击的折线图

    这篇文章主要为大家详细介绍了Android自定义可左右滑动和点击的折线图,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-04-04
  • Android控件系列之CheckBox使用介绍

    Android控件系列之CheckBox使用介绍

    CheckBox和Button一样,也是一种古老的控件,它的优点在于,不用用户去填写具体的信息,只需轻轻点击,缺点在于只有“是”和“否”两种情况,但我们往往利用它的这个特性,来获取用户的一些信息
    2012-11-11
  • 解决Android Studio 代码自动提示突然失效的问题

    解决Android Studio 代码自动提示突然失效的问题

    这篇文章主要介绍了解决Android Studio 代码自动提示突然失效的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-03-03
  • Android RecyclerBarChart绘制使用教程

    Android RecyclerBarChart绘制使用教程

    这篇文章主要为大家介绍了Android RecyclerBarChart绘制使用教程,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • Android Notification的多种用法总结

    Android Notification的多种用法总结

    这篇文章主要介绍了Android Notification的多种用法总结的相关资料,需要的朋友可以参考下
    2017-06-06
  • Android Imageloader的配置的实现代码

    Android Imageloader的配置的实现代码

    这篇文章主要介绍了Android Imageloader的配置的实现代码的相关资料,需要的朋友可以参考下
    2017-07-07
  • Jetpack Compose Canvas绘制超详细介绍

    Jetpack Compose Canvas绘制超详细介绍

    Canvas 是允许您在屏幕上指定区域并在此区域上执行绘制的组件。您必须使用修饰符指定尺寸,无论是通过Modifier.size修饰符指定确切尺寸,还是通过Modifier.fillMaxSize,ColumnScope.weight等相对于父级指定精确尺寸。如果父级包装了此子级,则仅必须指定确切尺寸
    2022-10-10
  • Android实现图片左右滑动效果

    Android实现图片左右滑动效果

    现在滑动效果用的比较多,尤其是在手机端上面,本文介绍了Android实现图片左右滑动效果,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧。
    2016-10-10
  • Android 使用FragmentTabHost实现底部菜单功能

    Android 使用FragmentTabHost实现底部菜单功能

    这篇文章主要介绍了Android 使用FragmentTabHost实现底部菜单功能,详细给大家介绍了FragmentTabHost配合Fragment的使用方法,需要的朋友可以参考下
    2017-12-12
  • Android仿网易云音乐播放界面

    Android仿网易云音乐播放界面

    这篇文章主要为大家详细介绍了Android仿网易云音乐播放界面,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01

最新评论