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
}
}