本文以一个简单的小例子,简述在Android开发中,动画的简单应用,仅供学习分享使用。

概述

android提供了各种强大的apis,用于将动画应用到ui元素中,来丰富应用程序的功能和应用。

动画分类

在Android框架中,动画主要分为三类【这三种动画系统都是可行的选择,但一般来说,属性动画系统是首选的使用方法,因为它更灵活,提供了更多的功能】,具体如下:

  • 帧动画:将图像资源按顺序一帧一帧的播放出来,形成动画()。
  • 补间动画:又叫视图动画,是比较旧的系统,只能用于视图组件,相对比较容易设置和提供能力满足程序的需要。
  • 属性动画:在android 3.0(api等级11)中引入的属性动画系统,允许您对任何对象的属性进行动画处理,包括未呈现到屏幕上的属性。该系统是可扩展的,并允许自定义动画类型的属性。

帧动画

将动画资源文件作为图片控件(ImageView)的背景图(background)。

帧动画涉及知识点如下:

  • AnimationDrawable: 用于创建逐帧动画的对象,由一系列可拖动对象,可用作视图对象的背景。
  • isRunning() 是否正在运行
  • stop() 停止动画
  • start() 开始运行

帧动画核心代码

在drawable目录下,新增一个动画资源配置文件【animation-list节点下包含item子节点,item有两个属性,android:drawable=图像资源id,android:duration=周期】,如下:

 <?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/n0" android:duration="300"></item>
<item android:drawable="@drawable/n1" android:duration="300"></item>
<item android:drawable="@drawable/n2" android:duration="300"></item>
<item android:drawable="@drawable/n3" android:duration="300"></item>
<item android:drawable="@drawable/n4" android:duration="300"></item>
<item android:drawable="@drawable/n5" android:duration="300"></item>
<item android:drawable="@drawable/n6" android:duration="300"></item>
<item android:drawable="@drawable/n7" android:duration="300"></item>
<item android:drawable="@drawable/n8" android:duration="300"></item>
<item android:drawable="@drawable/n9" android:duration="300"></item>
</animation-list>

java设置代码如下:

 private AnimationDrawable drawable;

     @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_drawable);
ImageView imageView= (ImageView) this.findViewById(R.id.ivLetter);
drawable= (AnimationDrawable) imageView.getBackground();
drawable.start();
} @Override
public boolean onTouchEvent(MotionEvent event) {
if(event.getAction()==MotionEvent.ACTION_DOWN){
if(drawable.isRunning()) {
drawable.stop();
}else{
drawable.start();
}
}
return super.onTouchEvent(event);
}

补间动画

补间动画,又称渐变动画是指定义起始状态,结束状态,中间状态等,然后其他部分由程序自动生成,从而形成动画。

补间动画涉及知识点如下:

  • TranslateAnimation 平移动画 控制对象位置的动画。
  • RotateAnimation 旋转动画 控制对象旋转的动画。这个旋转需要放置在xy平面上。您可以指定中心要使用的点,其中(0,0)是左上角。如果未指定,则(0,0)为默认旋转点。
  • ScaleAnimation 缩放动画 控制对象的比例尺的动画。您可以指定点用于缩放中心。
  • AlphaAnimation 透明度动画 控制对象的alpha级的动画,通过更改透明度属性,对于对象的淡入淡出,这是一个很有用的方法。
  • AnimationSet 动画集合 上述动画可以组合使用。
  • setFillAfter(true); 设置动画结束后的填充
  • setDuration(2000); 动画周期
  • setRepeatCount(2); 重复次数

  • setRepeatMode(Animation.REVERSE); 重复模式

