王学岗属性动画上(一)——ObjectAnimator

属性动画是补间动画的加强,但也是有区别的,我们现在位移一个有点击事件的控件,使用补间动画我们只能点击位移前的位置,而不能点击位移后控件所在的位置。使用属性动画我们就可以点击位移后的控价所在的位置。
可以采用如下写法

@Override
public void onAnimationUpdate(ValueAnimator animator) {
int i = (Integer)animator.getAnimatedValue();
int top = view.getTop();
				
//layout()方法,设置的是当前view在其父容器中的偏移量。
//并且是能够移动view,移动view的各种事件。
view.layout(i, top, i+view.getWidth(), top+view.getHeight());
}

下面我们学习属性动画ObjectAnimator

布局内容很简单,就是一张图片,这里就不列举出来了

package com.example.propertyOfGang;

import android.animation.ObjectAnimator;
import android.animation.ValueAnimator;
import android.animation.ValueAnimator.AnimatorUpdateListener;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ImageView;

@SuppressLint("NewApi")
// 新的API,支持的最低版本是11
public class MainActivity extends Activity implements OnClickListener {

	private ImageView iv_zhangxin;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		iv_zhangxin = (ImageView) findViewById(R.id.imageView1);
		iv_zhangxin.setOnClickListener(this);
		//可以在这里查看有什么属性
		//iv_zhangxin.setRotationX(rotationX);
 		//iv_zhangxin.setAlpha(alpha);
		//iv_zhangxin.setTranslationX(translationX);
		
	}

	@Override
	public void onClick(View v) {
		// TODO Auto-generated method stub
		// 第一个案例
		// target表示作用目标,这里是v,对我们的v执行动画
		// propertyName,属性名称,rotationX表示绕着x轴旋转
		// values value是个值,表示从哪里旋转到哪里
		// builder设计模式,返回当前对象
		ObjectAnimator objectAnimator = ObjectAnimator.ofFloat(v, "rotationY",
				0.0f, 360.f).setDuration(2000);
		objectAnimator.start();
		 
	}

}

我的第一篇文章介绍了objectAnimator的最基本用法。
透明度变化,从1到0.3再到1

   //1.设置参数
        //2.执行动画
        ObjectAnimator alphaAnim = ObjectAnimator.ofFloat(v, "alpha", 1.0f, 0.3f,1.0f);
        alphaAnim.setDuration(1000);//执行时间
        alphaAnim.setStartDelay(300);//延迟
        alphaAnim.start();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值