android中的progressbar,ProgressBar使用详解

本文详细介绍了Android中的ProgressBar控件,包括其子类、属性、样式设定及如何自定义颜色和形状。通过设置android:progress、android:secondaryProgress和android:indeterminate属性,可以创建确定或不确定的进度条。此外,通过修改progressDrawable,可以改变进度条的颜色和样式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

style="?android:attr/progressBarStyleHorizontal"

android:layout_width="240dp"

android:layout_height="wrap_content"

android:layout_gravity="center_horizontal"

android:layout_marginTop="10dp"

android:max="100"

android:progress="50" />

效果图:

f613571addb5

image.png

横向Widget.ProgressBar.Horizontal

style="@android:style/Widget.ProgressBar.Horizontal"

android:layout_width="240dp"

android:layout_height="wrap_content"

android:layout_gravity="center_horizontal"

android:layout_marginTop="10dp"

android:max="100"

android:progress="50" />

效果图:

f613571addb5

image.png

圆形:progressBarStyleLarge

android:layout_gravity="center_horizontal"

android:layout_marginTop="10dp"

android:id="@+id/progressBar1"

style="?android:attr/progressBarStyleLarge"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

/>

效果图:

f613571addb5

image.png

圆形:普通

android:layout_marginTop="10dp"

android:id="@+id/progressBar2"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

/>

效果图:

f613571addb5

image.png

圆形:progressBarStyleSmall

android:layout_marginTop="10dp"

android:layout_gravity="center_horizontal"

android:id="@+id/progressBar3"

style="?android:attr/progressBarStyleSmall"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

/>

效果图:

f613571addb5

image.png

自定义进度条修改进度的颜色

在布局文件中的style属性就是设置进度条样式的

style="?android:attr/progressBarStyleHorizontal"

android:layout_width="match_parent"

android:layout_height="wrap_content" />

实际上面的背景文件是位于@android:style/Widget.ProgressBar.Horizontal,既上面的布局可以写成

style="@android:style/Widget.ProgressBar.Horizontal"

android:layout_width="match_parent"

android:layout_height="wrap_content" />

查看系统中的水平进度条风格文件

false

@drawable/progress_horizontal

@drawable/progress_indeterminate_horizontal

20dip

20dip

true

上面的android:progressDrawable属性是设置进度条背景,进入查看

android:startColor="#ff9d9e9d"

android:centerColor="#ff5a5d5a"

android:centerY="0.75"

android:endColor="#ff747674"

android:angle="270"

/>

android:startColor="#80ffd300"

android:centerColor="#80ffb600"

android:centerY="0.75"

android:endColor="#a0ffcb00"

android:angle="270"

/>

android:startColor="#ffffd300"

android:centerColor="#ffffb600"

android:centerY="0.75"

android:endColor="#ffffcb00"

android:angle="270"

/>

可以看到,上面文件中的3个item标签分别是设置:进度条、第二进度条、第一进度条的背景色。这里我们在drawable文件夹下新建一个pb_pd_sp_blog.xml文件,将上面的代码复制进来,并修改背景色。

android:startColor="#ff9d9e9d"

android:centerColor="#ff5a5d5a"

android:centerY="0.75"

android:endColor="#ff747674"

android:angle="270"

/>

android:startColor="#b9a4ff"

android:centerColor="#c6b7ff"

android:centerY="0.75"

android:endColor="#c3b2ff"

android:angle="270"

/>

android:startColor="#57e8ff"

android:centerColor="#74ebff"

android:centerY="0.75"

android:endColor="#8eefff"

android:angle="270"

/>

f613571addb5

image.png

自定义进度条多种属性

我们不但可以修改进度的颜色,也可以修改其他属性我们可以自定义实现如下效果

布局中的属性设置

style="@android:style/Widget.ProgressBar.Horizontal"

android:layout_width="240dp"

android:layout_height="wrap_content"

android:layout_gravity="center_horizontal"

android:layout_marginTop="10dp"

android:max="100"

android:progress="100"

android:maxHeight="12dp"

android:minHeight="12dp"

android:progressDrawable="@drawable/pb_pd_sp_download" />

drawable文件夹下的pb_pd_sp_downloadxml定义

android:color="@color/c_ffffff"

/>

android:height="12dp"

/>

android:width="2dp"

android:color="@color/c_c4e9ff"

/>

android:startColor="#b9a4ff"

android:centerColor="#c6b7ff"

android:centerY="0.75"

android:endColor="#c3b2ff"

android:angle="270"

/>

android:height="12dp"

/>

android:startColor="@color/c_5cacff"

android:centerColor="@color/c_0061dd"

android:endColor="@color/c_0061dd"

android:angle="45"

/>

android:height="12dp"

/>

android:width="2dp"

android:color="@android:color/transparent"

/>

效果图:

f613571addb5

image.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值