NestedScrollView and CoordinatorLayout. Issue on Scrolling

后端 未结 5 1930
灰色年华
灰色年华 2020-12-08 00:46

I have a strange issue with the CoordinatorLayout and the NestedScrollView (with the design support library 22.2.0)

Using a content smaller

相关标签:
5条回答
  • 2020-12-08 01:04

    I might be late with my answer but here goes. I was having a similar problem, but none of the above mentioned solutions worked for me. In the end I fixed it by using version 23 of the support library.

    ...
    compileSdkVersion 23
    ...
    targetSdkVersion 23
    ...
    compile 'com.android.support:appcompat-v7:23.1.0'
    compile 'com.android.support:support-v4:23.1.0'
    compile 'com.android.support:design:23.1.0'
    
    0 讨论(0)
  • 2020-12-08 01:05

    I think that it is not a bug in the support lib,just use this

    <android.support.v4.widget.NestedScrollView
        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"
        android:fillViewport="true"
        android:layout_gravity="fill_vertical"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">
    
    0 讨论(0)
  • 2020-12-08 01:12

    android:layout_gravity="fill_vertical" worked for me too.

    0 讨论(0)
  • 2020-12-08 01:20

    The onMeasureChild() method is called many times during the layout process. Apparently, the key is getting a non-zero value for the child height early in the process. ScrollingViewBehavior fails to do so in the following:

    int scrollRange = appBar.getTotalScrollRange();
    int height = parent.getHeight() 
                 - appBar.getMeasuredHeight()
                 + scrollRange;
    

    FixedScrollingviewBehavior fixes this with:

    int height = parent.getHeight() 
                 - appBar.getMeasuredHeight() 
                 + Math.min(scrollRange, parent.getHeight() - heightUsed);
    

    which very early gives height the value of -128, the height of the app bar.

    An alternative, close to the original is:

    int height = parent.getMeasuredHeight()
                 - appBar.getMeasuredHeight()
                 + scrollRange;
    
    0 讨论(0)
  • 2020-12-08 01:26

    This can also be observed in the cheesesquare demo when removing all but one card in the details fragment.

    I was able to solve this (for now) using this class: https://gist.github.com/EmmanuelVinas/c598292f43713c75d18e

    <android.support.v4.widget.NestedScrollView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="com.evs.demo.layout.FixedScrollingViewBehavior">
        .....   
    </android.support.v4.widget.NestedScrollView>
    
    0 讨论(0)
提交回复
热议问题