Frame动画像gif画画,通过一些静态的图片,以实现动画效果。

Android sdk该AnimationDrawable就是专门针对Frame动画,当然Frame动画也可在java代码或者xml中写,可是提倡大家还是在xml中写,先上个效果图。

<span style="font-size:18px;"><?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
android:oneshot="false" > <item
android:drawable="@drawable/market_loading_01"
android:duration="100"/>
<item
android:drawable="@drawable/market_loading_02"
android:duration="100"/>
<item
android:drawable="@drawable/market_loading_03"
android:duration="100"/>
<item
android:drawable="@drawable/market_loading_04"
android:duration="100"/>
<item
android:drawable="@drawable/market_loading_05"
android:duration="100"/>
<item
android:drawable="@drawable/market_loading_06"
android:duration="100"/>
<item
android:drawable="@drawable/market_loading_07"
android:duration="100"/>
<item
android:drawable="@drawable/market_loading_08"
android:duration="100"/>
<item
android:drawable="@drawable/market_loading_09"
android:duration="100"/>
<item
android:drawable="@drawable/market_loading_10"
android:duration="100"/>
<item
android:drawable="@drawable/market_loading_11"
android:duration="100"/>
<item
android:drawable="@drawable/market_loading_12"
android:duration="100"/> </animation-list></span>

Frame动画在xml中的根节点是<animation-list>当中的oneshot=false是循环播放,为true的话则播放到最后一张图片就会停止播放,在java中调用

ImageView imageView;
AnimationDrawable animationDrawable; protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
imageView = (ImageView) findViewById(R.id.image);
imageView.setBackgroundResource(R.drawable.drawable_progress);
animationDrawable = (AnimationDrawable) imageView.getBackground();
animationDrawable.start();

由于Frame 动画是有一堆静态图构成的所以,能够当成background。

用java代码写的话

		  AnimationDrawable animationDrawable2 = new AnimationDrawable();
Drawable drawable = getResources().getDrawable(R.drawable.fengjing_1);
Drawable drawable2 = getResources().getDrawable(R.drawable.fengjing_2);
Drawable drawable3 = getResources().getDrawable(R.drawable.fengjing_3);
animationDrawable2.addFrame(drawable, 1000);
animationDrawable2.addFrame(drawable2, 1000);
animationDrawable2.addFrame(drawable3, 1000);
animationDrawable2.setOneShot(false);
imageView.setBackgroundDrawable(animationDrawable2);
animationDrawable2.start();

恩。。就是这样了,Frame 动画了解到这已经差点儿相同了。

项目源代码

版权声明:本文博客原创文章,博客,未经同意,不得转载。

最新文章

  1. SQLServer
  2. PHP中使用CURL请求页面,使用fiddler进行抓包
  3. 用 perl 统计 fasta 文件序列的总长
  4. R语言学习笔记:日期处理
  5. SQL2008 强烈要求限制最大内存
  6. cojs EX_香蕉 题解报告
  7. WPF异步调用WCF服务
  8. 数据类型和Json格式[转]
  9. SDP简要解析
  10. 【百度地图API】如何利用自己的数据制作社交地图?只显示可视区域内的标注
  11. nginx+php-fpm 的配置下,php的错误日志
  12. 4、手把手教你Extjs5(四)主界面上加入顶部和底部区域
  13. ReactiveCocoa源码解析(四) Signal中的静态属性静态方法以及面向协议扩展
  14. UOJ #450「集训队作业2018」复读机
  15. Charles使用心得总结
  16. Extjs6.2 项目学习系列(一)
  17. Envoy 源码分析--buffer
  18. CodeForces 55D &quot;Beautiful numbers&quot;(数位DP+离散化处理)
  19. [转]Ubuntu /home下中文目录如何修改成英文?
  20. Android View体系(四)从源码解析Scroller

热门文章

  1. 【u123】最大子段和
  2. form表单嵌套,用标签的form属性来解决表单嵌套的问题
  3. [E2E] Robot Framework introduction
  4. OpenCV编译步骤
  5. Opencv中integral计算积分图
  6. 【BZOJ 1005】[HNOI2008]明明的烦恼(化简的另一种方法)
  7. matlab 运行 AlexNet
  8. 探险 - 树型dp(背包)/多叉树转二叉树
  9. CodeBlocks 配色方案设置
  10. js判断两个时间段是否有交集