ProgressBar通过动画定义实现
来源:互联网 发布:java开源微信公众平台 编辑:程序博客网 时间:2024/05/21 16:21
通过动画实现
定义res/anim/loading.xml如下:
<?xml version="1.0" encoding="UTF-8"?>
<animation-list android:oneshot="false"
xmlns:android="http://schemas.android.com/apk/res/android">
<item android:duration="150" android:drawable="@drawable/loading_01" />
<item android:duration="150" android:drawable="@drawable/loading_02" />
<item android:duration="150" android:drawable="@drawable/loading_03" />
<item android:duration="150" android:drawable="@drawable/loading_04" />
<item android:duration="150" android:drawable="@drawable/loading_05" />
<item android:duration="150" android:drawable="@drawable/loading_06" />
<item android:duration="150" android:drawable="@drawable/loading_07" />
</animation-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="@anim/loading" />
二、通过自定义颜色实现
定义res/drawable/dialog_style_xml_color.xml如下:
<?xml version="1.0" encoding="utf-8"?>
<rotate xmlns:android="http://schemas.android.com/apk/res/android"
android:pivotX="50%" android:pivotY="50%" android:fromDegrees="0"
android:toDegrees="360">
<shape android:shape="ring" android:innerRadiusRatio="3"
android:thicknessRatio="8" android:useLevel="false">
<gradient android:type="sweep" android:useLevel="false"
android:startColor="#FFFFFF" android:centerColor="#FFDC35"
android:centerY="0.50" android:endColor="#CE0000" />
</shape>
</rotate>
在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_color" />
三、使用一张图片进行自定义
定义res/drawable/dialog_style_xml_icon.xml如下:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<rotate android:drawable="@drawable/dialog_progress_round"
android:fromDegrees="0.0" android:toDegrees="360.0" android:pivotX="50.0%"
android:pivotY="50.0%" />
</item>
</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 放在对话框中显示出来就完成了。
定义res/anim/loading.xml如下:
<?xml version="1.0" encoding="UTF-8"?>
<animation-list android:oneshot="false"
xmlns:android="http://schemas.android.com/apk/res/android">
<item android:duration="150" android:drawable="@drawable/loading_01" />
<item android:duration="150" android:drawable="@drawable/loading_02" />
<item android:duration="150" android:drawable="@drawable/loading_03" />
<item android:duration="150" android:drawable="@drawable/loading_04" />
<item android:duration="150" android:drawable="@drawable/loading_05" />
<item android:duration="150" android:drawable="@drawable/loading_06" />
<item android:duration="150" android:drawable="@drawable/loading_07" />
</animation-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="@anim/loading" />
二、通过自定义颜色实现
定义res/drawable/dialog_style_xml_color.xml如下:
<?xml version="1.0" encoding="utf-8"?>
<rotate xmlns:android="http://schemas.android.com/apk/res/android"
android:pivotX="50%" android:pivotY="50%" android:fromDegrees="0"
android:toDegrees="360">
<shape android:shape="ring" android:innerRadiusRatio="3"
android:thicknessRatio="8" android:useLevel="false">
<gradient android:type="sweep" android:useLevel="false"
android:startColor="#FFFFFF" android:centerColor="#FFDC35"
android:centerY="0.50" android:endColor="#CE0000" />
</shape>
</rotate>
在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_color" />
三、使用一张图片进行自定义
定义res/drawable/dialog_style_xml_icon.xml如下:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<rotate android:drawable="@drawable/dialog_progress_round"
android:fromDegrees="0.0" android:toDegrees="360.0" android:pivotX="50.0%"
android:pivotY="50.0%" />
</item>
</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 放在对话框中显示出来就完成了。
0 0
- ProgressBar通过动画定义实现
- 通过查看系统的ProgressBar样式来自定义旋转动画
- 使用ProgressBar 实现自定义动画
- android进度条(ProgressBar)实现动画效果
- 使用android frame动画定义自己的ProgressBar
- Fresco加载圆角图片以及定义progressbar动画
- 定义progressbar
- ProgressBar动画
- 通过贝塞尔曲线实现水波纹ProgressBar
- 通过贝塞尔曲线实现水波纹ProgressBar
- 通过定义属性动画资源Property Animation来实现背景色的不断变化
- android利用动画和imageVies实现自定义progressbar效果
- ProgressBar样式的定义
- Android定义圆形ProgressBar
- progressBar定义样式
- custom ProgressBar|动画 旋转
- ProgressBar 漂亮动画
- 通过画图实现动画效果
- Android设置透明效果
- IOS UIPageControl(分页控制器) 用法总结
- iOS开发-UITableView多层详解-UITableview多层级开发
- 看论坛一个帖子带来的震撼--熟悉函数多么重要(glob函数)
- 【模拟+数据结构】UVA 11995 I Can Guess the Data Structure!
- ProgressBar通过动画定义实现
- 从AFX_MANAGE_STATE(AfxGetStaticModuleState())说起
- 获取指定目录及子目录中所有文件列表
- C++中的case标签
- C# 转码
- Eclipse常规设置(我的Style我做主)
- android---xml---include用法(导入另一个XML文件到本布局中)
- Android事件传递机制
- delphi 回调函数与函数指针