Android动画的两种使用方式。

本文详细介绍了Android动画的两种使用方法:通过代码生成动画和通过XML文件生成动画。包括如何声明动画、设置动画时间、使用动画集及在布局文件中使用动画,并提供了实例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

android 动画的分类就不说了,主要说一下动画的两种使用方法:1.通过代码生成并使用动画 (不利于重复使用) 2.通过xml文件生成并使用动画(更方便,重用性高)。

1.通过代码生成动画

//初始化
Animation scaleAnimation = new ScaleAnimation(0.1f, 1.0f,0.1f,1.0f);
//设置动画时间
scaleAnimation.setDuration(500);                                    
this.startAnimation(scaleAnimation);

//初始化
Animation translateAnimation = new TranslateAnimation(0.1f, 100.0f,0.1f,100.0f);
//设置动画时间 translateAnimation.setDuration(1000);this.startAnimation(translateAnimation);

步骤:1.声明一个动画  2.设置动画时间(还可以设置动画次数等其它属性) 3.使用动画。

如果一个控件要同时使用两种或两种以上的动画,需要通过 AnimationSet(动画集)来实现。 例如一个imageView同时使用上面两个动画,代码如下:

//初始化 Translate动画
				translateAnimation = new TranslateAnimation(0.1f, 100.0f,0.1f,100.0f);
				//初始化 Alpha动画
				alphaAnimation = new AlphaAnimation(0.1f, 1.0f);
				
				//动画集
				AnimationSet set = new AnimationSet(true);
				set.addAnimation(translateAnimation);
				set.addAnimation(alphaAnimation);
				
				//设置动画时间 (作用到每个动画)
				set.setDuration(1000);
				this.startAnimation(set);
2.通过xml布局文件生成动画

ani.xml文件:

<set xmlns:android="http://schemas.android.com/apk/res/android">
 <alpha android:interpolator="@android:anim/accelerate_interpolator"
  android:fromAlpha="1.0" android:toAlpha="0.1" android:duration="2000" />
 <translate android:interpolator="@android:anim/accelerate_interpolator"
  android:fromXDelta="0" android:toXDelta="0" android:fromYDelta="0"
  android:toYDelta="-380" android:duration="2000" />
 <scale android:interpolator="@android:anim/accelerate_interpolator"
  android:fromXScale="1.0" android:toXScale="0.2" android:fromYScale="1.0"
  android:toYScale="0.2" android:pivotX="50%" android:pivotY="50%"
  android:duration="2000" />
</set>
上面的xml文件已经生成了动画,接下来只要在activity中使用就行了,代码如下:

Animation animation = AnimationUtils.loadAnimation(this.getContext(), R.anim.ani);
通过上面一行代码,就能直接使用在xml文件中的动画了。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值