Android Activity动画

动画XML文件

slide_right_in.xml
<?xml version="1.0" encoding="utf-8"?>
<set
  xmlns:android="http://schemas.android.com/apk/res/android">
    <translate android:duration="300" android:fromXDelta="100.0%p" android:toXDelta="0.0" />
</set>

 

slide_left_out.xml
<?xml version="1.0" encoding="utf-8"?>
<set
  xmlns:android="http://schemas.android.com/apk/res/android">
    <translate android:duration="300" android:fromXDelta="0.0" android:toXDelta="-100.0%p" />
</set>

 

slide_left_in.xml
<?xml version="1.0" encoding="utf-8"?>
<set
  xmlns:android="http://schemas.android.com/apk/res/android">
    <translate android:duration="300" android:fromXDelta="-100.0%p" android:toXDelta="0.0" />
</set>

slide_right_out.xml
<?xml version="1.0" encoding="utf-8"?>
<set
  xmlns:android="http://schemas.android.com/apk/res/android">
    <translate android:duration="300" android:fromXDelta="0.0" android:toXDelta="100.0%p" />
</set>

bottom_in.xml
<?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" android:duration="350"/>
</set>

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

 

使用动画

styles.xml

<resources>

    <!-- Base application theme. -->
    <style name="AppTheme" parent="android:Theme.Holo.Light.DarkActionBar">


        <!-- 设置activity切换动画 -->
        <item name="android:windowAnimationStyle">@style/activityAnimation</item>
    </style>

    <!-- animation 样式 -->
    <style name="activityAnimation" parent="@android:style/Animation.Activity">
        <!--当我们从 A1 启动 A2 时,A2 出现在屏幕上,这个动画叫做 android:activityOpenEnterAnimation-->
        <item name="android:activityOpenEnterAnimation">@anim/slide_right_in</item>
        <!--当我们从 A1 启动 A2 时,A1 从屏幕上消失,这个动画叫做 android:activityOpenExitAnimation-->
        <item name="android:activityOpenExitAnimation">@anim/slide_left_out</item>
        <!--当我们从 A2 退出回到 A1 时,A1 出现在屏幕上,这个叫做 android:activityCloseEnterAnimation-->
        <item name="android:activityCloseEnterAnimation">@anim/slide_left_in</item>
        <!--当我们从 A2 退出回到 A1 时,A2 从屏幕上消失,这个叫做 android:activityCloseExitAnimation-->
        <item name="android:activityCloseExitAnimation">@anim/slide_right_out</item>
    </style>

</resources>

启动 Activity A中

 Intent intent = new Intent();
 intent.setClassName(cxt,"com.test.DemoActivity");//打开一个activity
 cxt.startActivity(intent);
                     
 cxt.overridePendingTransition(R.anim.bottom_in,0);

退出 Activity B中

@Override
    public void finish() {
        super.finish();
        overridePendingTransition(0, R.anim.bottom_out);
    }

 

转载于:https://www.cnblogs.com/l2rf/p/4736715.html

  • 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: AndroidActivity跳转动画是指系统在跳转Activity时所播放的动画效果。Android提供了许多内置的跳转动画效果,例如淡入淡出、左/右滑入、翻转、放缩等等。除了这些内置的动画效果,我们还可以自定义Activity跳转动画,以满足个性化需求。 在实现Activity跳转动画时,我们通常需要在startActivity()或finish()方法中添加相应的动画参数。例如,当从Activity A跳转到Activity 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、付费专栏及课程。

余额充值