1. 程式人生 > >Android 三種方式實現自定義圓形頁面載入中效果的進度條

Android 三種方式實現自定義圓形頁面載入中效果的進度條

一、通過動畫實現

定義res/anim/loading.xml如下:
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <animation-list android:oneshot="false"
  3. xmlns:android="http://schemas.android.com/apk/res/android">  
  4.   <item android:duration="150" android:drawable="@drawable/loading_01" />  
  5.   <item android:duration="150" android:drawable=
    "@drawable/loading_02" />  
  6.   <item android:duration="150" android:drawable="@drawable/loading_03" />  
  7.   <item android:duration="150" android:drawable="@drawable/loading_04" />  
  8.   <item android:duration="150" android:drawable="@drawable/loading_05" />  
  9.   <item android:duration="150" android:drawable=
    "@drawable/loading_06" />  
  10.   <item android:duration="150" android:drawable="@drawable/loading_07" />  
  11. </animation-list>   

在layout檔案中引用如下:
  1. <ProgressBar android:id="@+id/loading_process_dialog_progressBar"
  2.   android:layout_width="wrap_content" android:layout_height="wrap_content"
  3.   android:indeterminate="false"
     android:indeterminateDrawable="@anim/loading" />  

二、通過自定義顏色實現
定義res/drawable/dialog_style_xml_color.xml如下:
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <rotate xmlns:android="http://schemas.android.com/apk/res/android"
  3.   android:pivotX="50%" android:pivotY="50%" android:fromDegrees="0"
  4.   android:toDegrees="360">  
  5.   <shape android:shape="ring" android:innerRadiusRatio="3"
  6.     android:thicknessRatio="8" android:useLevel="false">  
  7.     <gradient android:type="sweep" android:useLevel="false"
  8.      android:startColor="#FFFFFF" android:centerColor="#FFDC35"
  9.      android:centerY="0.50" android:endColor="#CE0000" />  
  10.   </shape>  
  11. </rotate>  

在layout檔案中引用如下:
  1. <ProgressBar android:id="@+id/loading_process_dialog_progressBar"
  2.   android:layout_width="wrap_content" android:layout_height="wrap_content"
  3.   android:indeterminate="false" android:indeterminateDrawable="@drawable/dialog_style_xml_color" />  

三、使用一張圖片進行自定義
定義res/drawable/dialog_style_xml_icon.xml如下:
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <layer-list xmlns:android="http://schemas.android.com/apk/res/android">  
  3. <item>  
  4.   <rotate android:drawable="@drawable/dialog_progress_round"
  5.    android:fromDegrees="0.0" android:toDegrees="360.0" android:pivotX="50.0%"
  6.    android:pivotY="50.0%" />  
  7. </item>  
  8. </layer-list>  

在layout檔案中引用如下:

<ProgressBar android:id="@+id/loading_process_dialog_progressBar"  
  android:layout_width="wrap_content" android:layout_height="wrap_content"  
  android:indeterminate="false" android:indeterminateDrawable="@drawable/dialog_style_xml_icon" /> 

main.xml如下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="fill_parent"
android:layout_height="fill_parent" android:gravity="center"
android:background="#FFF">
<Button android:text="@string/anim" android:id="@+id/anim"
  android:layout_width="120dip" android:layout_height="wrap_content" />
<Button android:text="@string/color" android:id="@+id/color"
  android:layout_width="120dip" android:layout_height="wrap_content" />
<Button android:text="@string/icon" android:id="@+id/icon"
  android:layout_width="120dip" android:layout_height="wrap_content" />
</LinearLayout>

之後通過三個按鈕將ProgressBar 放在對話方塊中顯示出來就完成了。

截圖如下: