【问题标题】:Recyclerview inside ViewPager which is inside nested Scroll View嵌套滚动视图内的 ViewPager 内的 Recyclerview
【发布时间】:2018-02-22 22:38:10
【问题描述】:

我在协调器布局中使用了以下代码,并且正在使用自定义折叠工具栏设计。

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:ignore="RtlHardcoded">

    <android.support.design.widget.AppBarLayout
        android:id="@+id/main.appbar"
        android:layout_width="match_parent"
        android:layout_height="250dp"
        android:background="@drawable/backg">

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

            <FrameLayout
                android:id="@+id/main.framelayout.title"
                android:layout_width="match_parent"
                android:layout_height="130dp"
                android:layout_gravity="bottom"
                android:background="#00000000"
                android:orientation="vertical"
                app:layout_collapseMode="parallax"
                app:layout_collapseParallaxMultiplier="0.3">

                <LinearLayout
                    android:id="@+id/main.linearlayout.title"
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:paddingLeft="30dp"
                    android:layout_gravity="left"
                    android:orientation="vertical">

                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:gravity="bottom"
                        android:text="User Name"
                        android:id="@+id/username"
                        android:textColor="@android:color/white"
                        android:textSize="30sp"/>

                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_marginTop="4dp"
                        android:id="@+id/business"
                        android:text="Users Business"
                        android:textColor="@android:color/white"/>
                </LinearLayout>

            </FrameLayout>

            <android.support.v7.widget.Toolbar
                android:id="@+id/main.toolbar"
                android:layout_width="match_parent"
                android:layout_height="110dp"
                android:background="#00000000"
                app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
                app:title=""
                app:layout_collapseMode="pin">

                <LinearLayout
                    android:layout_width="wrap_content"
                    android:layout_height="match_parent"
                    android:orientation="horizontal">

                    <ImageView
                        android:layout_width="32dp"
                        android:layout_height="32dp"
                        android:id="@+id/back"
                        android:layout_marginTop="10dp"
                        android:background="@drawable/ic_arrow_back"/>

                    <TextView
                        android:id="@+id/main.textview.title"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="12dp"
                        android:text="User Name"
                        android:textColor="@android:color/white"
                        android:textSize="24sp"
                        />

                </LinearLayout>
            </android.support.v7.widget.Toolbar>
            <android.support.design.widget.TabLayout
                android:id="@+id/tabs"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:background="#00000000"
                android:layout_gravity="bottom"
                app:tabMode="fixed"
                app:tabGravity="fill"
                app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"/>

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

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

    <android.support.v4.widget.NestedScrollView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"
        android:layout_gravity="fill_vertical"
        android:fillViewport="true"
        android:layout_marginBottom="110dp">

             <android.support.v4.view.ViewPager
                android:id="@+id/viewpager"
                android:layout_width="match_parent"
                 android:layout_gravity="fill_vertical"
                android:layout_height="match_parent"
                android:background="@android:color/white">
            </android.support.v4.view.ViewPager>
    </android.support.v4.widget.NestedScrollView>
</android.support.design.widget.CoordinatorLayout>

现在我面临的问题是,当我在较低的操作系统版本上运行此应用程序时,在所有 viewpager 片段 Recyclerviews 中滚动时一切正常,但是当我使用 Android.M 以上的操作系统时,recyclerview 的高度超出了显示屏幕,并且在屏幕上看不到该项目。请帮我解决我的问题。我已经设计了我的自定义折叠栏布局,但在较低的 Android 操作系统中一切正常。

[已编辑]
这是我添加操作栏大小的 margin_bottom 时的一些快照。
当我们使用 marginBottom 时,您可以看到 viewpagers 的高度小于屏幕尺寸。
现在
对于更高版本,一切正常,如下所示在使用 marginBottom 时。

【问题讨论】:

    标签: android android-recyclerview vertical-scrolling android-nestedscrollview


    【解决方案1】:

    感谢您的评论和对我问题的回答,但是在挖掘了很多之后我没有发现任何有用的东西,尽管以编程方式设置高度。所以我在下面尝试了 sn-p,这就像一个魅力。 对于较高的变体,在 NestedScrollView 的布局 xml 中设置带有操作栏大小的 marginBottom,对于较低的变体,请使用下面的这个 Hack。

     NestedScrollingView nsv = findViewByID(R.id.nsv);
    
     if (android.os.Build.VERSION.SDK_INT < android.os.Build.VERSION_CODES.M){
            android.support.design.widget.CoordinatorLayout.LayoutParams lpm = new android.support.design.widget.CoordinatorLayout.LayoutParams(
                    android.support.design.widget.CoordinatorLayout.LayoutParams.MATCH_PARENT, android.support.design.widget.CoordinatorLayout.LayoutParams.MATCH_PARENT);
            lpm.setMargins(0,0,0,0);
            lpm.setBehavior(new android.support.design.widget.AppBarLayout.ScrollingViewBehavior());
            nsv.setLayoutParams(lpm);
            nsv.requestLayout();
        }
    

    再次感谢您的帮助。

    【讨论】:

      【解决方案2】:

      您可以尝试在 viewpagger 顶部添加 linearLayout 并尝试一下。

      <android.support.v4.widget.NestedScrollView
      android:layout_width="match_parent"
      android:layout_height="match_parent"
      app:layout_behavior="@string/appbar_scrolling_view_behavior">
      
      <LinearLayout
          android:layout_width="match_parent"
          android:layout_height="wrap_content"
          android:minHeight="800dp"
          android:orientation="vertical">
      
          <android.support.v4.view.ViewPager
              android:id="@+id/pager"
              android:layout_width="match_parent"
              android:layout_height="0dp"
              android:layout_weight="1"/>
      

      【讨论】:

      • 我已经使用了滚动视图,并且我正在使用折叠工具栏,所以我也将它与 nestedscrollviewenabled="true" 一起使用,但它不再起作用了。我面临的问题是 NestedScrollView 中的视图页高度。
      • 我已经尝试过您告诉我的建议,但我面临的问题是 viewPagers 高度。当我在嵌套滚动布局中添加 fillViewPort="true" 时,它占据了全高,因此,recyclerview 占据了 viewpager 的全高,总之,我的其他 recyclerview 项目是 goung outts 屏幕,但是嘿,一个 hack是当我添加工具栏高度的 marginBottom 时,它工作正常,但现在,问题在于较低的变量
      【解决方案3】:

      如果我理解您的问题,您必须添加工具栏的边距(正如您已经说过的)。我通过添加layout_gravity 解决了这个问题,如下所示。

      <android.support.v4.widget.NestedScrollView
      android:layout_width="match_parent"
      android:layout_height="match_parent"
      app:layout_behavior="@string/appbar_scrolling_view_behavior"
      android:layout_gravity="fill_vertical"
      android:layout_marginBottom="?attr/actionBarSize">
      

      【讨论】:

      • 是的,它正在解决更高版本的问题,每当我添加边距底部的操作栏大小......但这个边距对于较低的操作系统变体有问题,并在下面显示空白空间(给定边距)较低操作系统中的 viewpager。
      • 你也加了android:layout_gravity
      • 您的问题也可能是您在 FrameLayout 中使用了android:fitsSystemWindows="true"。在 coordinatorlayout 中使用它时遇到了很多麻烦。
      • 这只是一个示例,实际上我使用了所有不同的布局来整理它,以及所有其他技巧,但它们都没有奏效,我面临的问题是 viewpager 的大小,它占用了所有屏幕高度。
      • 然后请发布您的最终布局,以便我看一下。
      猜你喜欢
      • 1970-01-01
      • 2016-09-15
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-07-25
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多