Nach einer Lösung für einen halben Tag ohne Ergebnis suchte ich eine eigene Implementierung. Ich verwende eine transparente Aktivität mit einem übereinstimmenden Stammlayout. Das Root-Layout ist eine Ansicht, die dann mit createCircularReveal()
angezeigt werden kann.
Mein Code sieht wie folgt aus:
Thema Definition in styles.xml
<style name="Theme.Transparent" parent="Theme.AppCompat.Light.NoActionBar">
<item name="android:windowIsTranslucent">true</item>
<item name="android:statusBarColor">@android:color/transparent</item>
<item name="android:windowBackground">@android:color/transparent</item>
</style>
Aktivität Definition in AndroidManifest.xml
<activity
android:name=".ui.CircularRevealActivity"
android:theme="@style/Theme.Transparent"
android:launchMode="singleTask"
/>
dann erklärte ich ein Layout für Meine Aktivität (Ich habe DrawerLayout gewählt, damit ich einen NavDrawer haben kann. Eve ry Layout soll hier arbeiten.)
<android.support.v4.widget.DrawerLayout
android:id="@+id/drawer_layout"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
<FrameLayout
android:id="@+id/root_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/honey_melon"
>
<!-- Insert your actual layout here -->
</FrameLayout>
</android.support.v4.widget.DrawerLayout>
wichtig, die FrameLayout mit dem root_layout
id ist. Diese Ansicht wird in der Aktivität angezeigt.
Schließlich implementiert ich CircularRevealActivity
und überschrieb onCreate()
:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
overridePendingTransition(R.anim.do_not_move, R.anim.do_not_move);
setContentView(R.layout.activity_reveal_circular);
if (savedInstanceState == null) {
rootLayout.setVisibility(View.INVISIBLE);
ViewTreeObserver viewTreeObserver = rootLayout.getViewTreeObserver();
if (viewTreeObserver.isAlive()) {
viewTreeObserver.addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
@Override
public void onGlobalLayout() {
circularRevealActivity();
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.JELLY_BEAN) {
rootLayout.getViewTreeObserver().removeGlobalOnLayoutListener(this);
} else {
rootLayout.getViewTreeObserver().removeOnGlobalLayoutListener(this);
}
}
});
}
}
}
Es war wichtig, circularRevealActivity()
in eine OnGlobalLayoutListener
zu setzen, denn die Aussicht für die Animation gezogen werden muss.
circularRevealActivity()
sieht aus wie Ishaan Vorschlag:
private void circularRevealActivity() {
int cx = rootLayout.getWidth()/2;
int cy = rootLayout.getHeight()/2;
float finalRadius = Math.max(rootLayout.getWidth(), rootLayout.getHeight());
// create the animator for this view (the start radius is zero)
Animator circularReveal = ViewAnimationUtils.createCircularReveal(rootLayout, cx, cy, 0, finalRadius);
circularReveal.setDuration(1000);
// make the view visible and start the animation
rootLayout.setVisibility(View.VISIBLE);
circularReveal.start();
}
bearbeiten 1
Die Definition für R.anim.do_not_move
hinzugefügt wurde. Es sollte jedoch auch ohne diese Zeile funktionieren, wenn Ihr Design keine Standardübergänge für Aktivitäten angibt. Lassen Sie mich
R.anim.do_not_move wissen:
<set xmlns:android="http://schemas.android.com/apk/res/android">
<translate
android:fromYDelta="0"
android:toYDelta="0"
android:duration="@android:integer/config_mediumAnimTime"
/>
</set>
Haben Sie Glück dabei? – StuStirling
Nein. Ich suche nicht mehr aktiv danach. –