一起学Android之Animation
本文以一个简单的小例子,简述在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); 动画周期
- setRepeatMode(Animation.REVERSE); 重复模式
setRepeatCount(2); 重复次数
补间动画核心代码如下:
/**
* 平移
* @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的更多相关文章
- Android开发学习之路-该怎么学Android(Service和Activity通信为例)
在大部分地方,比如书本或者学校和培训机构,教学Android的方式都基本类似,就是告诉先上原理方法,然后对着代码讲一下. 但是,这往往不是一个很好的方法,为什么? ① 学生要掌握这个方法的用途,只能通 ...
- 菜鸟学Android编程——简单计算器《一》
菜鸟瞎搞,高手莫进 本人菜鸟一枚,最近在学Android编程,网上看了一些视频教程,于是想着平时手机上的计算器应该很简单,自己何不尝试着做一个呢? 于是就冒冒失失的开撸了. 简单计算器嘛,功能当然很少 ...
- 学Android开发,入门语言java知识点
学Android开发,入门语言java知识点 Android是一种以Linux为基础的开源码操作系统,主要使用于便携设备,而linux是用c语言和少量汇编语言写成的,如果你想研究Android,就去学 ...
- DoNet屌丝学Android(一)——Android开发准备工作 & No HelloWord & (真机)调试
先乱扯淡一下吧,本人一.net屌丝,手持Android 4.2.2手机,Win7 x64本本,闲来无聊学习一下Android的开发,至于要开发啥玩意目前没有什么想法,就是想学学,搞不好是三分热度也有可 ...
- 从头学Android系列
从头学Android系列 http://blog.csdn.net/worker90/article/category/888358
- 学Android开发 这19个开发工具助你顺风顺水
学Android开发 这19个开发工具助你顺风顺水 要想快速开发一个Android应用,通常会用到很多工具,巧妙利用这些工具,能让我们的开发工作事半功倍,节省大量时间,下面大连Android开发培训小 ...
- 一步一步学android控件(之十五) —— DegitalClock & AnalogClock
原本计划DigitalClock和AnalogClock单独各一篇来写,但是想想,两个控件的作用都一样,就和在一起写一篇了. DegitalClock和AnalogClock控件主要用于显示当前时间信 ...
- Android动画Animation之Tween用代码实现动画
透明度动画.旋转动画.尺寸伸缩动画.移动动画 package com.javen.tween; import android.annotation.SuppressLint; import andro ...
- 一步一步学android控件(之十六)—— CheckBox
根据使用场景不同,有时候使用系统默认的CheckBox样式就可以了,但是有时候就需要自定义CheckBox的样式.今天主要学习如何自定义CheckBox样式.在CheckBox状态改变时有时需要做一些 ...
随机推荐
- CCF-CSP题解 201509-4 高速公路
有点忧愁.\(CSP\)也考\(Tarjan\)缩点的嘛. 原理咱也不明白,咱也不敢学,找到模板就是抄. #include<bits/stdc++.h> const int maxn = ...
- 时间轮算法(TimingWheel)是如何实现的?
前言 我在2. SOFAJRaft源码分析-JRaft的定时任务调度器是怎么做的?这篇文章里已经讲解过时间轮算法在JRaft中是怎么应用的,但是我感觉我并没有讲解清楚这个东西,导致看了这篇文章依然和没 ...
- dev gridcontrol 行号
/// <summary> /// GridView 显示行号 设置行号列的宽度 /// </summary> /// <param name="gv" ...
- html5 websocket 示例,websocket在线聊天,php websocket实例
WebSocket在线测试工具 http://ws.douqq.com/ 1.连接格式为 ws://IP/域名:端口(示例ws://119.29.3.36:5354) 2.对于内网的测试环境,只需填入 ...
- Integer 数值比较
//Integer 源码 private static class IntegerCache { static final int low = -128; sta ...
- python安装pymssql等包时出现microsoft visual c++ 14.0 is required问题无需下载visualcppbuildtools的解决办法
如题,在练习python安装一些包时,出现了microsoft visual c++ 14.0 is required问题.网上有很多资料:一是下载对应的.whl文件,然后pip install安装: ...
- 手写SpringMVC
环境描述 idea java 8 1. POM文件 <?xml version="1.0" encoding="UTF-8"?> <proje ...
- ObjectPool 对象池设计模式
Micosoft.Extension.ObjectPool 源码架构.模式分析: 三大基本对象: ObjectPool抽象类 ObjectPoolProvider抽象类 IPooledObjectPo ...
- iOS核心动画高级技巧 - 6
11. 基于定时器的动画 基于定时器的动画 我可以指导你,但是你必须按照我说的做. -- 骇客帝国 在第10章“缓冲”中,我们研究了CAMediaTimingFunction,它是一个通过控制动画缓冲 ...
- IDEA开发、测试、生产环境pom配置及使用
pom文件 一般放在最下面,project里 <!--开发环境.测试环境.生产环境--> <!--生产环境--> <profiles> <profile> ...