补间动画核心代码如下:

   /**
* 平移
* @param v
*/
protected void transfer_click(View v){ //参数是平移的起始坐标和结束坐标(起始X轴位置,结束X轴位置,起始Y轴位置,结束Y轴位置)的改变量。
//TranslateAnimation trans=new TranslateAnimation(0.0f,300f,0.0f,300f);
//fromXType 动画平移改变量的类型
//Animation.RELATIVE_TO_SELF,0 表示控件现在的坐标+0*控件本身的宽度或高度
//Animation.RELATIVE_TO_SELF,0.5f 表示控件现在的坐标+0.5*控件本身的宽度或高度
//Animation.RELATIVE_TO_PARENT 相对于父控件,计算方式和Animation.RELATIVE_TO_SELF一样
//fromXValue 起始坐标值的改变量,如果类型是ABSOLUTE,则此值为绝对数字,否则则表示百分比(0-1)之间。
TranslateAnimation trans=new TranslateAnimation(Animation.RELATIVE_TO_SELF,0,Animation.RELATIVE_TO_SELF,1,Animation.RELATIVE_TO_SELF,0,Animation.RELATIVE_TO_SELF,1);
trans.setDuration(2000);//设置周期
trans.setFillAfter(true);//当结束时保持结束位置
trans.setRepeatCount(2);//设置重复次数
trans.setRepeatMode(Animation.REVERSE);//重复模式
ivTaichi.startAnimation(trans);//启动
} /**
* 旋转
* @param v
*/
protected void rotate_click(View v){
//参数是旋转的起始偏移量(度数),结束度数,旋转中心点(相对x轴 位置和y轴位置)。
//RotateAnimation rotate=new RotateAnimation(0.0f,90.f,100.0f,100.0f);
RotateAnimation rotate =new RotateAnimation(0.0f,360.0f,Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF,0.5f);
rotate.setFillAfter(true);
rotate.setDuration(2000);
rotate.setRepeatCount(2);
rotate.setRepeatMode(Animation.REVERSE);
ivTaichi.startAnimation(rotate);//启动
} /**
* 缩放
* @param v
*/
protected void scale_click(View v){
//fromX toX 动画起始和结束时的X轴水平缩放因子
//fromY toY 动画起始和结束时的Y轴水平缩放因子
ScaleAnimation scale=new ScaleAnimation(0.5f,1.5f,0.5f,1.5f);
scale.setFillAfter(true);
scale.setDuration(2000);
scale.setRepeatCount(2);
scale.setRepeatMode(Animation.REVERSE);
ivTaichi.startAnimation(scale);//启动
} /**
* 透明度动画
* @param v
*/
protected void alpha_click(View v){
//fromAlpha toAlpha 动画起始和结束时的透明度。范围(0,1)
AlphaAnimation alpha=new AlphaAnimation(0,1);
alpha.setFillAfter(true);
alpha.setDuration(2000);
alpha.setRepeatCount(2);
alpha.setRepeatMode(Animation.REVERSE);
ivTaichi.startAnimation(alpha);//启动
} /**
* 集合动画
* @param v
*/
protected void set_click(View v){
AnimationSet set=new AnimationSet(true);
//TranslateAnimation animation1=new TranslateAnimation(0.0f,300.0f,0.0f,300.0f);
RotateAnimation animation2 =new RotateAnimation(0.0f,360.0f,Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF,0.5f);
ScaleAnimation animation3=new ScaleAnimation(0.0f,1.0f,0.0f,1.0f);
AlphaAnimation animation4=new AlphaAnimation(0,1);
//set.addAnimation(animation1);
set.addAnimation(animation2);
set.addAnimation(animation3);
set.addAnimation(animation4);
set.setFillAfter(true);
set.setDuration(2000);
set.setRepeatCount(2);
set.setRepeatMode(Animation.REVERSE);
ivTaichi.startAnimation(set);//启动
}

属性动画

属性动画主要通过改变对象的属性,来实现动画,可以进行扩展,且功能丰富。

