Android中的活动转换

时间:2010-08-02 16:03:21

标签: android android-activity transition

如何定义Android 1.5及更高版本的两个活动之间的转换? 我希望活动能够淡出。

14 个答案:

答案 0 :(得分:184)

这是在两个活动之间进行平滑淡化的代码..

fadein.xml

中创建名为res/anim的文件
<?xml version="1.0" encoding="utf-8"?>
<alpha xmlns:android="http://schemas.android.com/apk/res/android"
   android:interpolator="@android:anim/accelerate_interpolator"
   android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="2000" />

fadeout.xml

中创建名为res/anim的文件
<?xml version="1.0" encoding="utf-8"?>

<alpha xmlns:android="http://schemas.android.com/apk/res/android"
   android:interpolator="@android:anim/accelerate_interpolator"
   android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="2000" />

如果您想从活动A 淡出到活动B ,请在活动B onCreate()方法中添加以下内容。在setContentView()为我工作之前。

overridePendingTransition(R.anim.fadein, R.anim.fadeout);

如果淡入淡出对您来说太慢,请将上面的xml文件中的android:duration更改为更小的内容。

答案 1 :(得分:161)

您可以使用Activity.overridePendingTransition()执行此操作。您可以在XML资源文件中定义简单的过渡动画。

答案 2 :(得分:40)

一种更简单的方法是:

  1. 在styles.xml文件中创建动画样式
  2. <style name="WindowAnimationTransition">
        <item name="android:windowEnterAnimation">@android:anim/fade_in</item>
        <item name="android:windowExitAnimation">@android:anim/fade_out</item>
    </style>
    
    1. 将此样式添加到您的应用主题
    2. <style name="AppBaseTheme" parent="Theme.Material.Light.DarkActionBar">
            <item name="android:windowAnimationStyle">@style/WindowAnimationTransition</item>
      </style>
      

      就是这样:))

答案 3 :(得分:31)

是。您可以告诉操作系统您希望为您的活动进行哪种转换。

@Override
public void onCreate(Bundle savedInstanceState)
{
    super.onCreate(savedInstanceState);
    getWindow().setWindowAnimations(ANIMATION);

    ...

}

其中ANIMATION是一个整数,指的是操作系统中的内置动画。

答案 4 :(得分:29)

有关默认动画的列表,请参阅:http://developer.android.com/reference/android/R.anim.html

实际上{1}和fade_in适用于API级别1及以上。

答案 5 :(得分:28)

创建res&gt; anim&gt; fadein.xml

<?xml version="1.0" encoding="utf-8"?>
    <alpha xmlns:android="http://schemas.android.com/apk/res/android"
       android:interpolator="@android:anim/accelerate_interpolator"
       android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="500" />

创建res&gt; anim&gt; fadeout.xml

<?xml version="1.0" encoding="utf-8"?>
    <alpha xmlns:android="http://schemas.android.com/apk/res/android"
       android:interpolator="@android:anim/accelerate_interpolator"
       android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="500" />

在res&gt; values&gt; styles.xml

<style name="Fade">
        <item name="android:windowEnterAnimation">@anim/fadein</item>
        <item name="android:windowExitAnimation">@anim/fadeout</item>
    </style>

在onCreate()

活动中
getWindow().getAttributes().windowAnimations = R.style.Fade;

答案 6 :(得分:23)

这里是在两个活动之间做得很顺利的代码。

  1. 从左到右的平滑效果

    在res / anim

    中创建名为slide_in_right.xml和slide_out_right.xml的文件

    <强> slide_in_right.xml

        <?xml version="1.0" encoding="utf-8"?>
        <set xmlns:android="http://schemas.android.com/apk/res/android"
            android:shareInterpolator="false" >
            <translate android:duration="5000" android:fromXDelta="100%" android:toXDelta="0%" />
            <alpha android:duration="5000" android:fromAlpha="0.0" android:toAlpha="1.0" />
        </set>
    

    slide_out_right.xml

    <?xml version="1.0" encoding="utf-8"?>
    <set xmlns:android="http://schemas.android.com/apk/res/android"
        android:shareInterpolator="false" >
        <translate android:duration="5000" android:fromXDelta="0%" android:toXDelta="-100%"/>
        <alpha android:duration="5000" android:fromAlpha="1.0" android:toAlpha="0.0" />
    </set>
    
  2. 从右到左的平滑效果

    在res / anim

    中创建名为animation_enter.xml和animation_leave.xml的文件

    <强> animation_enter.xml

       <set xmlns:android="http://schemas.android.com/apk/res/android"
        android:shareInterpolator="false">
        <translate android:fromXDelta="-100%" android:toXDelta="0%"
            android:fromYDelta="0%" android:toYDelta="0%"
            android:duration="700"/>
       </set>
    

    <强> animation_leave.xml

      <set xmlns:android="http://schemas.android.com/apk/res/android"
        android:shareInterpolator="false">
        <translate
            android:fromXDelta="0%" android:toXDelta="100%"
            android:fromYDelta="0%" android:toYDelta="0%"
            android:duration="700" />
      </set>
    
  3. 从一个活动导航到第二个活动

       Intent intent_next=new Intent(One_Activity.this,Second_Activity.class);
       overridePendingTransition(R.anim.slide_in_right,R.anim.slide_out_right);
       startActivity(intent_next);
     finish();
    

    4.在背压事件或从第二个活动导航到一个活动

     Intent home_intent = new Intent(Second_Activity.this, One_Activity.class);
     overridePendingTransition(R.anim.animation_enter, R.anim.animation_leave);
     startActivity(home_intent);
     finish();
    

