android 自定义进度条

hqulyc 2014-07-03

4.0以后的进度条变得好细,而且颜色不是很好看。在网上找了一堆资料后,得到一个可行的步骤,记录下来,方便后续使用。

首先,在一开始定义进度条的时候使用的是系统的style。

定义方式如下

<ProgressBar 
       android:id="@+id/pg_build"
       android:layout_width="fill_parent"
       android:layout_height="wrap_content"
	   style="?android:attr/progressBarStyleHorizontal"
       android:visibility="visible"
       />

 这种定义得到的对话框就是最原始的对话框。现在我们要修改进度条的颜色。

步骤如下:

1:在values/styles.xml中添加如下代码

<style name="ProgressBar_Mini" parent="@android:style/Widget.ProgressBar.Horizontal">
        <item name="android:maxHeight">50dip</item>
        <item name="android:minHeight">8dip</item>
        <item name="android:indeterminateOnly">false</item>
        <item name="android:indeterminateDrawable">@android:drawable/progress_indeterminate_horizontal</item>
        <item name="android:progressDrawable">@drawable/progressbar_mini</item>
    </style>

 2:注意最后一行,这一行是控制进度条各种现实的。在res/drawable中添加progressbar_mini.xml。代码内容如下。

<layer-list xmlns:android="http://schemas.android.com/apk/res/android">

<item android:id="@android:id/background">
    <shape>
        <corners android:radius="5dip" />
        <gradient
                android:startColor="#ff9d9e9d"
                android:centerColor="#ff5a5d5a"
                android:centerY="0.75"
                android:endColor="#ff747674"
                android:angle="270"
        />
    </shape>
</item>

<item android:id="@android:id/secondaryProgress">
    <clip>
        <shape>
            <corners android:radius="5dip" />
            <gradient
                    android:startColor="#80ffd300"
                    android:centerColor="#80ffb600"
                    android:centerY="0.75"
                    android:endColor="#a0ffcb00"
                    android:angle="270"
            />
        </shape>
    </clip>
</item>
<item android:id="@android:id/progress">
    <clip>
        <shape>
            <corners
                android:radius="5dip" />
            <gradient
                android:startColor="#aa00ff00"
                android:endColor="#aa00ff00"
                android:angle="270" />
        </shape>
    </clip>
</item>
</layer-list>

 3:在倒数第七行,和倒数第六行的startColor以及endColor设置显示进度条的颜色为绿色。进行到这,修改基本完成。下面看看如何使用。

<ProgressBar 
       android:id="@+id/pg_build"
       android:layout_width="fill_parent"
       android:layout_height="wrap_content"
       style="@style/ProgressBar_Mini"
       android:visibility="visible"
       />

 关键代码在倒数第二行。到这里我们就实现了进度条颜色的修改。

相关推荐