修改ScrollView的滑动速度和解决ScrollView与ViewPager的冲突
2014-11-13 16:48
417 查看
话不多说,很简单,可以从注释中知道做法,直接上代码:
1、修改ScrollView的滑动速度:
public class MyHorizontalScrollView extends HorizontalScrollView {
public MyHorizontalScrollView(Context context) {
super(context);
}
public MyHorizontalScrollView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
public MyHorizontalScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
public void fling(int velocityX) {
//重写fling方法,将速度除以三,减缓其滑动速度
super.fling(velocityX / 3);
}
}
2、解决ScrollView与ViewPager的冲突:
public class PagerScrollView extends ScrollView {
private float xDistance, yDistance, xLast, yLast;
public PagerScrollView(Context context) {
super(context);
}
public PagerScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public PagerScrollView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
switch (ev.getAction()) {
case MotionEvent.ACTION_DOWN:
xDistance = yDistance = 0f;
xLast = ev.getX();
yLast = ev.getY();
break;
case MotionEvent.ACTION_MOVE:
final float curX = ev.getX();
final float curY = ev.getY();
xDistance += Math.abs(curX - xLast);
yDistance += Math.abs(curY - yLast);
xLast = curX;
yLast = curY;
/**
* X轴滑动距离大于Y轴滑动距离,也就是用户横向滑动时,返回false,ScrollView不处理这次事件,
* 让子控件中的TouchEvent去处理,所以横向滑动的事件交由ViewPager处理,
* ScrollView只处理纵向滑动事件
*/
if (xDistance > yDistance) {
return false;
}
}
return super.onInterceptTouchEvent(ev);
}
}
1、修改ScrollView的滑动速度:
public class MyHorizontalScrollView extends HorizontalScrollView {
public MyHorizontalScrollView(Context context) {
super(context);
}
public MyHorizontalScrollView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
public MyHorizontalScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
public void fling(int velocityX) {
//重写fling方法,将速度除以三,减缓其滑动速度
super.fling(velocityX / 3);
}
}
2、解决ScrollView与ViewPager的冲突:
public class PagerScrollView extends ScrollView {
private float xDistance, yDistance, xLast, yLast;
public PagerScrollView(Context context) {
super(context);
}
public PagerScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public PagerScrollView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
switch (ev.getAction()) {
case MotionEvent.ACTION_DOWN:
xDistance = yDistance = 0f;
xLast = ev.getX();
yLast = ev.getY();
break;
case MotionEvent.ACTION_MOVE:
final float curX = ev.getX();
final float curY = ev.getY();
xDistance += Math.abs(curX - xLast);
yDistance += Math.abs(curY - yLast);
xLast = curX;
yLast = curY;
/**
* X轴滑动距离大于Y轴滑动距离,也就是用户横向滑动时,返回false,ScrollView不处理这次事件,
* 让子控件中的TouchEvent去处理,所以横向滑动的事件交由ViewPager处理,
* ScrollView只处理纵向滑动事件
*/
if (xDistance > yDistance) {
return false;
}
}
return super.onInterceptTouchEvent(ev);
}
}
相关文章推荐
- 改动ScrollView的滑动速度和解决ScrollView与ViewPager的冲突
- VerticalViewPager和ScrollView的滑动冲突解决
- Android ScrollView嵌套ViewPager滑动失效和无法正常滑动冲突问题解决方案
- android scrollView 内嵌ViewPager或Gallery等水平滑动控件冲突问题解决实现同时滑动
- ViewPager,ScrollView 嵌套ViewPager滑动冲突解决
- 完美解决ScrollView嵌套ViewPager滑动失效和无法正常滑动冲突问题
- ScrollView和ViewPager滑动冲突的解决和整理
- ViewPager,ScrollView 嵌套ViewPager滑动冲突解决
- 解决ScrollView嵌套ViewPager出现的滑动冲突问题
- ViewPager,ScrollView 嵌套ViewPager滑动冲突解决
- ViewPager,ScrollView 嵌套ViewPager滑动冲突解决
- 安卓解决viewPager和scrollView和listView滑动冲突的问题
- 完美解决ScrollView嵌套ViewPager滑动失效和无法正常滑动冲突问题
- 修改ViewPager调用setCurrentItem时,滑屏的速度 ,解决滑动之间切换动画难看
- scrollview 嵌套 viewpager 滑动冲突的解决办法
- 解决ScrollView嵌套ViewPager出现的滑动冲突问题
- 解决ScrollView和VerticalViewPager滑动事件冲突问题
- (转)ViewPager,ScrollView 嵌套ViewPager滑动冲突解决
- 解决ScrollView嵌套ViewPager出现的滑动冲突问题
- NestedScrollView中嵌套ViewPager或RecyclerView出现滑动冲突的解决