CoordinatorLayout.Behavior回调不会触发

时间:2015-08-04 16:37:41

标签: android android-design-library androiddesignsupport android-coordinatorlayout coordinator-layout

我写了一个CordinatorLayout.Behaviour类并将其分配到CordinatorLayout的子节点,使用

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

但只调用layoutDependsOn,onStartNestedScroll,onInterceptTouchEvent回调,不调用rest。我做错了什么

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

2 个答案:

答案 0 :(得分:15)

根据onStartNestedScroll() Javadoc

  

只有从此方法返回true的行为才会收到后续的嵌套滚动事件。

默认行为始终是返回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;
}

答案 1 :(得分:0)

刚遇到同样的问题。事实上,我在google中发现了一个名为“NestedScrollView”的东西。 是的。 “NestedScrollView”就是答案。使用ScrollView,也可以在上面的anaswer中看到它。工作正常!