转自:http://blog.csdn.net/aminfo/article/details/7847761

第一步:先上图片素材,以下素材放到res/drawable目录下:

http://blog.csdn.net/aminfo/article/details/7847761

图片素材:                                     

文件名称:icon1.png      icon2.png       icon3.png        icon4.png       icon5.png      icon6.png

第二步:上动画Animation-list帧布局文件,有2个,一个是按顺序显示动画,一个是倒序显示动画,文件存放在res/drawable目录下

顺序显示动画文件:animation1.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!--
  3. 根标签为animation-list,其中oneshot代表着是否只展示一遍,设置为false会不停的循环播放动画
  4. 根标签下,通过item标签对动画中的每一个图片进行声明
  5. android:duration 表示展示所用的该图片的时间长度
  6. -->
  7. <animation-list
  8. xmlns:android="http://schemas.android.com/apk/res/android"
  9. android:oneshot="true"
  10. >
  11. <item android:drawable="@drawable/icon1" android:duration=""></item>
  12. <item android:drawable="@drawable/icon2" android:duration=""></item>
  13. <item android:drawable="@drawable/icon3" android:duration=""></item>
  14. <item android:drawable="@drawable/icon4" android:duration=""></item>
  15. <item android:drawable="@drawable/icon5" android:duration=""></item>
  16. <item android:drawable="@drawable/icon6" android:duration=""></item>
  17. </animation-list>

倒序显示动画文件:animation2.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!--
  3. 根标签为animation-list,其中oneshot代表着是否只展示一遍,设置为false会不停的循环播放动画
  4. 根标签下,通过item标签对动画中的每一个图片进行声明
  5. android:duration 表示展示所用的该图片的时间长度
  6. -->
  7. <animation-list
  8. xmlns:android="http://schemas.android.com/apk/res/android"
  9. android:oneshot="true"
  10. >
  11. <item android:drawable="@drawable/icon6" android:duration=""></item>
  12. <item android:drawable="@drawable/icon5" android:duration=""></item>
  13. <item android:drawable="@drawable/icon4" android:duration=""></item>
  14. <item android:drawable="@drawable/icon3" android:duration=""></item>
  15. <item android:drawable="@drawable/icon2" android:duration=""></item>
  16. <item android:drawable="@drawable/icon1" android:duration=""></item>
  17. </animation-list>

第三步:上布局文件,放在res/layout目录下,文件名main.xml:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:orientation="vertical">
  6.  
  7. <ImageView android:id="@+id/animationIV"
  8. android:layout_width="wrap_content"
  9. android:layout_height="wrap_content"
  10. android:padding="5px"
  11. android:src="@drawable/animation1"/>
  12.  
  13. <Button android:id="@+id/buttonA"
  14. android:layout_width="wrap_content"
  15. android:layout_height="wrap_content"
  16. android:padding="5px"
  17. android:text="顺序显示" />
  18.  
  19. <Button android:id="@+id/buttonB"
  20. android:layout_width="wrap_content"
  21. android:layout_height="wrap_content"
  22. android:padding="5px"
  23. android:text="停止" />
  24.  
  25. <Button android:id="@+id/buttonC"
  26. android:layout_width="wrap_content"
  27. android:layout_height="wrap_content"
  28. android:padding="5px"
  29. android:text="倒序显示" />
  30.  
  31. </LinearLayout>

第四步:上Activity文件,文件名:MainActivity.java

  1. package org.shuxiang.test;
  2.  
  3. import android.app.Activity;
  4. import android.graphics.drawable.AnimationDrawable;
  5.  
  6. import android.os.Bundle;
  7. import android.view.View;
  8. import android.view.View.OnClickListener;
  9. import android.view.Window;
  10. import android.widget.Button;
  11. import android.widget.ImageView;
  12.  
  13. public class Activity10 extends Activity
  14. {
  15. private ImageView animationIV;
  16. private Button buttonA, buttonB, buttonC;
  17. private AnimationDrawable animationDrawable;
  18. @Override
  19. public void onCreate(Bundle savedInstanceState) {
  20. super.onCreate(savedInstanceState);
  21. requestWindowFeature(Window.FEATURE_NO_TITLE);
  22. setContentView(R.layout.test10);
  23.  
  24. animationIV = (ImageView) findViewById(R.id.animationIV);
  25. buttonA = (Button) findViewById(R.id.buttonA);
  26. buttonB = (Button) findViewById(R.id.buttonB);
  27. buttonC = (Button) findViewById(R.id.buttonC);
  28.  
  29. buttonA.setOnClickListener(new OnClickListener()
  30. {
  31. @Override
  32. public void onClick(View v) {
  33. // TODO Auto-generated method stub
  34. animationIV.setImageResource(R.drawable.animation1);
  35. animationDrawable = (AnimationDrawable) animationIV.getDrawable();
  36. animationDrawable.start();
  37. }
  38.  
  39. });
  40.  
  41. buttonB.setOnClickListener(new OnClickListener()
  42. {
  43. @Override
  44. public void onClick(View v) {
  45. // TODO Auto-generated method stub
  46. animationDrawable = (AnimationDrawable) animationIV.getDrawable();
  47. animationDrawable.stop();
  48. }
  49.  
  50. });
  51.  
  52. buttonC.setOnClickListener(new OnClickListener()
  53. {
  54. @Override
  55. public void onClick(View v) {
  56. // TODO Auto-generated method stub
  57. animationIV.setImageResource(R.drawable.animation2);
  58. animationDrawable = (AnimationDrawable) animationIV.getDrawable();
  59. animationDrawable.start();
  60. }
  61. });
  62. }
  63. }

