一、上图

二、场景描写叙述

最近在做项目的时候。遇到一个怪异的需求,描写叙述例如以下:

1、ViewPager中嵌套3个View,当从View1滑动到View2时禁止ViewPager的滑动事件。

2、通过View2底部改变页面的布局实现滑动到View1和View3.

3、View2内嵌的View中还存在一个能够左右滑动的View。在其上加入了手势。即支持左右滑动,这里存在事件冲突,须要通过事件分发来进行处理。

三、问题解决思路

1、禁止ViewPager滑动。主要是不让ViewPager运行scrollTo(int x,int y)这种方法。这个參考了网上的做法,即自己定义一个ViewPager。通过设置一个开关标志位。来决定是否运行scrollTo方法。代码例如以下:

package com.example.viewpagerscrollconflict.views;

import android.content.Context;
import android.support.v4.view.ViewPager;
import android.util.AttributeSet;
import android.util.Log;
import android.view.MotionEvent; public class CustomViewPager extends ViewPager {
private static final String TAG = "CustomViewPager"; private boolean isCanScroll = true; public CustomViewPager(Context context) {
super(context);
} public CustomViewPager(Context context, AttributeSet attrs) {
super(context, attrs);
} public void setScanScroll(boolean isCanScroll) {
this.isCanScroll = isCanScroll;
} public boolean isCanScroll() {
return isCanScroll;
} @Override
public void scrollTo(int x, int y) {
if (isCanScroll) {
super.scrollTo(x, y);
}
} /**
* 事件分发
*/
@Override
public boolean dispatchTouchEvent(MotionEvent ev) {
Log.i(TAG, "====dispatchTouchEvent====事件分发");
if(getCurrentItem() == 1){
isCanScroll = false;
this.requestDisallowInterceptTouchEvent(true); }
return super.dispatchTouchEvent(ev);
} /**
* 事件拦截
*/
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
Log.i(TAG, "====onInterceptTouchEvent====事件拦截");
return super.onInterceptTouchEvent(ev);
} /**
* 事件响应
*/
@Override
public boolean onTouchEvent(MotionEvent event) {
Log.i(TAG, "====onTouchEvent====事件响应");
return super.onTouchEvent(event);
}
}

2、要实现View2底部改变页面的布局滑动到View1和View3

这里主要是为改变页面的布局加入滑动手势来进行滑动切换的。

(稍后给出源代码)

3、ViewPager与其内嵌的View水平滑动事件冲突解决思路(上主要代码)

(1)当处在View2页面时。首先让ViewPager禁止滑动。

(2)将事件分发给View2内嵌的View让其依据用户的手势进行滑动。

	/**
* 事件分发
*/
@Override
public boolean dispatchTouchEvent(MotionEvent ev) {
Log.i(TAG, "====dispatchTouchEvent====事件分发");
if(getCurrentItem() == 1){
isCanScroll = false;
//告诉ViewPager不要拦截子View中的各种事件
this.requestDisallowInterceptTouchEvent(true);
}
return super.dispatchTouchEvent(ev);
}

三、Activity中的代码

package com.example.viewpagerscrollconflict;

import java.util.ArrayList;
import java.util.List; import android.app.Activity;
import android.os.Bundle;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.util.Log;
import android.view.GestureDetector;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener; import com.example.viewpagerscrollconflict.adapters.ViewPagerAdapter;
import com.example.viewpagerscrollconflict.gestures.ViewPagerGestureListener;
import com.example.viewpagerscrollconflict.views.CustomViewPager;
import com.example.viewpagerscrollconflict.views.ScrollLinearLayout; public class MainActivity extends Activity{
private static final String TAG = "MainActivity";
private GestureDetector mDetector;
/**布局载入器**/
private LayoutInflater inflater;
private CustomViewPager mVpViewPager;
private ViewPagerAdapter vpAdapter;
private View v1, v2, v3;
private List<View> viewList;
private ScrollLinearLayout sllChangePage; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); mVpViewPager = (CustomViewPager) findViewById(R.id.vp_view_pager);
inflater = LayoutInflater.from(this);
v1 = inflater.inflate(R.layout.layout_1, null);
v2 = inflater.inflate(R.layout.layout_2, null);
v3 = inflater.inflate(R.layout.layout_3, null); mDetector = new GestureDetector(this, new ViewPagerGestureListener(mVpViewPager));
sllChangePage = (ScrollLinearLayout) findViewById(R.id.sll_change_page);
sllChangePage.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
mDetector.onTouchEvent(event);
return true;
}
}); viewList = new ArrayList<View>();
viewList.add(v1);
viewList.add(v2);
viewList.add(v3);
vpAdapter = new ViewPagerAdapter(viewList);
mVpViewPager.setAdapter(vpAdapter);
mVpViewPager.setOnPageChangeListener(new MyPageChangeListener());
} class MyPageChangeListener implements OnPageChangeListener { @Override
public void onPageScrollStateChanged(int arg0) { } @Override
public void onPageScrolled(int arg0, float arg1, int arg2) { } @Override
public void onPageSelected(int arg0) {
switch (arg0) {
case 0:
Log.i(TAG, "=======page=======" + arg0);
break;
case 1:
Log.i(TAG, "=======page=======" + arg0);
if (!mVpViewPager.isCanScroll()) {//假设不能够滑动
Log.i(TAG, "在页面1中。不能够滑动");
mVpViewPager.setCurrentItem(1);
}
break;
case 2:
Log.i(TAG, "=======page=======" + arg0);
if (!mVpViewPager.isCanScroll()) {//假设不能够滑动
Log.i(TAG, "在页面2中。不能够滑动");
mVpViewPager.setCurrentItem(1);
}
break;
}
} } }

