属性动画 的XML实现


之前介绍了Peoperty Animation 的ObjectAnimator 、ValueAnimator。

这次学习下一个重要的类AnimatorInflater。故名思意,就是通过引入xml文件实现动画效果。

<?xml version="1.0" encoding="utf-8"?>
<set  xmlns:android="http://schemas.android.com/apk/res/android"
    android:ordering="together"
    >
    <objectAnimator
	  android:duration="2000"
	  android:propertyName="scaleX"
	  android:valueFrom="1.0"
	  android:valueTo="2.0"
	  android:valueType="floatType"
	  >
	</objectAnimator>
	<objectAnimator 
	    android:duration="2000"
	    android:propertyName="rotationX"
	    android:valueFrom="0"
	    android:valueTo="180"
	    android:valueType="floatType"
	    >
	    
	</objectAnimator>
</set>

		Animator animator= AnimatorInflater.loadAnimator(context, R.animator.scale);
		animator.setTarget(imageView);
		animator.start();
同时实现X轴放大一倍、绕X旋转180度两个动画效果。

android:ordering="sequentially"//顺序执行

imageView.setPivotX(pivotX);//设置旋转、缩放的轴线和中心点
不清楚需不需要调用invalidate?


2,LayoutTransition   当容器中的视图层次发生变化时存在过渡的动画效果。

LayoutTransition.APPEARING 当一个View在ViewGroup中出现时,对此View设置的动画

LayoutTransition.CHANGE_APPEARING 当一个View在ViewGroup中出现时,对此View对其他View位置造成影响,对其他View设置的动画

LayoutTransition.DISAPPEARING  当一个View在ViewGroup中消失时,对此View设置的动画

LayoutTransition.CHANGE_DISAPPEARING 当一个View在ViewGroup中消失时,对此View对其他View位置造成影响,对其他View设置的


	public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
		layoutTransition = new LayoutTransition();
		// mApperBox 被选中,
		layoutTransition.setAnimator(
				LayoutTransition.APPEARING,
				(mApperBox.isChecked()) ? layoutTransition.getAnimator(LayoutTransition.APPEARING) : null);
		layoutTransition.setAnimator(
				LayoutTransition.DISAPPEARING,
				(mDisapperBox.isChecked()) ? layoutTransition.getAnimator(LayoutTransition.DISAPPEARING) : null);
		layoutTransition.setAnimator(
				LayoutTransition.CHANGE_APPEARING,
				(mChangeApperBox.isChecked()) ? layoutTransition.getAnimator(LayoutTransition.CHANGE_APPEARING) : null);
		layoutTransition.setAnimator(
				LayoutTransition.CHANGE_DISAPPEARING,
				(mDiaChangeApperBox.isChecked()) ? layoutTransition.getAnimator(LayoutTransition.CHANGE_DISAPPEARING) : null);
		gridLayout.setLayoutTransition(layoutTransition);
	}
这里选择的增添/消失的动画是系统自身的动画,我们也可以自定义,例如这样。自定义一个ObjectAnimator

mTransition.setAnimator(LayoutTransition.APPEARING, (mAppear
				.isChecked() ? ObjectAnimator.ofFloat(this, "scaleX", 0, 1)
				: null));

最后附上 hongyang的链接:http://blog.csdn.net/lmj623565791/article/details/38092093





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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值