三種ProgressBar的使用

一、普通的ProgressBar
效果圖
普通ProgressBar.png
xml
<ProgressBar
        android:id="@+id/pbNormal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        />
二、有進度的ProgressBar
效果圖
有進度的ProgressBar.png
xml:設(shè)置style,Horizontal
<ProgressBar
       android:id="@+id/progress"
       android:layout_width="match_parent"
       android:layout_height="wrap_content"
       style="@style/Widget.AppCompat.ProgressBar.Horizontal"
       />
設(shè)置進度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文件夾下,創(chuàng)建樣式
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"
        />
設(shè)置進度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();
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 173,523評論 25 708
  • 他是我難過時第一個想訴說的喜悅時第一個想分享的脆弱時第一個會尋找的苦惱時第一個會商量的疲憊時第一個想擁抱的回家時第...
    攝影師柳丁閱讀 264評論 0 1
  • 經(jīng)常有朋友問,買銀行理財產(chǎn)品好還是貨幣基金好?小編的建議是,如果閑置資金高于10萬,可以考慮投一部分資金到銀行理財...
    靜寂夜雨閱讀 320評論 1 4
  • 孩子身上的問題,來源于家長,如果你的孩子有如下表現(xiàn): 1.膽小,不自信 2.懦弱,習(xí)慣看別人臉色行事 3.情緒起伏...
    克萊辛先生閱讀 297評論 0 0