关闭

Android 动画之Interpolator插入器

标签: android动画Interpolator
3164人阅读 评论(0) 收藏 举报
分类:

本文转自:http://hi.baidu.com/892870119/item/ff76c623aca23ecfa5275aed

做了些动画,发现动画都有一个Interpolator的属性,它到底是个啥东西?

  网上也有很多解释Interpolator的文章,基本上都是停留在直接翻译SDK的意思层面上。看了,也就明白一个大概。

  Interpolator英文意思是: 篡改者; 分类机; 校对机

  SDK对Interpolator的描述是:An interpolator defines the rate of change of an animation. This allows the basic animation effects (alpha, scale, translate, rotate) to be accelerated, decelerated, repeated, etc。简而言之Interpolator就是一个“变化率”,一个基本动画的“变化率”。

 比如:从A到B的一个平移动画,移动,当然后速度的快慢,那么从A到B可以是匀速、匀加速、匀减速、变速完成这段距离。假设距离为S,时间为t,速度为v,都知道S=v*t。

这个Interpolator在这里就是一个速度控制器,控制速度变化。先给一个对Interpolator的大概理解,接下来站在程序员的角度来认识Interpolator。

Interpolator借口只有一个抽象方法getInterpolation(float input),由此SDK中扩展了另外几个常用Interpolator类,分别是:

    ——AccelerateInterpolator:动画从开始到结束,变化率是一个加速的过程。

    ——DecelerateInterpolator:动画从开始到结束,变化率是一个减速的过程。

    ——CycleInterpolator:动画从开始到结束,变化率是循环给定次数的正弦曲线。

    ——AccelerateDecelerateInterpolator:动画从开始到结束,变化率是先加速后减速的过程。

    ——LinearInterpolator:动画从开始到结束,变化率是线性变化。

    ..............

这里给一个简单的实现Interpolator接口的类:

import android.view.animation.Interpolator;

public class MyInterpolator implements Interpolator {

private float mFactor;

private int i;

public MyInterpolator(int i){

this.i = i;

}

@Override

public float getInterpolation(float input) {

switch(i){

case 1:mFactor = input;

break;

case 2:mFactor = input*input*input;

break;

}

return mFactor;

 

}

}

当初始变量为1的时候,mFactor = input,是一个线性函数,“变化率”是匀速的当初始变量为2的时候,mFactor = input*input*input,是一个曲线函数,“变化率”呈三次方。
这里需要注意的是,input是一个0.0f~1.0f的浮点类型

从上面看来,自定义一个Interpolator就是用input根据所需构造一个函数出来

比如:这里把初始变量为2的时候,把函数改为:mFactor=3*input。这里给出一个测试出来的效果图

这两个图所做的动画都是往下移动100的距离,时间都为3000ms.并且同时做。那为什么绿色的花移动距离是紫色花移动距离的3倍呢?这里来分析一下。

   都是以input为变量的一次线性函数,故两者都是匀速运动,此时后者的速度是前者的3倍,所以移动距离也应该是3被。回过头来看,在设置TranslateAniamtion的时候,明明是移动一样的距离啊!这里可以猜测这时设置的距离就不起效果了,也就是Interpolator改变了之前设置的距离。

   现在基本上明白了Interpolator到底是做什么的了!

 

0
0
查看评论

Android动画----Interpolator(插入器)

引言   Android的几种基础动画前面的几篇博客已经介绍的差不多了,在前几篇博客一直预留了一个问题就是Interpolator的说明,本篇博客就着重介绍一下Interpolator的含义Interpolator的含义   Interpolator字典意思是插入器,在动画当中充当的角色就是动作,类...
  • wenwen091100304
  • wenwen091100304
  • 2016-12-07 18:35
  • 1445

Android动画-View动画,插值器

原文地址 http://blog.csdn.net/qq_25806863/article/details/70169620补间动画又叫View动画。Android中的补间动画分四种,渐变、缩放、平移,旋转。还有个set是他们的组合,在XML文件中的标签对应是 <alpha>,<s...
  • qq_25806863
  • qq_25806863
  • 2017-04-14 10:23
  • 1039

Android 动画之Interpolator插入器

今天新发现的一个类的使用:简单介绍一下使用方法。 Android 动画之Interpolator插入器     ——AccelerateInterpolator:动画从开始到结束,变化率是一个加速的过程。     ——Decelerate...
  • jiang547860818
  • jiang547860818
  • 2016-11-03 17:52
  • 363

Android动画插入器

Interpolator英文意思是: 篡改者; 分类机; 校对机 SDK对Interpolator的描述是:An interpolator defines the rate of change of an animation. This allows the basic animation e...
  • u012453607
  • u012453607
  • 2015-09-11 23:35
  • 313

android 动画的Interpolator插值器

序 一个好的动画一定是用心做出来的,何为用心?其中一点我认为定义适当的 Interpolator 就是一种用心的表现;这点在 google material design 中尤为明显。一个好的动画一定要符合实际,一句老的话就是:石头下落一定要受重力才优雅,不然一颗石头像羽毛一样在风中...
  • linghu_java
  • linghu_java
  • 2015-02-12 14:17
  • 13654

android动画 之Interpolator类

序 一个好的动画一定是用心做出来的,何为用心?其中一点我认为定义适当的 Interpolator 就是一种用心的表现;这点在 google material design 中尤为明显。一个好的动画一定要符合实际,一句老的话就是:石头下落一定要受重力才优雅,不然一颗石头像羽毛一...
  • feizhixuan46789
  • feizhixuan46789
  • 2015-07-12 23:51
  • 3256

Android动画TimeInterpolator(插值器)和TypeEvaluator(估值器)分析

Android动画TimeInterpolator(插值器)和TypeEvaluator(估值器)简单分析。
  • wuyuxing24
  • wuyuxing24
  • 2016-06-06 08:43
  • 7672

Android动画-Interpolator(插值器)大全

本章内容 花了点时间,把所有动画的插值器都用了一遍,写了个Demo分享下,看效果之前先看下Android动画中插值器的类型: AccelerateDecelerateInterpolator 在动画开始与介绍的地方速率改变比较慢,在中间的时候加速 AccelerateInterpolat...
  • cjh_android
  • cjh_android
  • 2016-05-26 16:45
  • 1903

[Android 动画] 实现类似弹簧的插值器SpringInterpolator

一、前言         在我们移动app的开发中,用户与输入框editText的交互应该是必不可少的。为了为用户提供更好的交互体验,我们这样规定:如果用户输入了不符合规则的内容,我们将调用一个抖动的动画,来提示用户这个输入不合规...
  • u013581141
  • u013581141
  • 2016-02-25 15:43
  • 1692

详解Android动画之Interpolator插入器

Interpolator英文意思是: 篡改者; 分类机; 校对机 SDK对Interpolator的描述是:An interpolator defines the rate of change of an animation. This allows the basic animation e...
  • li_xiao_kang
  • li_xiao_kang
  • 2013-09-11 12:16
  • 637
    个人资料
    • 访问:1806718次
    • 积分:24161
    • 等级:
    • 排名:第329名
    • 原创:502篇
    • 转载:371篇
    • 译文:99篇
    • 评论:437条
    博客专栏
    最新评论