Rozpoczynam działanie i wolałbym raczej mieć pojawianie się alfa startActivity()
i zanikanie dla finish()
. Jak mogę to zrobić w Android SDK?
Rozpoczynam działanie i wolałbym raczej mieć pojawianie się alfa startActivity()
i zanikanie dla finish()
. Jak mogę to zrobić w Android SDK?
Odpowiedzi:
W tej samej instrukcji, w której wykonujesz finish (), wykonaj tam również swoją animację. Następnie w nowym działaniu uruchom kolejną animację. Zobacz ten kod:
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>
W Twojej klasie mety
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>
W swojej nowej klasie Activity tworzysz podobną metodę, taką jak runFadeAnimation, którą napisałem, a następnie uruchamiasz ją w onCreate i nie zapomnij zmienić identyfikatora zasobów na fadeout.
android:duration="@android:integer/config_shortAnimTime"
runFadeAnimation()
Począwszy od poziomu API 5 możesz natychmiast wywołać overridePendingTransition, aby określić wyraźną animację przejścia:
startActivity();
overridePendingTransition(R.anim.hold, R.anim.fade_in);
lub
finish();
overridePendingTransition(R.anim.hold, R.anim.fade_out);
Zobacz motywy na Androida: http://developer.android.com/guide/topics/ui/themes.html .
W pliku themes.xml powinno być miejsce, w android:windowAnimationStyle
którym można zobaczyć deklarację stylu w styles.xml .
Przykładowa realizacja:
<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
z kodu java?
Posługiwać się 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>
W przypadku fadeIn i fadeOut dodaj to tylko po super.onCreate (saveInstanceState) w nowej klasie Activity. Nie musisz tworzyć niczego innego (bez XML, bez folderu anim, bez dodatkowej funkcji).
overridePendingTransition(R.anim.abc_fade_in,R.anim.abc_fade_out);
Jeśli chcesz zawsze mieć tę samą animację przejścia dla działania
@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);
}
}
Chciałem użyć rozwiązania styles.xml, ale nie działało to w przypadku działań. Okazuje się, że zamiast używać android:windowEnterAnimation
i android:windowExitAnimation
, muszę użyć takich animacji działań:
<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);
Większość odpowiedzi jest całkiem poprawnych, ale niektóre z nich są przestarzałe, na przykład podczas korzystania z R.anim.hold, a niektóre z nich są po prostu dopracowywaniem procesu.
Możesz więc użyć:
startActivity(intent);
overridePendingTransition(android.R.anim.fade_in, android.R.anim.fade_out);