android 动画保存,Android 动画浅谈(二)

自定义动画

创建自定义动画非常简单,只需要实现它的applyTransformation的逻辑就可以了,不过通常情况下,还需要覆盖父类的Initialize方法来实现一些初始化工作,

下面,通过实现一个电视机关机的动画来看一下用法。

效果非常简单,让一个图片纵向比例不断缩小即可,对应的矩阵处理方法如下:

Matrix matrix = t.getMatrix();

matrix.preScale(1, 1-interpolatedTime,halfWidth,halfHeight);

其中,halfWidth 和 halfHeight即为缩放的中心点,设置为图片中心即可,这样通过一个简单的矩阵变换,就可以模拟电视机关闭的动画。

当然,还可以设置更加精确的插值器,并将0到1.0的时间因子拆分成不同的过程,从而对不同的过程采用不同的动画效果,模拟更加真实的特效。

具体实现代码如下:

首先是定义动画类

**TVOffAnimation **

package com.example.administrator.myapplication;

import android.graphics.Matrix;

import android.view.animation.AccelerateDecelerateInterpolator;

import android.view.animation.Animation;

import android.view.animation.Transformation;

/**

* Created by Administrator on 2015/11/26 0026.

*/

public class TVOffAnimation extends Animation {

private int halfWidth;

private int halfHeight;

@Override

public void initialize(int width, int height, int parentWidth,

int parentHeight) {

super.initialize(width, height, parentWidth, parentHeight);

setDuration(500);

setFillAfter(true);

//保存View的中心点

halfWidth = width / 2;

halfHeight = height / 2;

setInterpolator(new AccelerateDecelerateInterpolator());

}

@Override

protected void applyTransformation(float interpolatedTime, Transformation t) {

final Matrix matrix = t.getMatrix();

if (interpolatedTime < 0.8) {

matrix.preScale(1+0.625f*interpolatedTime, 1-interpolatedTime/0.8f+0.01f,halfWidth,halfHeight);

}else{

matrix.preScale(7.5f*(1-interpolatedTime),0.01f,halfWidth,halfHeight);

}

}

}

然后,是Activity调用

MyTvAnimationActivity

package com.example.administrator.myapplication;

import android.app.Activity;

import android.os.Bundle;

import android.view.View;

import android.widget.Button;

/**

* Created by Administrator on 2015/11/26 0026.

*/

public class MyTvAnimationActivity extends Activity {

/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.tvmain);

Button b = (Button) findViewById(R.id.Button01);

b.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

View img = findViewById(R.id.ImageView01);

img.startAnimation(new TVOffAnimation());

}

});

}

}

效果图如下所示:

977535569c7b

这里写图片描述

更多效果,就需要慢慢探索了。。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值