各位看官们大家好,上一回中咱们说的是Android中自定义ProgressBar的例子,这一回咱们继续说该例子。闲话休提,言归正转。让我们一起Talk Android吧!
看官们,我们在上一回中给进度条修改了颜色,这一回中我们继续给它修改颜色,不过修改的方法不一样了,这一回我们修改的是它的progressDrawable
属性。接下来我们通过文字结合代码的形式来演示。
首先通过AndroidStudio定一个Drawable资源文件,下面是具体的代码,请参考:
<?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 xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle" >
<solid android:color="#993399" />
<stroke
android:width="5dp"
android:color="#119900"/>
<corners android:radius="5dp" />
</shape>
</item>
<item android:id="@android:id/progress">
<clip>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle" >
<solid android:color="#ff8800" />
<corners android:radius="5dp" />
</shape>
</clip>
</item>
</layer-list>
然后把它赋值给progressDrawable属性(这里的diy_drawable就是刚才创建的Drawable文件)::
<com.example.talk8.blogapp05_handler.DIYProgressBar
android:layout_marginTop="20dp"
android:layout_marginLeft="5dp"
android:layout_marginRight="5dp"
android:id="@+id/id_process_bar"
android:max="50"
android:progressDrawable="@drawable/diy_drawable"
android:indeterminate="false"
android:indeterminateOnly="false"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
看官们,我们在上面的代码只列出了修改的内容,其它的代码没有变化,仍然复用原来的代码,因此不再列出。下面是程序的运行结果,请大家参考:
+
从运行结果可以看到进度条的背景是紫色的,这个是solid标签设定的,在其周围有一圈绿色边框,这个是stoke标签设定的,它设定线条的颜色和宽度。这些内容全部放在了第一个item中,正在更新的进度条是在第二个item中设定的,设定的内容和第一个item类似,不同之处在于多了个clip标签,它表示可以移动的内容。这两个item都被包含到了layer-list中了。
看官们,本章回可以看作是上一回的升级版,因为修改的颜色比上一回更加丰富,这主要得益于Drawable资源文件。关于此资源文件的知识比较多,我们就不详细介绍了,因为这部分知识都可以当作一个专题来介绍了,大家感兴趣的话可以参考官方的介绍文档。
各位看官,关于Android中自定义ProgressBar机制的例子咱们就介绍到这里,欲知后面还有什么例子,且听下回分解!