属性动画涉及知识点如下:

  • ObjectAnimator 该ValueAnimator的子类提供了对目标对象上的动画属性的支持。该类的构造函数使用参数来定义将被动画化的目标对象以及将被动画化的属性的名称。
  • setDuration(2000); 动画周期
  • setRepeatCount(2); 重复次数
  • setRepeatMode(Animation.REVERSE); 重复方式
  • start(); 启动

属性动画核心代码如下:

 /**
* 平移
* @param v
*/
protected void transfer_click(View v){
//target 属性动画的目标控件
//propertyName 产生动画的属性,所有的属性必须拥有set,get方法
//values 属性动画的范围集合
ObjectAnimator objectAnimator =ObjectAnimator.ofFloat(ivTaichi,"translationX",0,200,-200,0);
objectAnimator.setDuration(2000);
objectAnimator.setRepeatCount(2);
objectAnimator.setRepeatMode(Animation.REVERSE);
objectAnimator.start();
} /**
* 旋转
* @param v
*/
protected void rotate_click(View v){
ObjectAnimator objectAnimator =ObjectAnimator.ofFloat(ivTaichi,"rotationX",0,180);
objectAnimator.setDuration(2000);
objectAnimator.setRepeatCount(2);
objectAnimator.setRepeatMode(Animation.REVERSE);
objectAnimator.start();
} /**
* 缩放
* @param v
*/
protected void scale_click(View v){
ObjectAnimator objectAnimator =ObjectAnimator.ofFloat(ivTaichi,"scaleX",0,1,0);
objectAnimator.setDuration(2000);
objectAnimator.setRepeatCount(2);
objectAnimator.setRepeatMode(Animation.REVERSE);
objectAnimator.start();
} /**
* 透明度
* @param v
*/
protected void alpha_click(View v){
ObjectAnimator objectAnimator =ObjectAnimator.ofFloat(ivTaichi,"alpha",0,1);
objectAnimator.setDuration(2000);
objectAnimator.setRepeatCount(2);
objectAnimator.setRepeatMode(Animation.REVERSE);
objectAnimator.start();
} /**
* 集合动画
* @param v
*/
protected void set_click(View v){
AnimatorSet set=new AnimatorSet();
List<Animator> list=new ArrayList<Animator>() ;
ObjectAnimator objectAnimator1 =ObjectAnimator.ofFloat(ivTaichi,"translationX",0,200);
ObjectAnimator objectAnimator2 =ObjectAnimator.ofFloat(ivTaichi,"rotationX",0,180);
ObjectAnimator objectAnimator3 =ObjectAnimator.ofFloat(ivTaichi,"scaleX",0,1);
ObjectAnimator objectAnimator4 =ObjectAnimator.ofFloat(ivTaichi,"alpha",0,1);
list.add(objectAnimator1);
list.add(objectAnimator2);
list.add(objectAnimator3);
list.add(objectAnimator4);
//播放一序列的动画对象
set.playSequentially(list);
//
set.start();
}

备注

学而不思则罔,思而不学则殆!!!

