Activity跳转切换动画

MainActivity 代码:

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Button bt=(Button) findViewById(R.id.bt);
        bt.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                Intent intent = new Intent();
                intent.setClass(MainActivity.this, Aa.class);
                startActivity(intent);
                //设置动画的方法第一个activtiy执行第一个参数,第二个activtiy执行第二个参数
                overridePendingTransition(R.anim.huadong, R.anim.huadong2);
            }
        });
    }
}

跳转界面往左移动:

刚开始时

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">

    <translate
        android:duration="500"
        android:toXDelta="-100%p"
        android:interpolator="@android:anim/linear_interpolator"
        android:fromXDelta="0%p" />

</set>

结束时

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">

    <translate
        android:duration="500"
        android:toXDelta="0%p"
        android:interpolator="@android:anim/linear_interpolator"
        android:fromXDelta="100%p" />

</set>

跳转界面往右移动:

刚开始

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">

    <translate
        android:duration="500"
        android:toXDelta="0%p"
        android:interpolator="@android:anim/linear_interpolator"
        android:fromXDelta="-100%p" />

</set>

结束时

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">

    <translate
        android:duration="500"
        android:toXDelta="100%p"
        android:interpolator="@android:anim/linear_interpolator"
        android:fromXDelta="0%p" />

</set>

跳转界面往上移动:

开始时:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    >
    <translate 
        android:fromYDelta="100%p"
        android:toYDelta="0%p"
        android:duration="500"
        android:interpolator="@android:anim/linear_interpolator"
        />
</set>

结束时:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >

    <translate
        android:duration="500"
        android:fromYDelta="0%p"
        android:interpolator="@android:anim/linear_interpolator"
        android:toYDelta="-100%p" />

</set>

跳转往下移动:

开始时:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    >
    <translate 
        android:fromYDelta="0%p"
        android:toYDelta="100%p"
        android:duration="500"
        android:interpolator="@android:anim/linear_interpolator"
        />
</set>

结束时:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >

    <translate
        android:duration="500"
        android:fromYDelta="-100%p"
        android:interpolator="@android:anim/linear_interpolator"
        android:toYDelta="0%p" />

</set>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Android Activity动画是指在Activity之间切换时,为了增强用户体验而添加的动画效果。常见的动画有淡入淡出、滑动、旋等。可以通过在代码中设置Activity的进入和退出动画来实现。例如: 1. 淡入淡出动画 在res/anim目录下创建fade_in.xml和fade_out.xml两个文件,分别表示Activity进入和退出时的动画效果。 fade_in.xml: ``` <alpha xmlns:android="http://schemas.android.com/apk/res/android" android:duration="500" android:fromAlpha="0.0" android:toAlpha="1.0" /> ``` fade_out.xml: ``` <alpha xmlns:android="http://schemas.android.com/apk/res/android" android:duration="500" android:fromAlpha="1.0" android:toAlpha="0.0" /> ``` 在代码中设置Activity的进入和退出动画: ``` startActivity(intent); overridePendingTransition(R.anim.fade_in, R.anim.fade_out); ``` 2. 滑动动画 在res/anim目录下创建slide_in.xml和slide_out.xml两个文件,分别表示Activity进入和退出时的动画效果。 slide_in.xml: ``` <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="100%p" android:toXDelta="0" android:duration="500"/> <alpha android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="500" /> </set> ``` slide_out.xml: ``` <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="0" android:toXDelta="-100%p" android:duration="500"/> <alpha android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="500" /> </set> ``` 在代码中设置Activity的进入和退出动画: ``` startActivity(intent); overridePendingTransition(R.anim.slide_in, R.anim.slide_out); ``` 以上是两种常见的Activity动画,开发者可以根据需要自定义动画效果。 ### 回答2: Android平台的Activity是应用程序中最重要的部分之一。当我们需要在应用程序中切换不同的Activity时,我们可以使用动画来创建更加平滑和丰富的用户交互体验。本文将重点介绍如何在Android应用程序中实现Activity动画。 1. 系统默认动画 Android系统提供了一些默认的Activity动画,包括从右往左滑动、从左往右滑动、从上往下滑动、从下往上滑动等。我们可以在Intent中使用setFlags方法来设置动画,例如: intent.setFlags(Intent.FLAG_ACTIVITY_NO_ANIMATION); startActivity(intent); overridePendingTransition(R.anim.slide_right_in, R.anim.slide_left_out); 2. 自定义动画 除了系统默认动画,我们还可以根据自己的需求来创建自定义的Activity动画。Android系统提供了一些动画资源文件,包括translate、scale、rotate和alpha四种类型。我们可以通过在res目录下的anim文件夹中创建xml文件来定义自定义动画,例如: <?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:fillAfter="true"> <translate android:fromXDelta="0%" android:toXDelta="100%" android:duration="500"/> </set> 我们在代码中使用以下方法来启动Activity和设置动画: Intent intent = new Intent(MainActivity.this, SecondActivity.class); startActivity(intent); overridePendingTransition(R.anim.slide_in, R.anim.slide_out); 其中,slide_in.xml和slide_out.xml分别是进入和退出Activity时的动画,可以根据自己的需要来定义。 总结:以上是Android中实现Activity动画的方法。在实践中,我们可以根据实际需求来选择系统默认动画或自定义动画,以提升用户体验。在创建自定义动画时,需要注意动画类型的选择和动画时长的设置,以达到最佳效果。 ### 回答3: Android的Activity动画是指系统在Activity时所播放的动画效果。Android提供了许多内置的动画效果,例如淡入淡出、左/右滑入、翻、放缩等等。除了这些内置的动画效果,我们还可以自定义Activity动画,以满足个性化需求。 在实现Activity动画时,我们通常需要在startActivity()或finish()方法中添加相应的动画参数。例如,当从Activity AActivity B时,我们可以在startActivity()方法中添加以下代码: ``` startActivity(intent); overridePendingTransition(R.anim.slide_in_right, R.anim.slide_out_left); ``` 其中,R.anim.slide_in_right和R.anim.slide_out_left是我们自定义的两个动画效果,表示Activity B从右侧滑入,Activity A从左侧滑出。这两个动画效果需要我们在res文件夹下创建anim文件夹,并在该文件夹下添加相应的XML文件。 slide_in_right.xml的代码如下: ``` <set xmlns:android="http://schemas.android.com/apk/res/android" android:fillAfter="true"> <translate android:fromXDelta="100%p" android:toXDelta="0" android:duration="500"/> <alpha android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="500" /> </set> ``` slide_out_left.xml的代码如下: ``` <set xmlns:android="http://schemas.android.com/apk/res/android" android:fillAfter="true"> <translate android:fromXDelta="0" android:toXDelta="-100%p" android:duration="500"/> <alpha android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="500" /> </set> ``` 可以看到,slide_in_right.xml描述了Activity B从右侧进入的动画效果,其中包括了平移和透明度渐变两个动画效果。而slide_out_left.xml描述了Activity A从左侧离开的动画效果,同样包括了平移和透明度渐变两个动画效果。 除了基本的平移、透明度渐变效果之外,我们还可以使用缩放、旋等复杂的动画效果来实现更丰富的动画效果。需要注意的是,动画效果的实现需要考虑到用户体验和性能问题,避免出现卡顿或者过多的动画效果影响用户体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值