5

я написал CordinatorLayout.Behaviour класс и назначил его в ребенке CordinatorLayout, в нескольких LinearLayout с помощьюCoordinatorLayout.Behavior обратные вызовы не вызывают

app:layout_behavior="com.mob2.zd2duta.infodrawer.components. FloatingHeaderBehaviour" 

но только layoutDependsOn, onStartNestedScroll, onInterceptTouchEvent обратные вызовы называются, остальные не получают называется. Что я делаю неправильно

public class FloatingHeaderBehaviour extends CoordinatorLayout.Behavior<LinearLayout> { 

    private String TAG = FloatingHeaderBehaviour.class.getSimpleName(); 
    private Context context; 

    public FloatingHeaderBehaviour(Context context, AttributeSet attrs) { 
     this.context = context; 
    } 

    @Override 
    public boolean layoutDependsOn(CoordinatorLayout parent, LinearLayout child, View dependency) { 
     boolean val = (dependency.getId() == R.id.nested_scrollview); 
     return val; 
    } 

    @Override 
    public boolean onDependentViewChanged(CoordinatorLayout parent, LinearLayout child, View dependency) { 

     Utils.logD(this.getClass().getSimpleName(), "dependency changed"); 
     return true; 
    } 

    @Override 
    public boolean onStartNestedScroll(CoordinatorLayout coordinatorLayout, LinearLayout child, View directTargetChild, View target, int nestedScrollAxes) { 

     Utils.logD(this.getClass().getSimpleName(), "scroll started"); 
     return super.onStartNestedScroll(coordinatorLayout,child, directTargetChild, target, nestedScrollAxes); 
    } 

    @Override 
    public void onStopNestedScroll(CoordinatorLayout coordinatorLayout, LinearLayout child, View target) { 
     Utils.logD(this.getClass().getSimpleName(), "scroll stopped"); 
     super.onStopNestedScroll(coordinatorLayout, child, target); 
    } 

    @Override 
    public void onNestedScroll(CoordinatorLayout coordinatorLayout, LinearLayout child, View target, int dxConsumed, int dyConsumed, int dxUnconsumed, int dyUnconsumed) { 
     Utils.logD(this.getClass().getSimpleName(), "scroll changed"); 
     super.onNestedScroll(coordinatorLayout, child, target, dxConsumed, dyConsumed, dxUnconsumed, dyUnconsumed); 
    } 

    @Override 
    public void onNestedPreScroll(CoordinatorLayout coordinatorLayout, LinearLayout child, View target, int dx, int dy, int[] consumed) { 
     Utils.logD(this.getClass().getSimpleName(), "scroll pre"); 
     super.onNestedPreScroll(coordinatorLayout, child, target, dx, dy, consumed); 
    } 

    @Override 
    public boolean onInterceptTouchEvent(CoordinatorLayout parent, LinearLayout child, MotionEvent ev) { 
     Utils.logD(this.getClass().getSimpleName(), "onInterceptTouchEvent"); 
     return super.onInterceptTouchEvent(parent, child, ev); 
    } 

    @Override 
    public boolean onTouchEvent(CoordinatorLayout parent, LinearLayout child, MotionEvent ev) { 
     Utils.logD(this.getClass().getSimpleName(), "onTouchEvent"); 
     return super.onTouchEvent(parent, child, ev); 
    } 

    @Override 
    public void onNestedScrollAccepted(CoordinatorLayout coordinatorLayout, LinearLayout child, View directTargetChild, View target, int nestedScrollAxes) { 
     Utils.logD(this.getClass().getSimpleName(), "onNestedScrollAccepted"); 
     super.onNestedScrollAccepted(coordinatorLayout, child, directTargetChild, target, nestedScrollAxes); 
    } 

    @Override 
    public boolean onNestedFling(CoordinatorLayout coordinatorLayout, LinearLayout child, View target, float velocityX, float velocityY, boolean consumed) { 
     Utils.logD(this.getClass().getSimpleName(), "onNestedFling"); 
     return super.onNestedFling(coordinatorLayout, child, target, velocityX, velocityY, consumed); 
    } 

    @Override 
    public boolean onNestedPreFling(CoordinatorLayout coordinatorLayout, LinearLayout child, View target, float velocityX, float velocityY) { 
     Utils.logD(this.getClass().getSimpleName(), "onNestedPreFling"); 
     return super.onNestedPreFling(coordinatorLayout, child, target, velocityX, velocityY); 
    } 
} 

ответ

13

Пер с onStartNestedScroll() Javadoc:

Только Поведения, которые возвращают истинное от этого метода будет принимать последующие вложенные события прокрутки.

Поведение по умолчанию всегда возвращать false, что и вы возвращаете, когда вы звоните return super.onStartNestedScroll(). Вместо этого вы должны вернуться true для nestedScrollAxes вы хотите получить события прокрутки для:

@Override 
public boolean onStartNestedScroll(final CoordinatorLayout coordinatorLayout, 
     final FloatingActionButton child, final View directTargetChild, 
     final View target, final int nestedScrollAxes) { 
    return nestedScrollAxes == ViewCompat.SCROLL_AXIS_VERTICAL; 
} 
0

Просто была такая же проблема. Как бы то ни было, я нашел в Google что-то под названием «NestedScrollView». И да. «NestedScrollView» - это ответ. Используйте его в ScrollView, а также сделайте то, что вы можете увидеть в приведенном выше тексте. Работает отлично !

+0

Не могли бы вы предоставить полный ответ? Ответ «выше» не всегда может быть выше. – slfan