一起Talk Android吧(第四百八十四回:使用逐帧动画实现倒计时效果)
Posted talk_8
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一起Talk Android吧(第四百八十四回:使用逐帧动画实现倒计时效果)相关的知识,希望对你有一定的参考价值。
文章目录
各位看官们大家好,上一回中咱们说的例子是"如何修改Spinner的倒三角",这一回中咱们说的例子是" 使用逐帧动画实现倒计时效果"。闲话休提,言归正转,让我们一起Talk android吧!
概念介绍
我们在前面章回中介绍了各种类型的视图动画,这些动画都可以归类为补间动画,本章回将介绍另外一种视图动画:逐帧动画。
逐帧动画类似电影,电影是按照一定的速度依次播放每张胶片中的画面,逐帧动画则是按照一定的速度一帧一帧地播放帧中的内容,进而组成一个完整的动画。我们需要做的是添加帧,以及的控制帧的播放速度。
使用方法
明白逐帧动画的概念后,我们通过文字结合代码的方式来介绍如何使用逐帧动画;
- 在drawable目录下创建资源文件fram_anima.xml,该资源文件就是动画文件,文件中使用
<animation-list>
标签和它的item
属性;
<?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/ic_num6" android:duration="1000"></item>
<item android:drawable="@drawable/ic_num5" android:duration="1000"></item>
<item android:drawable="@drawable/ic_num4" android:duration="1000"></item>
<item android:drawable="@drawable/ic_num3" android:duration="1000"></item>
<item android:drawable="@drawable/ic_num2" android:duration="1000"></item>
<item android:drawable="@drawable/ic_num1" android:duration="1000"></item>
</animation-list>
- 创建一个ImageView控件,并且把动画文件赋值给控件的src属性(background属性也可以);
<ImageView
android:id="@+id/id_iv_frame_anima"
android:src="@drawable/frame_anima"
android:layout_width="56dp"
android:layout_height="56dp">
</ImageView>
- 在代码中获取ImageView控件以及控件中的动画资源;
- 使用动画资源播放动画;
mImageViewFrameAnima = mBinding.idIvFrameAnima;
AnimationDrawable animationDrawable = (AnimationDrawable) mImageViewFrameAnima.getDrawable();
animationDrawable.start();
我们在动画文件中添加了6个属性,每个属性是一张图片,图片的内容从6到1.运行动画就会出现从6到1的倒计时效果,并且动画反复运行。我们在这里就不演示程序的运行结果了,希望大家自己动手去实践。
注意事项
在使用逐帧动画时还有一些细节需要注意,接下来我们详细说明:
<animation-list>
标签中的oneshot
用来控制动画的播放次数,如果值为true表示只播放一次动画,如果值为false表示无限次地播放动画,默认值为false;- 属性表示动画中的一帧,它的
duration
表示该帧的播放时间,单位为毫秒; - 代码中逐帧动画的类型为
AnimationDrawable
类型,在从图片控件中获取动画文件时需要做类型转换; - 逐帧动画与其它视图动画的类型不同,使用方法也不同;
看官们,关于"使用逐帧动画实现倒计时效果"的例子咱们就介绍到这里,欲知后面还有什么例子,且听下回分解!
以上是关于一起Talk Android吧(第四百八十四回:使用逐帧动画实现倒计时效果)的主要内容,如果未能解决你的问题,请参考以下文章
一起Talk Android吧(第四百八十八回:ObjectAnimator)
一起Talk Android吧(第四百八十六回:值动画:ValueAnimator)
一起Talk Android吧(第四百八十九回:如何使用代码实现ObjectAnimator)
一起Talk Android吧(第四百八十回:用代码实现视图动画)