在经过半天的寻找解决方法而没有结果后,我自己开始实现。我使用了一个具有相应根布局的透明 Activity
。根布局是一个视图,可以使用createCircularReveal()
来显示。
我的代码看起来像这样:
在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>
AndroidManifest.xml中的Activity定义
<activity
android:name=".ui.CircularRevealActivity"
android:theme="@style/Theme.Transparent"
android:launchMode="singleTask"
/>
然后我为我的活动声明了一个布局(我选择了DrawerLayout,这样我就可以有一个NavDrawer。这里应该适用于任何布局。)
<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"
>
</FrameLayout>
</android.support.v4.widget.DrawerLayout>
重要的是带有id为root_layout
的FrameLayout。该视图将在活动中显示。
最后,我实现了CircularRevealActivity
并重写了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);
}
}
});
}
}
}
将 circularRevealActivity()
放入 OnGlobalLayoutListener
中非常重要,因为动画需要绘制视图。
circularRevealActivity()
看起来像是Ishaan的建议:
private void circularRevealActivity() {
int cx = rootLayout.getWidth() / 2;
int cy = rootLayout.getHeight() / 2;
float finalRadius = Math.max(rootLayout.getWidth(), rootLayout.getHeight());
Animator circularReveal = ViewAnimationUtils.createCircularReveal(rootLayout, cx, cy, 0, finalRadius);
circularReveal.setDuration(1000);
rootLayout.setVisibility(View.VISIBLE);
circularReveal.start();
}
编辑 1
添加了对R.anim.do_not_move
的定义。但是,如果您的设计未指定活动的默认过渡效果,即使没有这行代码也应该能正常工作。让我知道。
R.anim.do_not_move:
<set xmlns:android="http://schemas.android.com/apk/res/android">
<translate
android:fromYDelta="0"
android:toYDelta="0"
android:duration="@android:integer/config_mediumAnimTime"
/>
</set>