Android动画-帧动画

简介:

Android 平台提供了两种动画一种是 Frame动画,即顺序的播放事先做好的图像,与gif图片或者说跟放电影的原理相似,另一种是Tween动画,就是对场景里的对象不断的进行图像变化来产生动画效果(旋转、平移、放缩和渐变),本文中是是介绍第一种帧动画的的实现,帧动画是一种常见的动画形式(Frame By Frame),其原理是在“连续的关键帧”中分解动画动作,也就是在时间轴的每帧上逐帧绘制不同的内容,使其连续播放而成动画。 因为逐帧动画的帧序列内容不一样,不但给制作增加了负担而且最终输出的文件量也很大,但它的优势也很明显:逐帧动画具有非常大的灵活性,几乎可以表现任何想表现的内容,而它类似与电影的播放模式,很适合于表演细腻的动画。

布局文件

首先在res中新建一个drawable文件夹,将需要展示的图片放在里面,同样的还有展示图片的fight.xml文件,代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
<?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/fight_1"
         android:duration= "200" />
     <item
         android:drawable= "@drawable/fight_2"
         android:duration= "200" />
     <item
         android:drawable= "@drawable/fight_3"
         android:duration= "200" />
     <item
         android:drawable= "@drawable/fight_4"
         android:duration= "200" />
     <item
         android:drawable= "@drawable/fight_5"
         android:duration= "200" />
     <item
         android:drawable= "@drawable/fight_6"
         android:duration= "200" />
     <item
         android:drawable= "@drawable/fight_7"
         android:duration= "200" />
     <item
         android:drawable= "@drawable/fight_8"
         android:duration= "200" />
     <item
         android:drawable= "@drawable/fight_9"
         android:duration= "200" />
     <item
         android:drawable= "@drawable/fight_10"
         android:duration= "200" />
     <item
         android:drawable= "@drawable/fight_11"
         android:duration= "200" />
 
</animation-list>

 文件夹的布局:

 

Demo实现

MainActivity定义一个ImageView,oncreate中调用:

1
2
3
ImageView fightImage = (ImageView) findViewById(R.id.image_aniation);
      fightImage.setBackgroundResource(R.drawable.fight);
      fightnimation = (AnimationDrawable) fightImage.getBackground();

不能加载的时候立即调用,需要在触摸的时候调用:

1
2
3
4
5
6
7
public  boolean  onTouchEvent(MotionEvent event) {
      if  (event.getAction() == MotionEvent.ACTION_DOWN) {
          fightnimation.start();
        return  true ;
      }
      return  super .onTouchEvent(event);
    }

 效果如下:

本文转自Fly_Elephant博客园博客,原文链接:http://www.cnblogs.com/xiaofeixiang/p/4101548.html,如需转载请自行联系原作者

相关文章
|
7天前
|
Java Android开发 开发者
Android10 修改开发者选项中动画缩放默认值
Android10 修改开发者选项中动画缩放默认值
15 0
|
7天前
|
XML Java Android开发
android的三种动画
android的三种动画
15 0
|
5天前
|
数据库 Android开发
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
|
7天前
|
Java Android开发
Android 开机动画的启动
Android 开机动画的启动
17 0
|
7天前
|
Java Android开发
Android Mediatek 延迟停止启动动画和通知SurfaceFlinger(Android正在启动)
Android Mediatek 延迟停止启动动画和通知SurfaceFlinger(Android正在启动)
13 0
|
7天前
|
Java Android开发
Android开发之使用OpenGL实现翻书动画
本文讲述了如何使用OpenGL实现更平滑、逼真的电子书翻页动画,以解决传统贝塞尔曲线方法存在的卡顿和阴影问题。作者分享了一个改造后的外国代码示例,提供了从前往后和从后往前的翻页效果动图。文章附带了`GlTurnActivity`的Java代码片段,展示如何加载和显示书籍图片。完整工程代码可在作者的GitHub找到:https://github.com/aqi00/note/tree/master/ExmOpenGL。
40 1
Android开发之使用OpenGL实现翻书动画
|
7天前
|
XML 开发工具 Android开发
Android动画效果-更新中
Android动画效果-更新中
60 1
|
7天前
|
XML Android开发 数据格式
[Android]动画
[Android]动画
38 0
|
7天前
|
API Android开发 开发者
【Android App】Vulkan实现宇宙中旋转雷达动画效果(附源码和原始视频 超详细必看)
【Android App】Vulkan实现宇宙中旋转雷达动画效果(附源码和原始视频 超详细必看)
79 1
|
7天前
|
XML 小程序 Java
【Android App】给三维魔方贴图以及旋转动画讲解和实战(附源码和演示视频 超详细必看)
【Android App】给三维魔方贴图以及旋转动画讲解和实战(附源码和演示视频 超详细必看)
37 0