我写了一个CordinatorLayout.Behaviour
类并将其分配到CordinatorLayout的子节点,使用
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);
}
}
答案 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中看到它。工作正常!