ProgressBar使用详解(进度条动画)
ProgressBar是Android下的进度条,也是为数不多的直接继承于View类的控件,直接子类有AbsSeekBar和ContentLoadingProgressBar,其中AbsSeekBar的子类有SeekBar和RatingBar
ProgressBar的使用注意:
- 1、ProgressBar有两个进度,一个是android:progress,另一个是android:secondaryProgress。后者主要是为缓存需要所涉及的,比如在看网络视频时候都会有一个缓存的进度条以及还要一个播放的进度,在这里缓存的进度就可以是android:secondaryProgress,而播放进度就是android:progress。
- 2、ProgressBar分为确定的和不确定的,上面说的播放进度、缓存等就是确定的。相反地,不确定的就是不清楚、不确定一个操作需要多长时间来完成,这个时候就需要用的不确定的ProgressBar了。这个是由属性android:indeterminate来控制的,如果设置为true的话,那么ProgressBar就可能是圆形的滚动条或者水平的滚动条(由样式决定)。默认情况下,如果是水平进度条,那么就是确定的。
- 3、ProgressBar的样式设定其实有两种方式,在API文档中说明的方式如下:
- Widget.ProgressBar.Horizontal
- Widget.ProgressBar.Small
- Widget.ProgressBar.Large
- Widget.ProgressBar.Inverse
- Widget.ProgressBar.Small.Inverse
- Widget.ProgressBar.Large.Inverse
使用的时候可以这样:style="@android:style/Widget.ProgressBar.Small"。另外还有一种方式就是使用系统的attr,上面的方式是系统的style:
- style="?android:attr/progressBarStyle"
- style="?android:attr/progressBarStyleHorizontal"
- style="?android:attr/progressBarStyleInverse"
- style="?android:attr/progressBarStyleLarge"
- style="?android:attr/progressBarStyleLargeInverse"
- style="?android:attr/progressBarStyleSmall"
- style="?android:attr/progressBarStyleSmallInverse"
- style="?android:attr/progressBarStyleSmallTitle"
ProgressBar几种比较常用的属性:
布局中设置:
android:progress="50"——第一显示进度android:secondaryProgress="80"——第二显示进度android:indeterminate="true"——设置是否精确显示,true表示不精确显示进度,false表示精确显示进度
使用Java代码设置:
setProgress(int) //设置第一进度setSecondaryProgress(int) //设置第二进度getProgress() //获取第一进度getSecondaryProgress() //获取第二进度incrementProgressBy(int) //增加或减少第一进度incrementSecondaryProgressBy(int) //增加或减少第二进度getMax() //获取最大进度
ProgressBar常见的几种样式
- 横向progressBarStyleHorizontal
效果图:
image.png
- 横向Widget.ProgressBar.Horizontal
效果图:
image.png
- 圆形:progressBarStyleLarge
效果图:
image.png
- 圆形:普通
效果图:
image.png
- 圆形:progressBarStyleSmall
效果图:
image.png
自定义进度条修改进度的颜色
在布局文件中的style属性就是设置进度条样式的
实际上面的背景文件是位于@android:style/Widget.ProgressBar.Horizontal,既上面的布局可以写成
查看系统中的水平进度条风格文件
上面的android:progressDrawable属性是设置进度条背景,进入查看
<?xml version="1.0" encoding="utf-8"?> -
-
-
可以看到,上面文件中的3个item标签分别是设置:进度条、第二进度条、第一进度条的背景色。这里我们在drawable文件夹下新建一个pb_pd_sp_blog.xml文件,将上面的代码复制进来,并修改背景色。
<?xml version="1.0" encoding="utf-8"?> -
-
-
image.png
自定义进度条多种属性
我们不但可以修改进度的颜色,也可以修改其他属性我们可以自定义实现如下效果
布局中的属性设置
drawable文件夹下的pb_pd_sp_downloadxml定义
<?xml version="1.0" encoding="utf-8"?> -
-
-
效果图:
image.png
更多相关文章
- android 神奇的android:clipChildren属性
- 识别你的手机 Android的属性系统
- EditText的详细属性说明
- Android C 语言读取系统属性
- Animator记录一次属性动画实现的逐渐出现和逐渐消失的动画
- android textview属性