Android 三种方式实现自定义圆形页面加载中效果的进度条

转载:http://www.eoeandroid.com/forum.php?mod=viewthread&tid=76872

一、通过动画实现

定义res/anim/loading.xml如下:
[java]  view plain copy
  1. "1.0" encoding="UTF-8"?>  
  2. "false"  
  3. xmlns:android="http://schemas.android.com/apk/res/android">  
  4.   "150" android:drawable="@drawable/loading_01" />  
  5.   "150" android:drawable="@drawable/loading_02" />  
  6.   "150" android:drawable="@drawable/loading_03" />  
  7.   "150" android:drawable="@drawable/loading_04" />  
  8.   "150" android:drawable="@drawable/loading_05" />  
  9.   "150" android:drawable="@drawable/loading_06" />  
  10.   "150" android:drawable="@drawable/loading_07" />  
  11.    

在layout文件中引用如下:
[java]  view plain copy
  1. "@+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如下:
[java]  view plain copy
  1. "1.0" encoding="utf-8"?>  
  2. "http://schemas.android.com/apk/res/android"  
  3.   android:pivotX="50%" android:pivotY="50%" android:fromDegrees="0"  
  4.   android:toDegrees="360">  
  5.   "ring" android:innerRadiusRatio="3"  
  6.     android:thicknessRatio="8" android:useLevel="false">  
  7.     "sweep" android:useLevel="false"  
  8.      android:startColor="#FFFFFF" android:centerColor="#FFDC35"  
  9.      android:centerY="0.50" android:endColor="#CE0000" />  
  10.     
  11.   

在layout文件中引用如下:
[java]  view plain copy
  1. "@+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如下:
[java]  view plain copy
  1. "1.0" encoding="utf-8"?>  
  2. "http://schemas.android.com/apk/res/android">  
  3.   
  4.   "@drawable/dialog_progress_round"  
  5.    android:fromDegrees="0.0" android:toDegrees="360.0" android:pivotX="50.0%"  
  6.    android:pivotY="50.0%" />  
  7.   
  8.   

在layout文件中引用如下:

[html] view plain copy
  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_icon" />   

main.xml如下:

[html] view plain copy
  1. xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3. android:orientation="vertical" android:layout_width="fill_parent"  
  4. android:layout_height="fill_parent" android:gravity="center"  
  5. android:background="#FFF">  
  6. <Button android:text="@string/anim" android:id="@+id/anim"  
  7.   android:layout_width="120dip" android:layout_height="wrap_content" />  
  8. <Button android:text="@string/color" android:id="@+id/color"  
  9.   android:layout_width="120dip" android:layout_height="wrap_content" />  
  10. <Button android:text="@string/icon" android:id="@+id/icon"  
  11.   android:layout_width="120dip" android:layout_height="wrap_content" />  
  12. LinearLayout> 


之后通过三个按钮将ProgressBar 放在对话框中显示出来就完成了。

  AnimRoundProcessDialog.rar 
截图如下:

你可能感兴趣的:(android开发)