先来看看 ProgressBar 的常用属性:
- android:max:设置 ProgressBar 的最大值,默认是 100。
- android:indeterminate:设置是否开启不确定模式。true 表示进度条会展示实际的进度;而 false 表示在加载时会无限循环展示 loading 动画。
- android:minHeight:设置最小高度。
- android:minWidth:设置最小宽度。
- android:progress:设置进度条的当前进度。
- style:设置进度条的样式,默认情况下展示一个循环转圈的 loading 样式,而如果需要设置其他样式,就要用的 style 属性,比如通过设置style为android:attr/progressBarStyleHorizontal可以设置成横向进度条的样式。
- android:progressDrawable:设置进度条对应的 Drawable 对象的样式
- android:secondaryProgress:设置二级进度条的进度。看视频会有两级进度条,一级是播放进度,二级是缓冲进度。
值得注意的是max和progress属性只有在水平进度的时候才有效,ProgressBar默认是圆形无限循环loading的样式,在圆形样式的情况下,max和progress是无效的。
当然如果想要开发圆形样式并且具有progress进度显示的进度条,也是可以的。只需要按以下步骤:
1、首先我们的目的是想要使圆形的进度条具有水平进度条可以显示进度的功能,因此需要使用style属性将进度条的样式改成水平进度条的样式
style="?android:attr/progressBarStyleHorizontal"
2、有了水平进度条progress和max就有效了,但是还需要修改水平进度条的progressDrawable,让水平进度条显示为圆环形
在res/drawable目录下新建widget_pg_style.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:innerRadiusRatio="3.5" android:shape="ring" android:useLevel="false" android:type="sweep" android:thicknessRatio="12.0"> <solid android:color="@color/widget_track"/> </shape> </item> <item android:id="@android:id/progress"> <rotate android:pivotX="50%" android:pivotY="50%" android:fromDegrees="-90" android:toDegrees="-90"> <shape android:innerRadiusRatio="3.5" android:shape="ring" android:angle="0" android:type="sweep" android:thicknessRatio="12.0"> <solid android:color="#44aa00"/> </shape> </rotate> </item> </layer-list>
设置progressDrawable属性值为widget_pg_style
android:progressDrawable="@drawable/widget_pg_style"
完整的ProgressBar代码,关键就是上述的progressDrawable和style属性
<ProgressBar android:id="@+id/progressbar" android:layout_width="0dp" android:layout_height="50dp" android:layout_weight="1" android:layout_marginRight="15dp" android:max="100" android:progress="50" android:indeterminate="false" android:progressDrawable="@drawable/widget_pg_style" style="?android:attr/progressBarStyleHorizontal" />
完成上述步骤后得到的就是一个可以自由设置进度的圆形进度条了,而不是一直无限加载的圆形加载进度了。