アクティビティを開始していますが、の場合はアルファフェードイン、の場合startActivity()
はフェードアウトにしfinish()
ます。Android SDKでこれを行うにはどうすればよいですか?
10 に答える
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の下に、 styles.xmlandroid:windowAnimationStyle
でスタイルの宣言を確認できる場所があるはずです。
実装例:
<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>
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をフェードアウトに変更することを忘れないでください。
使用する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>
フェードインとフェードアウトの場合は、新しいActivityクラスのsuper.onCreate(savedInstanceState)の後にのみこれを追加します。他に何かを作成する必要はありません(XML、animフォルダー、追加の関数はありません)。
overridePendingTransition(R.anim.abc_fade_in,R.anim.abc_fade_out);
アクティビティで常に同じトランジションアニメーションが必要な場合
@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);
}
}
コンテキストを作成して、次のようなことを行うことができます:-
private Context context = this;
そしてあなたのアニメーション:-
((Activity) context).overridePendingTransition(R.anim.abc_slide_in_bottom,R.anim.abc_slide_out_bottom);
好きなアニメーションを使うことができます。
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>
次に、テーマで参照します。
<style name="AppTheme">
...
<item name="android:windowAnimationStyle">@style/ActivityAnimation.Vertical</item>
...
</style>
また、何らかの理由で、これはAndroid8以降でのみ機能しました。BaseActivityに次のコードを追加して、以下のAPIレベルに合わせて修正しました。
override fun finish() {
super.finish()
setAnimationsFix()
}
/**
* The activityCloseExitAnimation and activityCloseEnterAnimation properties do not work correctly when applied from the theme.
* So in this fix, we retrieve them from the theme, and apply them.
* @suppress Incorrect warning: https://stackoverflow.com/a/36263900/1395437
*/
@SuppressLint("ResourceType")
private fun setAnimationsFix() {
// Retrieve the animations set in the theme applied to this activity in the manifest..
var activityStyle = theme.obtainStyledAttributes(intArrayOf(android.R.attr.windowAnimationStyle))
val windowAnimationStyleResId = activityStyle.getResourceId(0, 0)
activityStyle.recycle()
// Now retrieve the resource ids of the actual animations used in the animation style pointed to by
// the window animation resource id.
activityStyle = theme.obtainStyledAttributes(windowAnimationStyleResId, intArrayOf(android.R.attr.activityCloseEnterAnimation, android.R.attr.activityCloseExitAnimation))
val activityCloseEnterAnimation = activityStyle.getResourceId(0, 0)
val activityCloseExitAnimation = activityStyle.getResourceId(1, 0)
activityStyle.recycle()
overridePendingTransition(activityCloseEnterAnimation, activityCloseExitAnimation);
}
// 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();
startActivity(myIntent1, bndlanimation1);
ほとんどの答えはかなり正しいですが、R.anim.holdを使用する場合など、一部は非推奨になり、一部はプロセスを詳細に説明しています。
したがって、次を使用できます。
startActivity(intent);
overridePendingTransition(android.R.anim.fade_in, android.R.anim.fade_out);