Android系统默认的ProgressBar往往都不能满足实际开发需要,一般都会开发者自定义ProgressBar。
在Android开发中,自定义ProgressBar一般有三种思路来完成。
一、在系统进度条基础上优化
首先来看一下style="@android:style/Widget.ProgressBar.Horizontal"的源码。鼠标移动到style属性值上,按住Ctrl键,鼠标左键点击即可打开对应资源文件。
当然也可以直接找到源码文件直接打开进行查看,本地相对路径为sdk\platforms\android-25\data\res\values\styles.xml。打开后可以看到源码如下:
从上述代码可以看到,水平进度条的核心就是android:progressDrawable,接着继续去寻找progress_horizontal的源码(本地相对路径为sdk\platforms\android-25\data\res\drawable\progress_horizontal.xml),如下:
从上述代码可以发现,progress_horizontal一共包括3个item,分别为background、secondProgress、progress,看名字就能知道其大概作用,其中我们比较关心的应该是后两个。
其实把这个文件copy一份到自己的项目下,就可以随心所欲的修改shape属性的圆角、渐变等,实现我们想要的效果了。
由于此处我们还没有学习Drawable资源,所以这里先给大家介绍一下概念,关于具体如何操作可以等学了Drawable资源后,再回过头来自定义ProgressBar。欢迎关注微信公众分享达人秀ShareExpert获取第一手教程,也可添加小编微信jinwenyu2010,然后拽入Android零基础入门技术讨论微信群一同学习。
二、使用动画来代替进度条
使用动画来替代进度条,其实就是使用一套连续图片,形成一个帧动画,当需要进度图的时候,让动画可见,不需要的时候让动画不可见即可。
继续使用WidgetSample工程的advancedviewsample模块,首先在drawable目录下准备一组连续的图片,然后在res/drawable/目录下定义一个myprogressbar.xml的资源文件,代码如下:
<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
android:oneshot="false">
<item android:drawable="@drawable/loading_01" android:duration="200" />
<item android:drawable="@drawable/loading_02" android:duration="200" />
<item android:drawable="@drawable/loading_03" android:duration="200" />
<item android:drawable="@drawable/loading_04" android:duration="200" />
<item android:drawable="@drawable/loading_05" android:duration="200" />
<item android:drawable="@drawable/loading_06" android:duration="200" />
<item android:drawable="@drawable/loading_07" android:duration="200" />
<item android:drawable="@drawable/loading_08" android:duration="200" />
<item android:drawable="@drawable/loading_09" android:duration="200" />
<item android:drawable="@drawable/loading_10" android:duration="200" />
<item android:drawable="@drawable/loading_11" android:duration="200" />
<item android:drawable="@drawable/loading_12" android:duration="200" />
</animation-list>
关于上述代码的具体意义会在Android动画进行讲解,此处大家知道如何操作即可。
接着新建一个布局文件myprogressbar_layout.xml,里面仅仅有一个ImageView即可,用于显示进度条,把src设置为上述drawable资源即可,代码如下:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/mypg_img"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
a