转载

转载 :http://gundumw100.iteye.com/blog/1289348



自定义ProgressBar的加载效果

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

To get a ProgressBar in the default theme that is to be used on white/light back ground, use one of the inverse styles: 
<ProgressBar style="@android:style/Widget.ProgressBar.Inverse"/> 
<ProgressBar style="@android:style/Widget.ProgressBar.Large.Inverse"/> 
<ProgressBar style="@android:style/Widget.ProgressBar.Small.Inverse"/> 

进度条 
Xml代码   收藏代码
  1. <ProgressBar android:layout_width="fill_parent" android:layout_height="wrap_content" style="?android:attr/progressBarStyleHorizontal"  />  

一、通过动画实现 
定义res/anim/loading.xml如下: 
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文件中引用如下: 
Xml代码   收藏代码
  1. <ProgressBar  
  2.   android:layout_width="wrap_content"   
  3. android:layout_height="wrap_content"  
  4.   android:indeterminate="false"   
  5. android:indeterminateDrawable="@anim/loading" />  


二、通过自定义颜色实现 
定义res/drawable/dialog_style_xml_color.xml如下: 
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文件中引用如下: 
Xml代码   收藏代码
  1. <ProgressBar  
  2.   android:layout_width="wrap_content"   
  3. android:layout_height="wrap_content"  
  4.   android:indeterminate="false" android:indeterminateDrawable="@drawable/dialog_style_xml_color" />  


三、使用一张图片进行自定义 
定义res/drawable/dialog_style_xml_icon.xml如下: 
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"   
  6. android:toDegrees="360.0"   
  7. android:pivotX="50.0%"  
  8.    android:pivotY="50.0%" />  
  9. </item>  
  10. </layer-list>  


在layout文件中引用如下: 
Xml代码   收藏代码
  1. <ProgressBar  
  2.   android:layout_width="wrap_content"   
  3. android:layout_height="wrap_content"  
  4.   android:indeterminate="false" android:indeterminateDrawable="@drawable/dialog_style_xml_icon" />  


或者使用<animated-rotate/>旋转一张图片: 
Xml代码   收藏代码
  1. <ProgressBar    
  2.         style="@android:style/Widget.ProgressBar"    
  3.         android:layout_width="wrap_content"    
  4.         android:layout_height="wrap_content"    
  5.         android:indeterminateDrawable="@drawable/custom_progress_draw"    
  6.         android:indeterminate="false" />  

custom_progress_draw.xml: 
Xml代码   收藏代码
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <animated-rotate xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:drawable="@drawable/circular"  
  4.     android:pivotX="50%"  
  5.     android:pivotY="50%" />  

circular就是一张转动效果的静态图片。 

main.xml如下: 
Xml代码   收藏代码
  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>  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值