Android在页面切换时添加animation

很简单,在startActivity后,调用overridePendingTransition方法,例如,实现淡入淡出的效果如下:

Intent i = new Intent(StartActivity.this,MainTab.class);
StartActivity.this.startActivity(i);
overridePendingTransition(android.R.anim.fade_in,android.R.anim.fade_out);

由左向右滑入的效果改变一下参数即可:

overridePendingTransition(android.R.anim.slide_in_left,android.R.anim.slide_out_right);

以上是直接使用android.R.anim预先定义好的animation,很奇怪为什么没有zoomin和zoomout(也许是我没有找到,还望高人指点)

要实现zoomin和zoomout,即类似iphone的进入和退出时的效果,代码如下:

overridePendingTransition(R.anim.zoomin, R.anim.zoomout);

添加此代码后,eclipse会报错,因为没有zoomin和zoomout的定义。

此时在res目录下新建文件夹anim,然后在anim下新建两个xml,默认选项不用更改,分别命名为zoomin.xml和zoomout.xml,代码如下:

zoomin

<?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:fromXScale="2.0" android:toXScale="1.0"
           android:fromYScale="2.0" android:toYScale="1.0"
           android:pivotX="50%p" android:pivotY="50%p"
           android:duration="@android:integer/config_mediumAnimTime" />
</set>

zoomout

<?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:fromXScale="1.0" android:toXScale=".5"
           android:fromYScale="1.0" android:toYScale=".5"
           android:pivotX="50%p" android:pivotY="50%p"
           android:duration="@android:integer/config_mediumAnimTime" />
    <alpha android:fromAlpha="1.0" android:toAlpha="0"
            android:duration="@android:integer/config_mediumAnimTime"/>
</set>

哦了,就是这么简单!



本文固定链接: http://www.ntxz.net/?p=1779 | 周忞 | 吉心的记事本



该日志由 吉心 于2012年02月09日发表在 Android 分类下, 你可以发表评论
在保留原文地址及作者的情况下引用到你的网站或博客。
原创文章转载请注明: Android在页面切换时添加animation | 周忞 | 吉心的记事本
关键字: ,

Android在页面切换时添加animation:等您坐沙发呢!

发表评论

您必须 [ 登录 ] 才能发表留言!