Android 用Animation-list实现逐帧动画 (转载)的更多相关文章

  1. Android中实现一个简单的逐帧动画(附代码下载)

    场景 Android中的逐帧动画,就是由连续的一张张照片组成的动画. 效果 注: 博客: https://blog.csdn.net/badao_liumang_qizhi 关注公众号 霸道的程序猿 ...

  2. 逐帧动画(Frame-by-frame Animations)

    1.这一类动画可以创建一个Drawable序列,这些Drawable可以按照指定的时间间歇一个一个的显示. xml定义方法 <animation-list xmlns:android=" ...

  3. Android动画效果之Frame Animation(逐帧动画)

    前言: 上一篇介绍了Android的Tween Animation(补间动画) Android动画效果之Tween Animation(补间动画),今天来总结下Android的另外一种动画Frame ...

  4. Android笔记(六十三) android中的动画——逐帧动画( frame-by-frame animation)

    就好像演电影一样,播放实现准备好的图片,来实现动画效果. 逐帧动画需要用到AnimationDrawable类,该类主要用于创建一个逐帧动画,然后我们把这个动画设置为view的背景即可. androi ...

  5. Android 逐帧动画isRunning 一直返回true的问题

    AnimationDrawabl主要通过xml实现逐帧动画,SDK实例如下: An AnimationDrawable defined in XML consists of a single < ...

  6. Android简单逐帧动画Frame的实现(三)

    android之动画(三)通过AnimationDrawable控制逐帧动画     android与逐帧动画: 效果图: 当我们点击按钮时,该图片会不停的旋转,当再次点击按钮时,会停止在当前的状态. ...

  7. Android 逐帧动画

    原理: 逐帧动画是最简单的一种动画.原理就是把几张图片连续显示出来,以达到动画的效果.就相当于下面这种手绘翻页动画啦~ 实现: 1.需要建立一个animation-list来设置静态图片资源.持续时间 ...

  8. css3 animation实现逐帧动画

    css3里面的animation属性非常强大,但是自己用的比较少,最近有次面试就刚好被问到了,趁现在有时间就对animation做一个小总结.同时实现一个逐帧动画的demo作为练习 animation ...

  9. animation中的steps()逐帧动画

    在我们平时做宽高确定,需要背景图片切换的效果时,我如果用的是一张大的png图片.而且恰好是所有小图都是从左向右排列的,那么 我们只需测量出某一个小图距左侧有多少像素(x),然后我们banckgroun ...

  10. Android中的动画具体解释系列【1】——逐帧动画

    逐帧动画事实上非常easy,以下我们来看一个样例: <?xml version="1.0" encoding="utf-8"?> <anima ...

随机推荐

  1. 边看chromium的代码,边想骂人...

    这一年一直在看chromium for android的代码,边看边想骂,谷歌这帮人..一开始搞了个牛逼的架构,在安卓4.4上把以前android webkit团队的简单版替换掉了,结果发现性能大不如 ...

  2. 步步为营(十六)搜索(二)BFS 广度优先搜索

    上一篇讲了DFS,那么与之相应的就是BFS.也就是 宽度优先遍历,又称广度优先搜索算法. 首先,让我们回顾一下什么是"深度": 更学术点的说法,能够看做"单位距离下,离起 ...

  3. (转) Universal-Image-Loader使用大全(史上最屌)

    转载自http://blog.csdn.net/zenjj11/article/details/38728481 项目介绍: Android上最让人头疼的莫过于从网络获取图片.显示.回收,不论什么一个 ...

  4. node.js内存泄露问题记录

    先说一下.事情的来龙去脉. 公司开发一款游戏棋牌游戏,服务端的开发是IO密集型,开发的时候,考虑过使用python,java,node.js. 终于选择了node.js(node.js宣传的杀手功能. ...

  5. linux centos7 安装常用软件java,node,mysql,Seafile

    linux centos7 安装常用软件java,node,mysql,Seafile 安装压缩解压缩软件 yum install -y unzip zip 安装git yum install -y ...

  6. 把node加入master节点时,日志内容分析

    root@node1:~# kubeadm --token bggbum.mj3ogzhnm1wz07mj --discovery-token-ca-cert-hash sha256:8f02f833 ...

  7. java8--面向对象 上(疯狂java讲义3) 复习笔记

    1.初始化块总在构造器执行之前被调用 2.静态初始化块用于初始化类,在类初始化阶段被执行 3.如果继承树里的某个类要被初始化时,系统将会同时初始化该类的所有父类 4.一旦程序员为一个类提供了构造器,系 ...

  8. Cluster Mode Overview

    https://spark.apache.org/docs/latest/cluster-overview.html

  9. 常见的页面效果,相关的js代码

    1.焦点图 $(document).ready(function(){ var i=0; var autoChange= setInterval(function(){ if(i<$(" ...

  10. java基础知识一

    1.计算机基础知识概述 (1) 计算机 计算机(computer)俗称电脑,是一种用于高速计算的电子计算机器,可以进行数值计算,又可以进行逻辑计算,还具有存储记忆功能.是能够按照程序运行,自动.高速处 ...