答案 7 :(得分:19)

我覆盖了我的默认活动动画。我在api 15中测试它运行顺畅。这是我使用的解决方案:

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorPrimary</item>
    <item name="android:windowAnimationStyle">@style/CustomActivityAnimation</item>

</style>

<style name="CustomActivityAnimation" parent="@android:style/Animation.Activity">
    <item name="android:activityOpenEnterAnimation">@anim/slide_in_right</item>
    <item name="android:activityOpenExitAnimation">@anim/slide_out_left</item>
    <item name="android:activityCloseEnterAnimation">@anim/slide_in_left</item>
    <item name="android:activityCloseExitAnimation">@anim/slide_out_right</item>
</style>

在res文件夹下创建anim文件夹,然后创建这四个动画文件:

slide_in_right.xml

<?xml version="1.0" encoding="utf-8"?>

<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate android:fromXDelta="100%p" android:toXDelta="0"
        android:duration="@android:integer/config_mediumAnimTime"/>
</set>

slide_out_left.xml

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate android:fromXDelta="0" android:toXDelta="-100%p"
        android:duration="@android:integer/config_mediumAnimTime"/>
</set>

slide_in_left.xml

<?xml version="1.0" encoding="utf-8"?>

<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate android:fromXDelta="-100%p" android:toXDelta="0"
        android:duration="@android:integer/config_mediumAnimTime"/>
</set>

slide_out_right.xml

<?xml version="1.0" encoding="utf-8"?>

<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate android:fromXDelta="0" android:toXDelta="100%p"
        android:duration="@android:integer/config_mediumAnimTime"/>
</set>

您可以下载我的sample project

这就是......:)

答案 8 :(得分:4)

您不能在Android 1.5中使用overridePendingTransition。 overridePendingTransistion来到Android 2.0。

如果您要完成此操作而没有任何错误,则必须使用普通动画(或您拥有)编译目标(1.5或更高版本),或者您必须使用overridePendingTransistion编译目标(2.0或更高版本)

摘要:您无法在Android 1.5中使用overridePendingTransistion

您可以使用操作系统中的内置动画。

答案 9 :(得分:2)

在GALAXY设备中:

您需要确保使用设置&gt;在设备中关闭它。开发者选项:

two muppets

答案 10 :(得分:1)

使用ActivityCompat.startActivity()工作API&gt; 21。

    ActivityOptionsCompat options = ActivityOptionsCompat.makeSceneTransitionAnimation(activity, transitionImage, EXTRA_IMAGE);
    ActivityCompat.startActivity(activity, intent, options.toBundle());

答案 11 :(得分:1)

在开始你的意图之前:

ActivityOptions options = ActivityOptions.makeSceneTransitionAnimation(AlbumListActivity.this);
startActivity(intent, options.toBundle());

这为您的活动过渡提供了默认动画。

答案 12 :(得分:0)

某些版本的Android支持自定义Activity转换,而某些版本则不支持(旧版设备)。如果您想使用自定义转换,那么检查Activity是否具有overridePendingTransition()方法是一种很好的做法,就像旧版本不一样。

要知道方法是否存在,可以使用反射API。这是一个简单的代码,它将检查并返回方法(如果存在):

Method mOverridePendingTransition;

try {
        mOverridePendingTransition = Activity.class.getMethod(
                "overridePendingTransition", new Class[] { Integer.TYPE, Integer.TYPE } );
        /* success */
    } catch (NoSuchMethodException nsme) {
        /* failure, this version of Android doesn't have this method */
    } 

然后,我们可以应用我们自己的转换,即使用此方法:

if (UIConstants.mOverridePendingTransition != null) {
               try {
                   UIConstants.mOverridePendingTransition.invoke(MainActivity.this, R.anim.activity_fade_in, R.anim.activity_fade_out);
               } catch (InvocationTargetException e) {
                   e.printStackTrace();
               } catch (IllegalAccessException e) {
                   e.printStackTrace();
               }
            }

在这里,作为一个例子,简单的淡入和淡出动画被用于过渡演示。

答案 13 :(得分:0)

放大动画

Intent i = new Intent(getApplicationContext(), LoginActivity.class);
 overridePendingTransition(R.anim.zoom_enter, R.anim.zoom_exit);
startActivity(i);
finish();

zoom_enter

<?xml version="1.0" encoding="utf-8"?>
<alpha xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/accelerate_interpolator"
    android:fromAlpha="0.0" android:toAlpha="1.0"
    android:duration="500" />

zoom_exit

<alpha xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/accelerate_interpolator"
    android:fromAlpha="1.0" android:toAlpha="0.0"
    android:fillAfter="true"
    android:duration="500" />