Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/212.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android AppBarLayout.ScrollingViewBehavior-屏幕外视图的底部_Android_Android Layout_Android Coordinatorlayout_Coordinator Layout - Fatal编程技术网

Android AppBarLayout.ScrollingViewBehavior-屏幕外视图的底部

Android AppBarLayout.ScrollingViewBehavior-屏幕外视图的底部,android,android-layout,android-coordinatorlayout,coordinator-layout,Android,Android Layout,Android Coordinatorlayout,Coordinator Layout,当将AppBarLayout与标准的ScrollingViewBehavior一起使用时,默认情况下,AppBarLayout的同级将为坐标布局的高度,同级的底部将由AppBarLayout的高度偏移屏幕 在我的用例中,NestedScrollView仅仅是一个允许折叠工具栏的工具,同时在可折叠工具栏下方显示另一个可滚动视图(本例中为片段)。片段是包含底部固定视图的片段(本例中为FAB) 下面的图片演示了我正在描述的问题,提供的代码是导致该问题的基本XML <?xml version="1

当将
AppBarLayout
与标准的
ScrollingViewBehavior
一起使用时,默认情况下,AppBarLayout的同级将为坐标布局的高度,同级的底部将由AppBarLayout的高度偏移屏幕

在我的用例中,
NestedScrollView
仅仅是一个允许折叠工具栏的工具,同时在可折叠工具栏下方显示另一个可滚动视图(本例中为片段)。片段是包含底部固定视图的片段(本例中为FAB)

下面的图片演示了我正在描述的问题,提供的代码是导致该问题的基本XML

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

    <android.support.design.widget.AppBarLayout
        android:id="@+id/appBarLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            app:layout_scrollFlags="scroll|enterAlways" />

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

    <android.support.v4.widget.NestedScrollView
        android:id="@+id/nestedScrollView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

        <LinearLayout
            android:id="@+id/fragmentHolder"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical">

        </LinearLayout>

    </android.support.v4.widget.NestedScrollView>

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


我找到的解决这个问题的方法包括两个部分

  • 将等于
    AppBarLayout
    高度的填充添加到
    NestedScrollView
    的底部。在我的例子中,因为AppBarLayout只包含一个
    工具栏
    ,所以高度为
    ?attr/actionBarSize

    android:paddingBottom=“?attr/actionBarSize”

  • 将自定义的
    AppBarLayout.OnOffsetChangedListener
    添加到
    AppBarLayout
    中,这会在工具栏折叠时更改
    NestedScrollView
    的高度

    class ScrollingOffsetFixListener(
        private val nestedScrollView: NestedScrollView
    ): AppBarLayout.OnOffsetChangedListener {
    
    private var originalHeight = 0
    private var firstOffset = true
    
    override fun onOffsetChanged(layout: AppBarLayout?, offset: Int) {
        if(firstOffset) {
            firstOffset = false
            originalHeight = nestedScrollView.measuredHeight
        }
    
        val params = nestedScrollView.layoutParams
        params.height = originalHeight + (offset * -1)
    
        nestedScrollView.layoutParams = params
       }
    }