当前位置:   article > 正文

Android ProgressBar控件

android progressbar

1. ProgressBar类

ProgressBar用于显示进度条,进度条有两种不同的样式,旋转和水平,通过设置style来区分。

  • 旋转进度条,有大、中、小三种样式。
    style="?android:attr/progressBarStyleSmall" 
    style="?android:attr/progressBarStyleSmallInverse" 
    style="?android:attr/progressBarStyleSmallTitle" 
    style="?android:attr/progressBarStyleLarge" 
    style="?android:attr/progressBarStyleLargeInverse"
    style="?android:attr/progressBarStyleInverse"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
  • 水平进度条,水平进度条可以设置progresssecondaryProgressmax属性,来显示进度。
    <ProgressBar
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        style="?android:attr/progressBarStyleHorizontal"
        android:max="100"
        android:progress="30"/>
    
    <ProgressBar
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        style="?android:attr/progressBarStyleHorizontal"
        android:max="100"
        android:progress="40"
        android:secondaryProgress="70"/>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    效果如下
    在这里插入图片描述

2. 自定义进度条背景

  • 可以通过设置shape文件来指定进度条背景,需要配置progressDrawable属性
    <ProgressBar
        android:layout_width="match_parent"
        android:layout_height="5dp"
        style="?android:attr/progressBarStyleHorizontal"
        android:max="100"
        android:progress="30"
        android:progressDrawable="@drawable/progress_bar_bg"/>
    
    <ProgressBar
        android:layout_width="match_parent"
        android:layout_height="5dp"
        android:layout_marginTop="5dp"
        style="?android:attr/progressBarStyleHorizontal"
        android:max="100"
        android:progress="40"
        android:secondaryProgress="70"
        android:progressDrawable="@drawable/progress_bar_bg"/>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    progress_bar_bg.xml文件
    <layer-list xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:id="@android:id/background" >
            <shape>
                <solid android:color="#ffffffff" />
            </shape>
        </item>
        <item android:id="@android:id/secondaryProgress" >
            <clip>
                <shape>
                    <solid android:color="#fff84c00" />
                </shape>
            </clip>
        </item>
        <item android:id="@android:id/progress" >
            <clip>
                <shape>
                    <solid android:color="#ffff8c00" />
                </shape>
            </clip>
        </item>
    </layer-list>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    效果如下
    在这里插入图片描述
  • 利用图片指定进度条背景
    <ProgressBar
        android:layout_width="match_parent"
        android:layout_height="10dp"
        style="?android:attr/progressBarStyleHorizontal"
        android:max="100"
        android:progress="30"
        android:progressDrawable="@drawable/progress_bar_star_bg"/>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    progress_bar_star_bg.xml文件
    <layer-list xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:id="@android:id/background" >
            <shape>
                <solid android:color="#ffffffff" />
            </shape>
        </item>
        <item android:id="@android:id/progress"
            android:drawable="@drawable/star" />
    </layer-list>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    效果如下
    在这里插入图片描述
  • 利用indeterminateDrawable属性
    <ProgressBar
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:indeterminateDrawable="@anim/anim_progress_bar"
        android:indeterminateDuration="1000"/>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    anim_progress_bar.xml文件
    <rotate xmlns:android="http://schemas.android.com/apk/res/android"
        android:drawable="@drawable/nav_refresh"
        android:fromDegrees="0"
        android:toDegrees="360"
        android:pivotX="50%"
        android:pivotY="50%" />
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    效果如下
    在这里插入图片描述

相关文章
Android ProgressBar控件
Android SeekBar控件
Android RatingBar控件

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Monodyee/article/detail/461101
推荐阅读
相关标签
  

闽ICP备14008679号