zoukankan      html  css  js  c++  java
  • Androidxml实现帧动画

    使用AnimationDrawable类的API.,可以简单通过XML文件

    列出动画中的所有帧,这种类别动画的XML文件放入工程中的res/anim目录

    在XML文件包含一个<animation-list>根节点元素和好几个子节点<item>来定义每帧。一个资源分别定

    义了帧的名字与帧的持续时间。,下面为范例:

    <animation-list xmlns:android="http://schemas.android.com/apk/res/

    android"

    android:oneshot="true">

    <item android:drawable="@drawable/rocket_thrust1"

    android:duration="200" />

    <item android:drawable="@drawable/rocket_thrust2"

    android:duration="200" />

    <item android:drawable="@drawable/rocket_thrust3"

    android:duration="200" />

    </animation-list>

    这个动画播放三个帧动画,通过设置android:oneshot属性为true,它将会在最后一帧停下来,如果设置

    为false这个动画将循环播放。这个文件保存到工程目录res/anim目录下为rocket_thrust.xml,你也

    可以添加一个背景图片到视图中,然后开始播放。下面为范例:

    AnimationDrawable rocketAnimation;

    public void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);

    setContentView(R.layout.main);

    ImageView rocketImage = (ImageView) findViewById(R.id.rocket_image);

    rocketImage.setBackgroundResource(R.anim.rocket_thrust);

    rocketAnimation = (AnimationDrawable) rocketImage.getBackground();

    }

    public boolean onTouchEvent(MotionEvent event) {

    if (event.getAction() == MotionEvent.ACTION_DOWN) {

    rocketAnimation.start();

    return true;

    }

    return super.onTouchEvent(event);

    }

    一个比较需要特别注意的是,在AnimationDrawable调用onCreate()过程中不能调用start(),这是因

    为AnimationDrawable不能在不完全的窗口上运行,如果你想立即播放动画,没有必要的交互,你可以

    再onWindowFocusChanged()方法中调用它。这样它将成为窗口焦点.

     
  • 相关阅读:
    git的简单操作
    angularjs的基础
    针对IE8透明度设置及一些简单的兼容问题
    sublime 部分常用的快捷键
    Linux简单的操作
    AngularJS 简单的介绍
    html5的viewport与css3的媒体查询
    css的优先级的相关内容
    (转) vmware 切换桥接模式
    从nginx的编译安装,了解编译安装原理(转)
  • 原文地址:https://www.cnblogs.com/crane13/p/3150172.html
Copyright © 2011-2022 走看看