三种ProgressBar的使用

一、普通的ProgressBar
效果图
普通ProgressBar.png
xml
<ProgressBar
        android:id="@+id/pbNormal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        />
二、有进度的ProgressBar
效果图
有进度的ProgressBar.png
xml:设置style,Horizontal
<ProgressBar
       android:id="@+id/progress"
       android:layout_width="match_parent"
       android:layout_height="wrap_content"
       style="@style/Widget.AppCompat.ProgressBar.Horizontal"
       />
设置进度java文件
        final ProgressBar  bar= (ProgressBar) findViewById(R.id.progress);
        final TextView textView= (TextView) findViewById(R.id.tvProgress);
        new Thread(){
            @Override
            public void run() {
                int i=0;
                while(i<100){
                    i++;
                    try {
                        Thread.sleep(80);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    final int j=i;
                    bar.setProgress(i);
                    runOnUiThread(new Runnable() {
                        @Override
                        public void run() {
                            textView.setText(j+"%");
                        }
                    });
                }
            }
        }.start();
三、自定义有进度ProgressBar
效果图

自定义进度有ProgressBar.png

progressBar进度条有两个部分组成,背景图形加载进度图形,使用<layer-list>标签,分别用backgroundprogress作为两个部分的id值,背景图形使用<shape>加载进度图形还需要用<clip>标签对图形<shape>标签进行包裹;

res下的drawable文件夹下,创建样式
custom_progress.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">
        <shape android:shape="rectangle">
        <corners android:radius="5dp"/>
        <gradient android:startColor="#fff"
                  android:endColor="#fff"/>
        </shape>
    </item>
    <item android:id="@android:id/progress">
        <clip><!--可裁剪对象-->
            <shape android:shape="rectangle">
            <corners android:radius="5dp"/>
            <gradient android:angle="45" 
                      android:startColor="#f00"
                      android:endColor="#f90"/>
            </shape>
        </clip>
    </item>
</layer-list>
布局xml,需要指定ProgressBar的style
    <ProgressBar
        android:id="@+id/progressSelf"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        style="@style/Widget.AppCompat.ProgressBar.Horizontal"
        android:progressDrawable="@drawable/custom_progress"
        />
    <TextView
        android:id="@+id/tvProgress"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        />
设置进度java文件
        final ProgressBar bar = (ProgressBar) findViewById(R.id.progressSelf);
        final TextView textView= (TextView) findViewById(R.id.tvProgress);
        new Thread(){
            @Override
            public void run() {
                int i=0;
                while(i<100){
                    i++;
                    try {
                        Thread.sleep(80);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    final int j=i;
                    bar.setProgress(i);
                    runOnUiThread(new Runnable() {
                        @Override
                        public void run() {
                            textView.setText(j+"%");
                        }
                    });
                }
            }
        }.start();
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,545评论 25 709
  • 他是我难过时第一个想诉说的喜悦时第一个想分享的脆弱时第一个会寻找的苦恼时第一个会商量的疲惫时第一个想拥抱的回家时第...
    摄影师柳丁阅读 1,755评论 0 1
  • 经常有朋友问,买银行理财产品好还是货币基金好?小编的建议是,如果闲置资金高于10万,可以考虑投一部分资金到银行理财...
    靜寂夜雨阅读 2,435评论 1 4
  • 孩子身上的问题,来源于家长,如果你的孩子有如下表现: 1.胆小,不自信 2.懦弱,习惯看别人脸色行事 3.情绪起伏...
    克莱辛先生阅读 2,187评论 0 0