一起学Android之Animation的更多相关文章

  1. Android开发学习之路-该怎么学Android(Service和Activity通信为例)

    在大部分地方,比如书本或者学校和培训机构,教学Android的方式都基本类似,就是告诉先上原理方法,然后对着代码讲一下. 但是,这往往不是一个很好的方法,为什么? ① 学生要掌握这个方法的用途,只能通 ...

  2. 菜鸟学Android编程——简单计算器《一》

    菜鸟瞎搞,高手莫进 本人菜鸟一枚,最近在学Android编程,网上看了一些视频教程,于是想着平时手机上的计算器应该很简单,自己何不尝试着做一个呢? 于是就冒冒失失的开撸了. 简单计算器嘛,功能当然很少 ...

  3. 学Android开发,入门语言java知识点

    学Android开发,入门语言java知识点 Android是一种以Linux为基础的开源码操作系统,主要使用于便携设备,而linux是用c语言和少量汇编语言写成的,如果你想研究Android,就去学 ...

  4. DoNet屌丝学Android(一)——Android开发准备工作 & No HelloWord & (真机)调试

    先乱扯淡一下吧,本人一.net屌丝,手持Android 4.2.2手机,Win7 x64本本,闲来无聊学习一下Android的开发,至于要开发啥玩意目前没有什么想法,就是想学学,搞不好是三分热度也有可 ...

  5. 从头学Android系列

    从头学Android系列 http://blog.csdn.net/worker90/article/category/888358

  6. 学Android开发 这19个开发工具助你顺风顺水

    学Android开发 这19个开发工具助你顺风顺水 要想快速开发一个Android应用,通常会用到很多工具,巧妙利用这些工具,能让我们的开发工作事半功倍,节省大量时间,下面大连Android开发培训小 ...

  7. 一步一步学android控件(之十五) —— DegitalClock & AnalogClock

    原本计划DigitalClock和AnalogClock单独各一篇来写,但是想想,两个控件的作用都一样,就和在一起写一篇了. DegitalClock和AnalogClock控件主要用于显示当前时间信 ...

  8. Android动画Animation之Tween用代码实现动画

    透明度动画.旋转动画.尺寸伸缩动画.移动动画 package com.javen.tween; import android.annotation.SuppressLint; import andro ...

  9. 一步一步学android控件(之十六)—— CheckBox

    根据使用场景不同,有时候使用系统默认的CheckBox样式就可以了,但是有时候就需要自定义CheckBox的样式.今天主要学习如何自定义CheckBox样式.在CheckBox状态改变时有时需要做一些 ...

随机推荐

  1. 使用between操作符过滤数据

    select prod_name,prod_price from products where prod_price between 5 and 10; 就可以查询处5-10之间的所有数据 betwe ...

  2. 这几种JavaScript语法不要轻易使用,容易出事

    文章目录 12种不宜使用的JavaScript语法 1. == 2. with 3. eval 4. continue 5. switch 贯穿 6. 单行的块结构 7. ++和-- 8. 位运算符 ...

  3. vue中子组件直接修改父组件prop属性bug

    在有些时候,子组件直接修改父组件传来的 prop 对象的属性会出现不同步的问题. 比如,父组件传过来的一个对象 checkBoxObj: checkBoxObj:{ checked: false } ...

  4. Task.Factory.StartNew 测试

    到底该用多少线程?线程数.CPU核心数.本地计算时间.等待时间的关系 线程数 = CPU核心数 * ( 本地计算时间 + 等待时间 ) / 本地计算时间 下面是Task.Factory.StartNe ...

  5. Android DSelectorBryant 单选滚动选择器

    单选滚动选择器.diy丰富.有阻尼效果.简单美观.触摸or点击模式 (Rolling Selector, Diy Rich, Damping Effect, Simple and Beautiful, ...

  6. js 日期格式化小问题

    看一个图 toLocaleString 的格式是 yyyy/MM/d , 想要 yyyy/MM/dd, toISOString 的格式基本满足, 本想直接 split("T"),  ...

  7. 1.Ansible自动化管理工具

    1.Ansible基本概述 Ansible是一个IT自动化的配置管理工具,自动化主要体现在Ansible集成了丰富模块,丰富的功能组件, 可以通过一个命令行完成一系列的操作.进而能减少我们重复性的工作 ...

  8. reports buileder 触发器的写法

    触发器写法: function CF_SHOULD_BACK_TIMEFormula return Number is--其他:取MES工时按工段分别统计产量.投入工时合计:应回报工时=移动数量*[∑ ...

  9. Computer: Use the mouse to open the analog keyboard

    Xx_Introduction Please protection,respect,love,"China's Internet Security Act"! For learni ...

  10. LeetCode刷题191122

    博主渣渣一枚,刷刷leetcode给自己瞅瞅,大神们由更好方法还望不吝赐教.题目及解法来自于力扣(LeetCode),传送门. 算法: 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. ...