欢迎访问移动开发之家(rcyd.net),关注移动开发教程。移动开发之家  移动开发问答|  每日更新
页面位置 : > > > 内容正文

Android实现圆形ProgressBar停止转动的方法详解,

来源: 开发者 投稿于  被查看 10021 次 评论:235

Android实现圆形ProgressBar停止转动的方法详解,


先来看看 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"
            />

完成上述步骤后得到的就是一个可以自由设置进度的圆形进度条了,而不是一直无限加载的圆形加载进度了。

到此这篇关于Android实现圆形ProgressBar停止转动的方法详解的文章就介绍到这了,更多相关Android ProgressBar停止转动内容请搜索3672js教程以前的文章或继续浏览下面的相关文章希望大家以后多多支持3672js教程!

您可能感兴趣的文章:
  • Android开发基础使用ProgressBar加载进度条示例
  • Android ProgressBar组件使用教程
  • android实现简单进度条ProgressBar效果
  • Android ProgressBar实现进度条效果
  • Android ProgressBar 模拟进度条效果的实现
  • Android自定义控件实现圆形进度CircleProgressBar
  • Android自定义带动画效果的圆形ProgressBar

用户评论