一起Talk Android吧(第四百八十四回:使用逐帧动画实现倒计时效果)

Posted talk_8

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一起Talk Android吧(第四百八十四回:使用逐帧动画实现倒计时效果)相关的知识,希望对你有一定的参考价值。

文章目录


各位看官们大家好,上一回中咱们说的例子是"如何修改Spinner的倒三角",这一回中咱们说的例子是" 使用逐帧动画实现倒计时效果"。闲话休提,言归正转,让我们一起Talk android吧!

概念介绍

我们在前面章回中介绍了各种类型的视图动画,这些动画都可以归类为补间动画,本章回将介绍另外一种视图动画:逐帧动画

逐帧动画类似电影,电影是按照一定的速度依次播放每张胶片中的画面,逐帧动画则是按照一定的速度一帧一帧地播放帧中的内容,进而组成一个完整的动画。我们需要做的是添加帧,以及的控制帧的播放速度。

使用方法

明白逐帧动画的概念后,我们通过文字结合代码的方式来介绍如何使用逐帧动画;

  1. 在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>
  1. 创建一个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>
  1. 在代码中获取ImageView控件以及控件中的动画资源;
  2. 使用动画资源播放动画;
mImageViewFrameAnima = mBinding.idIvFrameAnima;
AnimationDrawable animationDrawable = (AnimationDrawable) mImageViewFrameAnima.getDrawable();
animationDrawable.start();

我们在动画文件中添加了6个属性,每个属性是一张图片,图片的内容从6到1.运行动画就会出现从6到1的倒计时效果,并且动画反复运行。我们在这里就不演示程序的运行结果了,希望大家自己动手去实践。

注意事项

在使用逐帧动画时还有一些细节需要注意,接下来我们详细说明:

  1. <animation-list>标签中的oneshot用来控制动画的播放次数,如果值为true表示只播放一次动画,如果值为false表示无限次地播放动画,默认值为false;
  2. 属性表示动画中的一帧,它的duration表示该帧的播放时间,单位为毫秒;
  3. 代码中逐帧动画的类型为AnimationDrawable类型,在从图片控件中获取动画文件时需要做类型转换;
  4. 逐帧动画与其它视图动画的类型不同,使用方法也不同;

看官们,关于"使用逐帧动画实现倒计时效果"的例子咱们就介绍到这里,欲知后面还有什么例子,且听下回分解!

以上是关于一起Talk Android吧(第四百八十四回:使用逐帧动画实现倒计时效果)的主要内容,如果未能解决你的问题,请参考以下文章

一起Talk Android吧(第四百八十八回:ObjectAnimator)

一起Talk Android吧(第四百八十六回:值动画:ValueAnimator)

一起Talk Android吧(第四百八十九回:如何使用代码实现ObjectAnimator)

一起Talk Android吧(第四百八十回:用代码实现视图动画)

一起Talk Android吧(第四百八十回:用代码实现视图动画)

一起Talk Android吧(第四百八十二回:如何修改Switch的长宽