一、属性动画

  • ObjectAnimator

    ObjectAnimator是属性动画框架中最重要的实行类,创建一个ObjectAnimator只需通过他的静态工厂类直接返回一个ObjectAnimator对象。参数包括一个对象和对象的属性名字,但这个属性必须有get和set函数,内部会通过JAVA反射机制来调用set函数修改属性值,同样,你也可以调用setInterpolator设置相信的差值器。

    例子:实现平移动画:

      /**
* view:需要实现动画效果的view
* "translationX":需要什么动画
* 300:可变参数数组,需要传进改属性的一个取值过程
*/
ObjectAnimator animator=ObjectAnimator.ofFloat(view,"translationX",300);
animator.setDuration(2000);
animator.start();

    使用ObjectAnimator的时候,操纵的属性必须要有get和set方法,但是一般内部都会自己创建。

    下面是一些常用的可以直接使用属性动画的属性值:

      translationX和translationY:这连个属性为平移,从view左上角坐标开始位置

      rotation、rotationX和rotationY:围绕支点2D和3D旋转

      scaleX和 scaleY:围绕支点2D缩放

      pivotX和pivoY:这个是控制支点位置,支点控制着旋转和缩放,默认为view中点为支点

      x和y:View最终位置,它是最初是view左上角坐标和translationX、translationY值的累积和

      alpha:透明度,默认为1(不透明),0位完全透明。

  • PropertyValuesHolder

    类似视图动画中的AnimationSet

    例子:

     /**
* view将先缩小,透明度慢慢变为0,在慢慢放大,透明度变为1
*/
PropertyValuesHolder pvh1 = PropertyValuesHolder.ofFloat("scaleX", 1f, 0f, 1f);
PropertyValuesHolder pvh2 = PropertyValuesHolder.ofFloat("scaleY", 1f, 0f, 1f);
PropertyValuesHolder pvh3 = PropertyValuesHolder.ofFloat("alpha",1f, 0f, 1f);
ObjectAnimator.ofPropertyValuesHolder(view, pvh1, pvh2, pvh3).setDuration(4000).start();
  • ValueAnimtor

    属性动画的核心所在,ObjectAnimator继承于它

 ValueAnimator animator = ValueAnimator.ofFloat(0, 1);
animator.setTarget(view);
animator.setDuration(2000).start();
animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator valueAnimator) {
Float value = (Float) valueAnimator.getAnimatedValue();//拿到value然后进行操作 value由0-->1
view.setAlpha(value);
}
});
  • 动画监听
 ObjectAnimator animator = ObjectAnimator.ofFloat(imageView, "alpha",1f, 0f, 1f);
animator.addListener(new Animator.AnimatorListener() {
@Override
public void onAnimationStart(Animator animator) { } @Override
public void onAnimationEnd(Animator animator) { } @Override
public void onAnimationCancel(Animator animator) { } @Override
public void onAnimationRepeat(Animator animator) { }
}); animator.start();

    我们一般只用到end这个方法,android提供了另外一个方法:

animator.addListener(new AnimatorListenerAdapter() {
@Override
public void onAnimationEnd(Animator animation) {
super.onAnimationEnd(animation);
}
});
  • Animatorset

    对于一个属性同时作用多个属性动画效果,前面已经用PropetryValuesHolder实现了这样的效果。而AnimatorSet不仅能实现这样的效果,同时也能实现更为精确的顺序控制。

     ObjectAnimator animator1 = ObjectAnimator.ofFloat(imageView, "scaleX", 1f, 0f, 1f);
ObjectAnimator animator2 = ObjectAnimator.ofFloat(imageView, "scaleY", 1f, 0f, 1f);
ObjectAnimator animator3 = ObjectAnimator.ofFloat(imageView, "alpha", 1f, 0f, 1f); AnimatorSet set = new AnimatorSet();
set.setDuration(2000);
set.playTogether(animator1, animator2, animator3);//顺序依次是1-->2-->3
set.start();

    在AnimatorSet正是通过playTogether()、playSequentially()、animSet.play().with()、defore()、after()这些方法来控制多个动画的协同工作方式,从而做到对动画播放顺序的精确控制。

  • 在xml中使用属性动画

    在res文件中创建文件夹:animator,在这个文件夹里面创建objectAnimator资源文件

<?xml version="1.0" encoding="utf-8"?>
<objectAnimator xmlns:android="http://schemas.android.com/apk/res/android"
android:duration="1000"
android:propertyName="scaleX"
android:valueFrom="1.0"
android:valueTo="2.0"
android:valueType="floatType"> </objectAnimator>
  Animator animator = AnimatorInflater.loadAnimator(this, R.animator.test);
animator.setTarget(view);
animator.start();
  • view的animate方法

    animate方法可以理解为属性动画的一种简写方式

        view.animate().alpha(0).y(300).setDuration(300).withStartAction(new Runnable() {
@Override
public void run() { }
}).withEndAction(new Runnable() {
@Override
public void run() {
runOnUiThread(new Runnable() {
@Override
public void run() { }
});
}
}).start();

二、布局动画

   所谓的布局动画是指作用的ViewGroup上,给ViewGroup增加子View时添加一个动画过度效果。

   在ViewGroup的xml中添加和这个属性:

