我正在尝试使用 SlidingDrawer ViewGroup,但遇到了一些障碍。我们可以将一些侦听器附加到 SlidingDrawer:
OnDrawerScrollListener
OnDrawerOpenListener
OnDrawerCloseListener
最初拉动 SlidingDrawer 句柄时调用 onScrollStarted()。
onScrollEnded() 当用户停止在手柄上跟踪他们的手指时调用(令人惊讶的是不是在动画结束之后)。
onDrawerOpened() 仅在用户抬起手指并且抽屉动画完全打开时调用。
onDrawerClosed() 仅在用户抬起手指并且抽屉已动画完全关闭时调用。
我想在抽屉开始打开的那一刻禁用我的 Activity 的主视图(这可以通过 onScrollStarted() 完成)。当抽屉关闭时,我想启用我的 Activity 的主视图。如果用户将抽屉拖到半开,然后(不抬起手指)再次将抽屉完全关闭,那么我不知道如何确定是否再次启用主视图,因为未调用 onDrawerClosed()。我不能只在 onScrollEnded() 中启用主视图,因为该方法是在抽屉完全打开或完全关闭之前调用的。
我提到的 3 个监听器中的调用顺序是:
onScrollStarted() onScrollEnded() onDrawerOpened() / onDrawerClosed()
很明显,在 onScroll 方法中,除非我监听触摸事件,否则无法确定抽屉是“打开”还是“关闭”。有没有办法让我做到这一点不会那么混乱?
谢谢。
编辑:这是我的代码片段。
private boolean mDrawerScrolling = false;
@Override
public void onDrawerOpened() {
Log.d(TAG, "onDrawerOpened");
}
@Override
public void onDrawerClosed() {
mViewPager.setScrollEnabled(true);
Log.d(TAG, "onDrawerClosed");
final View view = (View) mDrawer.getTag();
if (view != null) {
final Animator fadeInAnimation = AnimatorInflater.loadAnimator(
InboxActivity.this, R.animator.fade_out);
fadeInAnimation.setTarget(view);
fadeInAnimation.addListener(new AnimatorListenerAdapter() {
@Override
public void onAnimationEnd(Animator animation) {
removeView();
}
@Override
public void onAnimationCancel(Animator animation) {
removeView();
}
private void removeView() {
ViewGroup container = (ViewGroup) findViewById(R.id.container);
container.removeView(view);
}
});
fadeInAnimation.start();
mDrawer.setTag(null);
}
}
@Override
public void onScrollEnded() {
mDrawerScrolling = false;
int left = mDrawer.getHandle().getLeft();
Log.d(TAG, "onScrollEnded() " + left);
}
@Override
public void onScrollStarted() {
mDrawerScrolling = true;
mCanHide = false;
Log.d(TAG, "onScrollStarted");
/*
* Open the drawer if it is not open yet.
*/
if (mDrawer.getTag() == null) {
final View dimView = getLayoutInflater().inflate(
R.layout.drawer_outer, null);
RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams(
RelativeLayout.LayoutParams.MATCH_PARENT,
RelativeLayout.LayoutParams.MATCH_PARENT);
dimView.setLayoutParams(params);
dimView.setOnTouchListener(this);
final ViewGroup container = (ViewGroup) findViewById(R.id.container);
container.addView(dimView);
container.bringChildToFront(mDrawer);
final Animator fadeInAnimation = AnimatorInflater.loadAnimator(
InboxActivity.this, R.animator.fade_in);
fadeInAnimation.setTarget(dimView);
fadeInAnimation.start();
mDrawer.setTag(dimView);
}
}