Вы можете создать свои собственные файлы анимации .xml, чтобы они появлялись в новых Activity
и постепенно уменьшались в текущих Activity
:
fade_in.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" />
fade_out.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:fillAfter="true"
android:duration="500" />
Используйте его в таком коде: (Внутри вашего Activity
)
Intent i = new Intent(this, NewlyStartedActivity.class)
startActivity(i)
overridePendingTransition(R.anim.fade_in, R.anim.fade_out)
Приведенный выше код исчезнет из текущего активного Activity
и исчезнет из нового, что Activity
приведет к плавному переходу.
ОБНОВЛЕНИЕ : @Dan J указал, что использование встроенной анимации Android улучшает производительность , что я действительно обнаружил после некоторого тестирования. Если вы предпочитаете работать со встроенной анимацией, используйте:
overridePendingTransition(android.R.anim.fade_in, android.R.anim.fade_out);
Обратите внимание, что я ссылаюсь android.R
вместо R
доступа к идентификатору ресурса.
ОБНОВЛЕНИЕ : сейчас обычной практикой является выполнение переходов с использованием класса Transition, представленного на уровне API 19 .
overridePendingTransition(android.R.anim.fadein, android.R.anim.fadeout);
просмотр этих файлов также может дать вам подсказки о том, как улучшить ваши пользовательские анимации (например, сделав постепенное появление дольше, чем исчезновение).overridePendingTransition(android.R.anim.fade_in, android.R.anim.fade_out);
:)Bundle bundle = ActivityOptionsCompat.makeCustomAnimation(getContext(), android.R.anim.fade_in, android.R.anim.fade_out).toBundle(); startActivity(intent, bundle);
Просто повторно отправьте ответ oleynikd, потому что он простой и аккуратный
Bundle bundle = ActivityOptionsCompat.makeCustomAnimation(getContext(), android.R.anim.fade_in, android.R.anim.fade_out).toBundle(); startActivity(intent, bundle);
источник
вы также можете добавить анимацию в свою деятельность в методе onCreate, как показано ниже, потому что overridePendingTransition не работает с некоторыми мобильными устройствами или зависит от настроек устройства ...
View view = findViewById(android.R.id.content); Animation mLoadAnimation = AnimationUtils.loadAnimation(getApplicationContext(), android.R.anim.fade_in); mLoadAnimation.setDuration(2000); view.startAnimation(mLoadAnimation);
источник
@Override public void onBackPressed() { super.onBackPressed(); overridePendingTransition(R.anim.fade_in, R.anim.fade_out); }
вы также можете использовать этот код в своем файле style.xml, поэтому вам не нужно ничего писать в своем activity.java
<!-- 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/colorAccent</item> <item name="android:windowAnimationStyle">@style/AppTheme.WindowTransition</item> </style> <!-- Setting window animation --> <style name="AppTheme.WindowTransition"> <item name="android:windowEnterAnimation">@android:anim/fade_in</item> <item name="android:windowExitAnimation">@android:anim/fade_out</item> </style>
источник