Seekbar 在 viewpager 内滚动不流畅
Seekbar not scrolling smoothly inside viewpager
一个片段包含一个具有两个片段的viewpager。在第一个中,搜索栏不滚动,但在尝试滚动时滑动 viewpager。似乎 viewpager 偏移量在尝试滚动时被激活。但问题是我在另一个菜单中有相同类型的配置并且它有效。解决方案是什么?
我认为这两个片段都有一个变化。一个添加了 swiperefreshlayout,另一个没有。
在此之后,我认为解决方案如下所示。
如果有人仍然对这个问题感到困惑。创建 SwipeRefreshlayout 的自定义 class 并添加到布局。
public class CustomSwipeRefresh extends SwipeRefreshLayout {
private int mTouchSlop;
private float mPrevX;
private boolean isDisabled;
public CustomSwipeRefresh(Context context, AttributeSet attrs) {
super(context, attrs);
mTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();
}
public void disableInterceptTouchEvent(boolean isDisabled) {
this.isDisabled = isDisabled;
getParent().requestDisallowInterceptTouchEvent(isDisabled);
}
@Override
public boolean onInterceptTouchEvent(MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
mPrevX = MotionEvent.obtain(event).getX();
break;
case MotionEvent.ACTION_MOVE:
if (isDisabled) {
return false;
}
float eventX = event.getX();
float xDiff = Math.abs(eventX - mPrevX);
if (xDiff > mTouchSlop) {
return false;
}
}
return super.onInterceptTouchEvent(event);
}
}
然后在带有搜索栏的片段 class 上,只需添加代码
mswiperefresh.disableInterceptTouchEvent(布尔值);
启用和禁用滑动焦点。
@Override public void onStartTrackingTouch(SeekBar seekBar) {
mswiperefresh.disableInterceptTouchEvent(true);
}
@Override
public void onStopTrackingTouch(SeekBar seekBar) {
mswiperefresh.disableInterceptTouchEvent(false);
}
一个片段包含一个具有两个片段的viewpager。在第一个中,搜索栏不滚动,但在尝试滚动时滑动 viewpager。似乎 viewpager 偏移量在尝试滚动时被激活。但问题是我在另一个菜单中有相同类型的配置并且它有效。解决方案是什么?
我认为这两个片段都有一个变化。一个添加了 swiperefreshlayout,另一个没有。
在此之后,我认为解决方案如下所示。
如果有人仍然对这个问题感到困惑。创建 SwipeRefreshlayout 的自定义 class 并添加到布局。
public class CustomSwipeRefresh extends SwipeRefreshLayout {
private int mTouchSlop;
private float mPrevX;
private boolean isDisabled;
public CustomSwipeRefresh(Context context, AttributeSet attrs) {
super(context, attrs);
mTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();
}
public void disableInterceptTouchEvent(boolean isDisabled) {
this.isDisabled = isDisabled;
getParent().requestDisallowInterceptTouchEvent(isDisabled);
}
@Override
public boolean onInterceptTouchEvent(MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
mPrevX = MotionEvent.obtain(event).getX();
break;
case MotionEvent.ACTION_MOVE:
if (isDisabled) {
return false;
}
float eventX = event.getX();
float xDiff = Math.abs(eventX - mPrevX);
if (xDiff > mTouchSlop) {
return false;
}
}
return super.onInterceptTouchEvent(event);
}
}
然后在带有搜索栏的片段 class 上,只需添加代码
mswiperefresh.disableInterceptTouchEvent(布尔值); 启用和禁用滑动焦点。
@Override public void onStartTrackingTouch(SeekBar seekBar) {
mswiperefresh.disableInterceptTouchEvent(true);
}
@Override
public void onStopTrackingTouch(SeekBar seekBar) {
mswiperefresh.disableInterceptTouchEvent(false);
}