小小黑

小黑屋

android的基础Animation的实现

在android中,使用动画可以显示在ImageView上,设置并显示动画的代码如下:

img.startAnimation(AnimationUtils.loadAnimation(this, R.anim.anim_alpha));

除了显示在ImageView上,android的动画还可以用在Activity,ListView中,下面介绍一下他们的用法:

1.在ImageView上显示Animation的几种动画如下:


<--透明度动画-->
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <alpha 
        android:fromAlpha="0.0"
        android:toAlpha="1.0"
        android:duration="3000"/>
</set>

<--大小变化动画-->
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <scale 
        android:duration="3000"
        android:fillAfter="false"
        android:fromXScale="0.0"
        android:fromYScale="0.0"
        android:interpolator="@android:anim/accelerate_decelerate_interpolator"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toXScale="1.0"
        android:toYScale="1.0"/>

</set>

<--图像旋转动画-->
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <rotate 
        android:duration="2000"
        android:fromDegrees="0"
        android:interpolator="@android:anim/accelerate_decelerate_interpolator"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toDegrees="360"/>

</set>

<--图像位移动画-->
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate 
        android:duration="2000"
        android:fromXDelta="10"
        android:fromYDelta="10"
        android:toXDelta="100"
        android:toYDelta="100"/>

</set>

2.如果想要在切换Activity时显示动画,那么需要这样实现:

首先创建两个xml动画文件,分别表示前一个activity退出和后一个activity进入时播放的动画,这里可以利用上面的方法组合设置:


<--<span style="font-size:18px;">anim_activity_zoom_out.xml</span>-->

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/decelerate_interpolator">
    <scale 
        android:duration="1000"
        android:fromXScale="1.0"
        android:fromYScale="1.0"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toXScale="0.1"
        android:toYScale="0.1"/>
    
    <alpha 
        android:duration="1000"
        android:fromAlpha="1.0"
        android:toAlpha="0"/>

</set>

<--<span style="font-size:18px;">anim_activity_zoom_in.xml</span>-->
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/decelerate_interpolator"
    android:zAdjustment="top">
    <scale 
        android:duration="1000"
        android:fromXScale="0.1"
        android:fromYScale="0.1"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toXScale="1.0"
        android:toYScale="1.0"/>
    
    <alpha 
        android:duration="1000"
        android:fromAlpha="0"
        android:toAlpha="1.0"/>

</set>

然后在调用startActivity之后设置动画,注意这里是在之后:

Intent intent1 = new Intent(getApplicationContext(), BactivityActivity.class);
			startActivity(intent1);
			/*
			 * Call immediately after one of the flavors of startActivity(Intent) 
			 * or finish to specify an explicit transition animation to perform next. 
			 */
			overridePendingTransition(R.anim.anim_activity_zoom_in, R.anim.anim_activity_zoom_out);


3.在ListView中设置动画,他的xml的anim实现和activity中的实现方式一样,代码中我们只需要如下设置即可:

LayoutAnimationController lac = new LayoutAnimationController(
				AnimationUtils.loadAnimation(this, R.anim.anim_activity_zoom_in));
		lac.setOrder(LayoutAnimationController.ORDER_RANDOM);
		lv.setLayoutAnimation(lac);
		lv.startLayoutAnimation();


阅读更多
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u014520745/article/details/49915345
文章标签: android开发
个人分类: 我的android之路
想对作者说点什么? 我来说一句

Android Animation

2014年03月19日 186KB 下载

动画效果编程基础--Animatiom(apk)

2014年07月17日 23KB 下载

android objectanimator animation

2013年03月28日 1.55MB 下载

animation-test1

2013年06月27日 1.64MB 下载

android 旋转抽屉菜单

2015年11月03日 1.68MB 下载

没有更多推荐了,返回首页

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