有時項目中須要實現水平圓角進度,以下兩種,其實很簡單java
![](http://static.javashuo.com/static/loading.gif)
下面開始看代碼,先從主界面佈局開始看起: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.xml
和layer_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
![](http://static.javashuo.com/static/loading.gif)
參考於:https://www.jianshu.com/p/c8193ba61195