답변:
finish ()를 실행하는 동일한 명령문에서 애니메이션도 실행하십시오. 그런 다음 새 활동에서 다른 애니메이션을 실행합니다. 이 코드를 참조하십시오.
fadein.xml
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:fillAfter="true">
<alpha android:fromAlpha="1.0"
android:toAlpha="0.0"
android:duration="500"/> //Time in milliseconds
</set>
마무리 수업에서
private void finishTask() {
if("blabbla".equals("blablabla"){
finish();
runFadeInAnimation();
}
}
private void runFadeInAnimation() {
Animation a = AnimationUtils.loadAnimation(this, R.anim.fadein);
a.reset();
LinearLayout ll = (LinearLayout) findViewById(R.id.yourviewhere);
ll.clearAnimation();
ll.startAnimation(a);
}
fadeout.xml
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:fillAfter="true">
<alpha android:fromAlpha="0.0"
android:toAlpha="1.0"
android:duration="500"/>
</set>
새로운 Activity 클래스에서 내가 작성한 runFadeAnimation과 같은 유사한 메서드를 만든 다음 onCreate에서 실행하고 리소스 ID를 페이드 아웃으로 변경하는 것을 잊지 마십시오.
android:duration="@android:integer/config_shortAnimTime"
runFadeAnimation()
API 레벨 5부터 즉시 overridePendingTransition을 호출하여 명시 적 전환 애니메이션을 지정할 수 있습니다.
startActivity();
overridePendingTransition(R.anim.hold, R.anim.fade_in);
또는
finish();
overridePendingTransition(R.anim.hold, R.anim.fade_out);
android : http://developer.android.com/guide/topics/ui/themes.html 테마를 참조 하십시오 .
themes.xml 아래 android:windowAnimationStyle
에 styles.xml 의 스타일 선언을 볼 수 있는 위치 가 있어야합니다 .
구현 예 :
<style name="AppTheme" parent="...">
...
<item name="android:windowAnimationStyle">@style/WindowAnimationStyle</item>
</style>
<style name="WindowAnimationStyle">
<item name="android:windowEnterAnimation">@android:anim/fade_in</item>
<item name="android:windowExitAnimation">@android:anim/fade_out</item>
</style>
@android:anim/fade_in
Java 코드에서 어떻게 액세스 합니까?
사용하다 overridePendingTransition
startActivity();
overridePendingTransition(R.anim.fadein, R.anim.fadeout);
fadein.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<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" />
</set>
fadeout.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<alpha xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/anticipate_interpolator"
android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="500" />
</set>
활동에 대해 항상 동일한 전환 애니메이션을 원하는 경우
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
overridePendingTransition(android.R.anim.fade_in, android.R.anim.fade_out);
@Override
protected void onPause() {
super.onPause();
if (isFinishing()) {
overridePendingTransition(android.R.anim.fade_in, android.R.anim.fade_out);
}
}
styles.xml 솔루션을 사용하고 싶었지만 활동에 적합하지 않았습니다. android:windowEnterAnimation
and 를 사용하는 대신 android:windowExitAnimation
다음과 같은 활동 애니메이션을 사용해야합니다.
<style name="ActivityAnimation.Vertical" parent="">
<item name="android:activityOpenEnterAnimation">@anim/enter_from_bottom</item>
<item name="android:activityOpenExitAnimation">@anim/exit_to_bottom</item>
<item name="android:activityCloseEnterAnimation">@anim/enter_from_bottom</item>
<item name="android:activityCloseExitAnimation">@anim/exit_to_bottom</item>
<item name="android:windowEnterAnimation">@anim/enter_from_bottom</item>
<item name="android:windowExitAnimation">@anim/exit_to_bottom</item>
</style>
// CREATE anim
// CREATE animation,animation2 xml // animation like fade out
Intent myIntent1 = new Intent(getApplicationContext(), Attend.class);
Bundle bndlanimation1 = ActivityOptions.makeCustomAnimation(getApplicationContext(),
R.anim.animation, R.anim.animation2).toBundle();
tartActivity(myIntent1, bndlanimation1);
대부분의 답변은 매우 정확하지만 R.anim.hold 를 사용할 때와 같이 일부는 더 이상 사용되지 않으며 일부는 프로세스를 정교하게 처리합니다.
따라서 다음을 사용할 수 있습니다.
startActivity(intent);
overridePendingTransition(android.R.anim.fade_in, android.R.anim.fade_out);