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

简介:

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

一、通过动画实现

定义res/anim/loading.xml如下:
[java]  view plain copy
  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文件中引用如下:
[java]  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="@anim/loading" />  

二、通过自定义颜色实现
定义res/drawable/dialog_style_xml_color.xml如下:
[java]  view plain copy
  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文件中引用如下:
[java]  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_color" />  

三、使用一张图片进行自定义
定义res/drawable/dialog_style_xml_icon.xml如下:
[java]  view plain copy
  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 放在对话框中显示出来就完成了。

  AnimRoundProcessDialog.rar 


截图如下:

相关文章
|
14天前
|
Java API 调度
Android系统 自定义开机广播,禁止后台服务,运行手动安装应用接收开机广播
Android系统 自定义开机广播,禁止后台服务,运行手动安装应用接收开机广播
39 0
|
14天前
|
存储 Java Linux
Android Mstar增加IR 自定义遥控头码完整调试过程
Android Mstar增加IR 自定义遥控头码完整调试过程
26 1
|
14天前
|
Android开发 芯片
Android源代码定制:移除无用lunch|新建lunch|自定义customize.mk
Android源代码定制:移除无用lunch|新建lunch|自定义customize.mk
26 3
|
14天前
|
移动开发 Java Unix
Android系统 自动加载自定义JAR文件
Android系统 自动加载自定义JAR文件
39 1
|
14天前
|
Shell Android开发 开发者
Android系统 自定义动态修改init.custom.rc
Android系统 自定义动态修改init.custom.rc
27 0
|
14天前
|
存储 安全 Android开发
Android系统 自定义系统和应用权限
Android系统 自定义系统和应用权限
26 0
|
25天前
|
XML 数据可视化 Android开发
深入探究Android中的自定义View组件开发
【4月更文挑战第12天】在安卓应用开发中,创建具有独特交互和视觉表现的自定义View组件是增强用户体验的重要手段。本文将详细阐述如何从头开始构建一个Android自定义View,包括理解View的工作原理、处理绘制流程、事件分发机制以及属性的自定义与管理。通过具体案例分析,我们将一步步实现一个可定制的动态进度条,不仅具备基础功能,还能根据业务需求进行扩展,体现高度的产品个性化。
|
Android开发
Android圆形扩展动画
今天学习了一个实现圆形扩展Activity切换动画效果 工具类代码 public class CircularAnimUtil { public static final long PERFECT_MILLS = 618; public static final int MINI_RADIUS = 0; /** * 向四周伸张,直到完成显示。
1425 0
|
14天前
|
消息中间件 网络协议 Java
Android 开发中实现数据传递:广播和Handler
Android 开发中实现数据传递:广播和Handler
16 1
|
4天前
|
存储 安全 Android开发
安卓应用开发:构建一个高效的用户登录系统
【5月更文挑战第3天】在移动应用开发中,用户登录系统的设计与实现是至关重要的一环。对于安卓平台而言,一个高效、安全且用户体验友好的登录系统能够显著提升应用的用户留存率和市场竞争力。本文将探讨在安卓平台上实现用户登录系统的最佳实践,包括对最新身份验证技术的应用、安全性考量以及性能优化策略。