四、项目源代码下载链接

http://download.csdn.net/detail/xiogjie_67/8897119




ViewPager禁止滑动以及它与内层滑动控件水平方向上事件冲突的解决方法的更多相关文章

  1. scrollview嵌套listview 滑动事件冲突的解决方法

    listView.setOnTouchListener(new View.OnTouchListener() {                            @Override       ...

  2. 关于Android滑动冲突的解决方法(二)

    之前的一遍学习笔记主要就Android滑动冲突中,在不同方向的滑动所造成冲突进行了了解,这样的冲突非常easy理解,当然也非常easy解决.今天,就同方向的滑动所造成的冲突进行一下了解,这里就先以垂直 ...

  3. Android ViewPager+Fragment 在Activity中获取Fragment的控件

    如果ViewPager+Fragment实现Tab切换,在activity中利用adapter.getItem获取到fragment然后再根据fragment.的方法获取控件 //隐藏求租,以下代码用 ...

  4. vue项目使用前端框架开发,实现滑动效果,若不刷新页面则无法达到预期效果的问题及解决方法

    滑动等效果的初始化时机很重要,在vue项目开发中,需到mounted()钩子函数 (当组件中的DOM结构被渲染好并放到页面中后,会执行这个钩子函数,此时即可初始化滑动效果的js代码). 若组件未挂载到 ...

  5. WP8__实现ListBox横向滑动及子项绑定图片等控件

    <!--实现绑定的图片等信息 ListBox水平滚动--> <Grid> <Grid.Resources> <Style x:Key="horizo ...

  6. Viewpager禁止滑动

    参考:http://www.jianshu.com/p/d3d766cf73d7 public class NoScrollViewPager extends ViewPager { private ...

  7. Android导航菜单横向左右滑动并和下方的控件实现联动

    这个是美团网个人订单的效果,找了很多地方都没找到,自己研究了两天终于弄出来了^_^,有什么问题希望大家指出来,谢谢. 实现原理是上方使用HorizontalScrollView这个可以水平横向拖动的控 ...

  8. webview滑动事件 与内部html左右滑动事件冲突问题的解决办法

    最近在做个混合app , 用html做页面,然后通过webview嵌套在activity中,效果是这样: 开始还是比较顺利,增加了菜单退出按钮,返回键页面回退功能,页面加载显示加载图标(在app端实现 ...

  9. Android 实现 IOS相机滑动控件

     IOS相比于Android,动画效果是一方面优势,IOS相机切换时滑动的动画很不错,看着是有一个3D的效果,而且变化感觉很自然.Android也可以通过Graphics下面的Camera可以实现3D ...

随机推荐

  1. 第二部分面向对像基础第五章Strng类中方法的使用

    package com.java.oop.day2; import java.util.Calendar; import java.util.Formatter; import java.util.L ...

  2. asp.net C# 导出EXCEL数据

    if (dt == null) { return ""; } Microsoft.Office.Interop.Excel.Application xlApp = new Micr ...

  3. C#实现发送邮件

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  4. cxf客户端代码设置设置访问用户名、密码、证书域名不匹配认证通过

    最近和第三方联调,需要调用对方的wsdl,但是调用必须的设置用户名.密码验证.在soapUI里面设置用户名.密码调用通过.但是怎么转换成JAVA代码呢,搜索了好多解决方案,现将代码截图如下: 1.SO ...

  5. Js 旋转平滑特效

    效果图 源码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. ...

  6. Python md5 sha1 的使用

    版本: Python 2.7 说明: Python 内置的 hashlib 模块中有 md5 和 sha1 加密方法,可以直接使用. md5加密 import hashlib data = 'This ...

  7. [jQuery编程挑战]001:实现页面元素加速动画效果

    要求: 页面包含两个HTML元素:一个按钮,一个小方块 动画要求:点击按钮,小方块从页面坐标300,300,加速移动到0,0 相关知识点: jQuery动画方法animate easing参数的设置 ...

  8. 字符串截取slice() substring() substr()的区别?

    获取子字符串 slice()        substr()    substring() 不会修改字符串本身,他们只是返回一个基本类型的字符串值 var str='abcdefghijklmn'; ...

  9. thinkphp action.class.php 学习

    控制器类(Action) 描述 Description ThinkPHP Action控制器基类 抽象类 位置:ThinkPHP/Lib/Core/Action.class.php 声明: abstr ...

  10. CSS3圆角详解

    一.CSS3圆角的优点 传统的圆角生成方案,必须使用多张图片作为背景图案.CSS3的出现,使得我们再也不必浪费时间去制作这些图片了,而且还有其他多个优点: * 减少维护的工作量.图片文件的生成.更新. ...