Android属性动画基础:TypeEvaluator

  本文简单介绍一下TypeEvaluator,来了解一下它的用途。TypeEvaluator是一个接口,我们可以自定义该接口实例,并通过ValueAnimator的setEvaluator(TypeEvaluator)方法来控制动画的更新计算表达式。如果您只是想利用属性动画操纵单一数值变化(如控制View的X或Y方向旋转、X或Y平移等,或仅仅是操纵与对象无关的数值),那么你完全不必关心TypeEvaluator,通过插值器控制就好了,杀鸡焉用牛刀啊,牙签足以。但是如果您要同时操纵对象的多个属性怎么办,比如您想模拟小球运动,要控制X和Y两个方向的坐标,而且由于两个方向的加速度不一样导致X和Y坐标的计算方式也不一样,难道您想通过动画组合的方式来分别处理X、Y吗,您当然可以这么做,不过并不好,此外如果还要求您记录运动轨迹,这种X、Y组合动画就无能为力了。这种相对复杂的场景,TypeEvaluator就可以大展身手了,好了,先看一下源码及api介绍

/**
 * Interface for use with the {@link ValueAnimator#setEvaluator(TypeEvaluator)} function. Evaluators
 * allow developers to create animations on arbitrary property types, by allowing them to supply
 * custom evaluators for types that are not automatically understood and used by the animation
 * system.
 *
 * @see ValueAnimator#setEvaluator(TypeEvaluator)
 */
public interface TypeEvaluator<T> {

    /**
     * This function returns the result of linearly interpolating the start and end values, with
     * <code>fraction</code> representing the proportion between the start and end values. The
     * calculation is a simple parametric calculation: <code>result = x0 + t * (x1 - x0)</code>,
     * where <code>x0</code> is <code>startValue</code>, <code>x1</code> is <code>endValue</code>,
     * and <code>t</code> is <code>fraction</code>.
     *
     * @param fraction   The fraction from the starting to the ending values
     * @param startValue The start value.
     * @param endValue   The end value.
     * @return A linear interpolation between the start and end values, given the
     *         <code>fraction</code> parameter.
     */
    public T evaluate(float fraction, T startValue, T endValue);
}

  这个接口代码看起来是相当简单,就一个方法,通过接口描述,我们可以知道,TypeEvaluator能够支持我们创建支持任意属性类型的动画。如果您有看过谷歌对属性动画的描述,就该知道,属性动画能够操纵任类型意属性,如果操纵的是对象,系统只内置了数值型计算方式,那么对象属性如何更新计算?TypeEvaluator就是解决这个问题的,当然,您也可以使用TypeEvaluator来计算基础数值型数据,这不是不可以的。evaluate方法就是更新计算方法,通过该方法计算出来的属性值来更新动画,参数fraction是插值器getInterpolation方法计算出来的时间因子(请参考Android属性动画基础:你是否真的了解插值器(TimeInterpolator));startValue和endValue分别表示每个动画区间段的起始值和终点值。
  以我们之前说的模拟小球运动轨迹为示例,写段简单的使用方法(下一篇文章会给出完整示例及另一种模拟方式)

 // 描述小球运动轨迹坐标
    private class Point {
        private float pointX;
        private float pointY;

        private Point(float pointX, float pointY) {
            this.pointX = pointX;
            this.pointY = pointY;
        }

        private float getPointX() {
            return pointX;
        }

        private float getPointY() {
            return pointY;
        }
    }

 // 模拟平抛运动轨迹的估值器
    private class MyTypeEvaluator implements TypeEvaluator<Point> {
        @Override
        public Point evaluate(float fraction, Point startValue, Point endValue) {
            float pointX = fraction * endValue.getPointX() + startValue.getPointX();
            float pointY = fraction * fraction * endValue.getPointY() + startValue.getPointY();
            Point point  = new Point(pointX, pointY);
            // ToDo 您可以在此记录或做相应操作
            return point;
        }
    }

    ValueAnimator animator = ValueAnimator.ofObject(new MyTypeEvaluator(), new Point(0, 0), new Point(300, 600)).setDuration(1000);
    animator.setInterpolator(new LinearInterpolator());
    animator .addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
            @Override
            public void onAnimationUpdate(ValueAnimator animation) {
                Point point = (Point) animation.getAnimatedValue();
               // ToDo 您也可以在此记录或做相应操作
            }
        });
    animator.start();

  这篇文章比较简单,就到这,对于复杂属性动画,请不要忘记TypeEvaluator

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342