如何定义Android 1.5及更高版本的两个活动之间的转换? 我希望活动能够淡出。
答案 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)
一种更简单的方法是:
<style name="WindowAnimationTransition"> <item name="android:windowEnterAnimation">@android:anim/fade_in</item> <item name="android:windowExitAnimation">@android:anim/fade_out</item> </style>
<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)
这里是在两个活动之间做得很顺利的代码。
从左到右的平滑效果
在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>
从右到左的平滑效果
在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>
从一个活动导航到第二个活动
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;在设备中关闭它。开发者选项:
答案 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" />