11

最近,我使用了 Android 设计支持库,并且我的折叠工具栏有以下代码。

<android.support.design.widget.CoordinatorLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    >

    <android.support.design.widget.AppBarLayout
        android:id="@+id/media_detail_appbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
        >

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/collapsing_toolbar"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            app:layout_scrollFlags="scroll|exitUntilCollapsed"
            app:contentScrim="?attr/colorPrimary"
            >

            <include
                layout="@layout/layout_card"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                />

            <android.support.v7.widget.Toolbar
                android:id="@+id/media_detail_toolbar"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
                app:layout_collapseMode="pin"
                />

        </android.support.design.widget.CollapsingToolbarLayout>

    </android.support.design.widget.AppBarLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"
        >

        <android.support.design.widget.TabLayout
            android:id="@+id/media_detail_tabs"
            android:layout_width="match_parent"
            android:layout_height="?android:attr/actionBarSize"
            android:background="@color/blue_2"
            app:tabMode="scrollable"
            />

        <android.support.v4.view.ViewPager
            android:id="@+id/view_pager"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            />

    </LinearLayout>

</android.support.design.widget.CoordinatorLayout>

我有两个 View Pager 片段。一个是 NestedScrollView,另一个是 Recycler View。我的问题是 NestedScrollView,下面是代码。

<android.support.v4.widget.NestedScrollView
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    >
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        >
    </LinearLayout>
</android.support.v4.widget.NestedScrollView>

我的问题是,当您向上滚动视图时,只要您的手指在侧面移动一点,它就会触发视图寻呼机的水平滚动。你能帮我避免这种情况吗?当我们上下滚动时,不应触发视图寻呼机。它在我的回收站视图片段中运行良好。谢谢。

4

2 回答 2

1

我用这些库的最新版本尝试了相同的布局

compile 'com.android.support:appcompat-v7:23.1.1'
compile 'com.android.support:design:23.1.1'

它按预期运行良好,即:

如果手势主要是垂直滚动(甚至对角线) NestedScrollView 触发滚动,否则如果手势主要是水平滑动(即使垂直间隙很小)ViewPager 触发滑动。解决升级你的库。

于 2016-01-18T14:54:50.513 回答
0

到目前为止,我针对此问题提出的最佳解决方案是跟踪触摸事件并确定用户何时垂直滚动,然后禁用 ViewPager 滚动,直到用户将手指从屏幕上移开。

将此添加到您的活动中:

private float startX;
private float startY;

@Override
public boolean dispatchTouchEvent(MotionEvent event)
{
    if (event.getAction() == MotionEvent.ACTION_DOWN)
    {
        startX = event.getX();
        startY = event.getY();
    }
    else if (event.getAction() == MotionEvent.ACTION_MOVE &&
        Math.abs(event.getX() - startX) < Math.abs(event.getY() - startY) &&
        Math.abs(event.getY() - startY) > 20)
    {
        ViewPager viewPager = findViewById(R.id.view_pager);
        viewPager.requestDisallowInterceptTouchEvent(true);
    }

    return super.dispatchTouchEvent(event);
}

夫妇评论:

  • requestDisallowInterceptTouchEvent不允许 ViewPager 拦截触摸事件,直到用户将手指从屏幕上抬起,之后如果用户开始水平滚动以更改选项卡,它将正常工作。
  • 20是我发现效果最好的垂直滚动距离的阈值,请随意更改。
于 2019-09-13T22:42:25.690 回答