Android 自定義水平進度條的圓角進度

有時項目中須要實現水平圓角進度,以下兩種,其實很簡單java

 
 

下面開始看代碼,先從主界面佈局開始看起:android

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center"
    android:orientation="vertical">

    <ProgressBar
        android:id="@+id/progressbar1"
        style="@android:style/Widget.ProgressBar.Horizontal"
        android:layout_width="match_parent"
        android:layout_height="20dp"
        android:layout_margin="10dp"
        android:max="100"
        android:progress="50"
        android:progressDrawable="@drawable/layer_list_progress_drawable_1" />

    <ProgressBar
        android:id="@+id/progressbar2"
        style="@android:style/Widget.ProgressBar.Horizontal"
        android:layout_width="match_parent"
        android:layout_height="20dp"
        android:layout_margin="10dp"
        android:max="100"
        android:progress="20"
        android:progressDrawable="@drawable/layer_list_progress_drawable" />

</LinearLayout>

  

兩個進度條佈局,而後是不一樣的progressDrawable佈局:
layer_list_progress_drawable_1.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"
        android:drawable="@drawable/shape_progressbar_bg" />

    <item android:id="@android:id/progress">
        <clip android:drawable="@drawable/shape_progressbar_progress" />
    </item>
</layer-list>

  

layer_list_progress_drawable.xmlspa

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">

    <item
        android:id="@android:id/background"
        android:drawable="@drawable/shape_progressbar_bg" />

    <item android:id="@android:id/progress">
        <scale
            android:drawable="@drawable/shape_progressbar_progress"
            android:scaleWidth="100%" />
    </item>
</layer-list>

  

從上面兩佈局文件能夠看出,佈局文件基本也是相同的,惟一的區別就是一個用的是clip另外一個用的是scale
若是在layer-list裏面進行設置的話,也是要注意item的添加順序。code

下面是背景,和進度文件:
shape_progressbar_bg.xmlxml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">

    <corners android:radius="10dp" />
    <solid android:color="#dadada" />

</shape>

  

shape_progressbar_progress.xmlblog

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">

    <corners android:radius="10dp" />
    <solid android:color="#0484fa" />

</shape>

  

自定義Android進度條ProgressBar顏色的漸變

自定義Android進度條ProgressBar顏色的漸變其實也很簡單,就拿第一個水平進度來講吧,只須要修改一個layer_list_progress_drawable_1.xmllayer_list_progress_drawable.xml就能夠了
layer_list_progress_drawable_1.xmlip

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">

    <item
        android:id="@android:id/background"
        android:drawable="@drawable/shape_progressbar_bg" />

    <item android:id="@android:id/progress">
        <clip android:drawable="@drawable/shape_progressbar_progress" >
            <shape>
                <corners android:radius="10dp" />
                <!--<gradient-->
                <!--android:startColor="#00FF00"-->
                <!--android:centerColor="#FFFF00"-->
                <!--android:endColor="#FF0000"/>-->
                <!--在gradient這裏設置不一樣的顏色就會產生漸變的效果-->
                <gradient
                    android: startColor ="#0484fa"
                    android: endColor ="#ff00ff" />

            </shape>
        </clip>
    </item>
</layer-list>

  

layer_list_progress_drawable.xmlutf-8

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">

    <item
        android:id="@android:id/background"
        android:drawable="@drawable/shape_progressbar_bg" />

    <item android:id="@android:id/progress">

        <scale
            android:drawable="@drawable/shape_progressbar_progress"
            android:scaleWidth="100%">
            <shape>
                <corners android:radius="10dp" />
                <!--<gradient-->
                <!--android:startColor="#00FF00"-->
                <!--android:centerColor="#FFFF00"-->
                <!--android:endColor="#FF0000"/>-->
                <!--在gradient這裏設置不一樣的顏色就會產生漸變的效果-->

                <gradient
                    android: startColor ="#0484fa"
                    android: endColor ="#ff00ff" />

            </shape>
        </scale>
    </item>
</layer-list>

  

效果以下圖:get


 

參考於:https://www.jianshu.com/p/c8193ba61195

相關文章
相關標籤/搜索