博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android动画效果之Frame Animation(逐帧动画)
阅读量:5915 次
发布时间:2019-06-19

本文共 2050 字,大约阅读时间需要 6 分钟。

前言:

      上一篇介绍了Android的Tween Animation(补间动画) ,今天来总结下Android的另外一种动画Frame Animation(逐帧动画)。

     其他几种动画效果:

Frame Animation(逐帧动画):

       逐帧动画(Frame-by-frame Animations)从字面上理解就是一帧挨着一帧的播放图片,就像放电影一样。和补间动画一样可以通过xml实现也可以通过java代码实现。接下来借助目前项目中的一个开奖的动画来总结如何使用。实现效果如下:

具体实现过程:

1.)在res/drawable目录下一个文件lottery_animlist.xml,内容如下:

根节点是animation-list(动画列表),里面有一个或者多个item节点组成,oneshot属性表示是否只播放一次,true表示只会播放一次,false表示一直循环播放,内部用item节点声明一个动画帧,android:drawable指定此帧动画所对应的图片资源,android:druation代表此帧持续的时间,整数,单位为毫秒。

注意:

   之前使用eclipse或者Android ADT开发的时候,文件可以放在res/anim和res/drawable两个文件夹下面,虽然谷歌推荐放在res/drawable文件夹下但是不会报错,在使用Android studio时候就没那么幸运了,如果不放在res/drawable文件夹下面会报如下错误:

2.)用ImageView控件作为动画载体来显示动画

这个时候我们运行一下,发现动画没有运行而是停留在第一帧,那是因为AnimationDrawable播放动画是依附在window上面的,而在Activity onCreate方法中调用时Window还未初始化完毕,所有才会停留在第一帧,要想实现播放必须在onWindowFocusChanged中添加如下代码:

imageView.setImageResource(R.drawable.lottery_animlist);AnimationDrawable animationDrawable = (AnimationDrawable) imageView.getDrawable();animationDrawable.start();

如果想要停止播放动画可以调用AnimationDrawable的stop方法

imageView.setImageResource(R.drawable.lottery_animlist);  AnimationDrawable animationDrawable = (AnimationDrawable) imageView.getDrawable();  animationDrawable.stop();

3.)纯Java代码实现方式

AnimationDrawable anim = new AnimationDrawable();    for (int i = 1; i <= 6; i++) {    int id = getResources().getIdentifier("lottery_" + i, "mipmap", getPackageName()); Drawable drawable = getResources().getDrawable(id); anim.addFrame(drawable, 200); } anim.setOneShot(false); imageView.setImageDrawable(anim); anim.start();

4.)AnimationDrawable 几个常见的api

  • void start() - 开始播放动画

  • void stop() - 停止播放动画

  • addFrame(Drawable frame, int duration) - 添加一帧,并设置该帧显示的持续时间

  • void setOneShoe(boolean flag) - false为循环播放,true为仅播放一次

  • boolean isRunning() - 是否正在播放

总结:

   Frame Animation(逐帧动画)相对来说比较简单,但是在实际开发中使用的频率还是比较高的。希望以这个小例子能够掌握逐帧动画,但是逐帧动画只能实现比较小的动画效果,如果复杂而且帧数比较多的动画不太建议使用逐帧动画,一方面是因为会造成OOM,另一方面会显得很卡,如果真是超级复杂的动画的话建议选择双缓冲绘制View来实现。

    本文转自 一点点征服   博客园博客,原文链接:http://www.cnblogs.com/ldq2016/p/7228159.html,如需转载请自行联系原作者

你可能感兴趣的文章
微软发布ReactXP:方便开发者构建跨平台应用
查看>>
日本经产省将向地方政府提供“物联网”扶持
查看>>
比尔盖茨:机器人抢人类工作应该交税
查看>>
翻译:The Difference Between SOA and Microservices Isn’t Size
查看>>
下一代5G移动网络的安全挑战
查看>>
Facebook正为Internet.org研发毫米波技术
查看>>
人们需要了解的有关闪存缓存的内容
查看>>
NB-IoT/LoRa/eMTC和蓝牙/WiFi互补效应的几个典型案例
查看>>
北京君正:126.22亿收购两家传感器芯片公司 布局智能生态圈
查看>>
《企业软件交付:敏捷与高效管理精要》——2.4 项目背景
查看>>
《人民的名义》霸屏,如何戏里戏外看安防?
查看>>
Runtime 类
查看>>
亲们,不用再创建变更了
查看>>
华为研发投入首破百亿美元
查看>>
投资1500万美元 思科发力SDS和全闪存存储
查看>>
FBI时隔半年再被打脸 研究者轻松破解iPhone 5C
查看>>
浅谈zwave智能家居与zigBee的区别
查看>>
传统监控结合“视频+” 石化领域玩创新
查看>>
调查显示40%的管理员使用Word文档存储密码
查看>>
联合光伏3000万英镑增持6个英国光伏电站
查看>>