Начиная с API 16, вы можете предоставлять пакет параметров активности при вызове Context.startActivity (Intent, Bundle) или связанных методов. Он создается с помощью конструктора ActivityOptions :
Intent myIntent = new Intent(context, MyActivity.class);
ActivityOptions options =
ActivityOptions.makeCustomAnimation(context, R.anim.fade_in, R.anim.fade_out);
context.startActivity(myIntent, options.toBundle());
Не забудьте проверить другие методы построителя ActivityOptions и ActivityOptionsCompat, если вы используете библиотеку поддержки.
API 5+:
Для приложений, ориентированных на уровень API 5+, существует overridePendingTransition
метод Activities . Для входящей и исходящей анимации требуется два идентификатора ресурса. Идентификатор 0
отключит анимацию. Звоните сразу после startActivity
звонка.
то есть:
startActivity(new Intent(this, MyActivity.class));
overridePendingTransition(R.anim.fade_in, R.anim.fade_out);
API 3+:
Вы можете предотвратить анимацию по умолчанию (сдвиньте вправо) с помощью Intent.FLAG_ACTIVITY_NO_ANIMATION
флага в своем намерении.
то есть:
Intent myIntent = new Intent(context, MyActivity.class);
myIntent.addFlags(Intent.FLAG_ACTIVITY_NO_ANIMATION);
context.startActivity(myIntent);
тогда в своей деятельности вам просто нужно указать собственную анимацию.
Это также работает для API версии 1.5 (уровень 3).