android:animateLayoutChanges="true"

   这个效果是android默认的显示的过度效果,我们无法自定义,需要自在定义的过度效果则需要使用LayoutAnimationController类来自定义一个。

     /**
* 第一个参数:需要作用的时间
* 第二个参数:每个子view显示的delay时间
* 当第二个参数不为0的时候可以设置View的显示顺序:
* LayoutAnimationController.ORDER_NORMAL:顺序
* LayoutAnimationController.ORDER_RANDOM:随机
* LayoutAnimationController.ORDER_REVERSE:反序
*
*/
AlphaAnimation animation = new AlphaAnimation(0, 1);
animation.setDuration(2000);
LayoutAnimationController lac=new LayoutAnimationController(animation);
lac.setOrder(LayoutAnimationController.ORDER_REVERSE);
rl.setLayoutAnimation(lac);

  xml中设置:

android 属性动画和布局动画p165-p171的更多相关文章

  1. Android动画效果之自定义ViewGroup添加布局动画

    前言: 前面几篇文章介绍了补间动画.逐帧动画.属性动画,大部分都是针对View来实现的动画,那么该如何为了一个ViewGroup添加动画呢?今天结合自定义ViewGroup来学习一下布局动画.本文将通 ...

  2. 自定义ViewGroup添加布局动画

    声明几个属性值: <declare-styleable name="GridImageViewGroup"> <attr name="childVert ...

  3. Android动画:模拟开关按钮点击打开动画(属性动画之平移动画)

    在Android里面,一些炫酷的动画确实是很吸引人的地方,让然看了就赏心悦目,一个好看的动画可能会提高用户对软件的使用率.另外说到动画,在Android里面支持3种动画: 逐帧动画(Frame Ani ...

  4. Android中的布局动画

    简介 布局动画是给布局的动画,会影响到布局中子对象 使用方法 给布局添加动画效果: 先找到要设置的layout的id,然后创建布局动画,创建一个LayoutAnimationController,并把 ...

  5. Android属性动画之ValueAnimation

    ValueAnimation是ObjectAnimation类的父类,经过前几天的介绍,相信大家对ObjectAnimation有了 一定的认识,今天就为大家最后介绍一下ValueAnimation, ...

  6. Android Animation学习(五) ApiDemos解析:容器布局动画 LayoutTransition

    Android Animation学习(五) ApiDemos解析:容器布局动画 LayoutTransition Property animation系统还提供了对ViewGroup中的View改变 ...

  7. Android属性动画完全解析(上),初识属性动画的基本用法

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/43536355 在手机上去实现一些动画效果算是件比较炫酷的事情,因此Android系 ...

  8. Android 属性动画(Property Animation) 完全解析 (上)

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/38067475 1.概述 Android提 供了几种动画类型:View Anima ...

  9. Android属性动画完全解析(中)

    转载:http://blog.csdn.net/guolin_blog/article/details/43536355 大家好,在上一篇文章当中,我们学习了Android属性动画的基本用法,当然也是 ...

随机推荐

  1. mysql以下c连接mysql数据库

    1.安装sudo yum install mysql-devel  安装组件和库 2. #include <stdio.h> #include <stdlib.h> #incl ...

  2. Linux命令之pip

    使用pip进行install,sudo pip install xxx 使用pip进行update,sudo pip install --update xxx 使用pip设置超时时间,sudo pip ...

  3. 设置EditText明文切换

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/mingyue_1128/article/details/37651793 if (!isChecke ...

  4. Grunt JS构建环境搭建以及使用入门

    Grunt JS构建环境搭建以及使用入门 1.应用场景 一种自动化任务处理工具,对于日常的需求(代码规则检查.代码合并)可以实现自动化执行,只需要保留package.json和Gruntfile.js ...

  5. github-----文件项目的推拉二式

    将本地项目文件推送上线: $ git init $ git add . $ git commit -m "第一次修改" $ git log $ git remote add ori ...

  6. Python(迭代、三元表达式、列表生成、生成器、迭代器)

    迭代 什么是迭代 1 重复 2 下次重复一定是基于上一次的结果而来 如果给定一个list或tuple,我们可以通过for循环来遍历这个list或tuple,这种遍历我们称为迭代(Iteration). ...

  7. Rest_framework-3

    目录: 返回值的封装 分页 视图 路由 渲染器 一 返回值的封装 a. API的基本框架 setting: 1 首先注册rest_framework 2 版本配置 REST_FRAMEWORK = { ...

  8. 错误:为 Web 项目“XXX”配置的 URL“http://localhost/”的网站同时存在于本地 IIS Web 服务器和 IIS Express Web 服务器上。您需要使用 IIS 管理器在 IIS 中更改此网站的绑定。

    解决方法: 用记事本打开MVC网站的项目文件(*.csproj),滚动条拉到最下,找到这两个节点: <UseIIS>True</UseIIS> <AutoAssignPo ...

  9. 102. Binary Tree Level Order Traversal ------层序遍历

      Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to righ ...

  10. 利用ntp自动同步时间

    实验环境:centos 6.10 1.安装ntp工具 yum install -y ntp 2.便宜/etc/ntp.conf文件,添加远程时间服务器 server ntp1.aliyun.com s ...