今天我分享一下ViewPager的双层嵌套时影响内部ViewPager的触摸滑动问题
之前在做自己的一个项目的时候,遇到广告栏图片动态切换,我第一时间想到的就是ViewPager,整个软件只有广告这一部分ViewPager还好说,但是软件越复杂出现的问题越多,尤其是遇到ViewPager双层嵌套问题,找了很多资料
解决方法一:自定义ViewPager做为父ViewPager控件
01 |
public class ParentViewPager extends ViewPager{ |
02 |
private int childVPHeight=0; |
03 |
public ParentViewPager(Context
context) { |
05 |
//
TODO Auto-generated constructor stub |
09 |
public ParentViewPager(Context
context, AttributeSet attrs) { |
10 |
super(context,
attrs); |
11 |
//
TODO Auto-generated constructor stub |
15 |
private void init(Context
context) { |
16 |
//
TODO Auto-generated method stub |
18 |
WindowManager
windowManager = (WindowManager) context.getSystemService(context.WINDOW_SERVICE); |
19 |
int disWidth
= windowManager.getDefaultDisplay().getWidth(); |
21 |
childVPHeight=(int)
(context.getResources().getDisplayMetrics().density * disWidth + 0.5f); |
25 |
public boolean onInterceptTouchEvent(MotionEvent
arg0) { |
26 |
//
TODO Auto-generated method stub |
27 |
//触摸在子ViewPager所在的页面和子ViewPager控件高度之内时 |
28 |
//返回false,此时将会将触摸的动作传给子ViewPager |
29 |
if(getCurrentItem()==1 &&
arg0.getY()<childVPHeight){ |
32 |
return super.onInterceptTouchEvent(arg0); |
此方法虽然简单可行,但是会出现,子ViewPager如果为ScrollView的时候,子ViewPager虽然已经滑动到看不到的地方,但是设定的高度内还是不能让父ViewPager左右滑动,onTouch的动作透过了父Viewpager传递到了子控件
**解决方法二:自定义Viewpager做为子控件**
01 |
public class ChildViewPager extends ViewPager{ |
03 |
PointF
downP = new PointF(); |
05 |
PointF
curP = new PointF(); |
06 |
OnSingleTouchListener
onSingleTouchListener; |
08 |
public ChildViewPager(Context
context, AttributeSet attrs) { |
09 |
super(context,
attrs); |
10 |
//
TODO Auto-generated constructor stub |
13 |
public ChildViewPager(Context
context) { |
15 |
//
TODO Auto-generated constructor stub |
19 |
public boolean onInterceptTouchEvent(MotionEvent
arg0) { |
20 |
//
TODO Auto-generated method stub |
21 |
//当拦截触摸事件到达此位置的时候,返回true, |
22 |
//说明将onTouch拦截在此控件,进而执行此控件的onTouchEvent |
27 |
public boolean onTouchEvent(MotionEvent
arg0) { |
28 |
//
TODO Auto-generated method stub |
29 |
//每次进行onTouch事件都记录当前的按下的坐标 |
33 |
if(arg0.getAction()
== MotionEvent.ACTION_DOWN){ |
35 |
//切记不可用
downP = curP ,这样在改变curP的时候,downP也会改变 |
36 |
downP.x
= arg0.getX(); |
37 |
downP.y
= arg0.getY(); |
38 |
//此句代码是为了通知他的父ViewPager现在进行的是本控件的操作,不要对我的操作进行干扰 |
39 |
getParent().requestDisallowInterceptTouchEvent(true); |
42 |
if(arg0.getAction()
== MotionEvent.ACTION_MOVE){ |
43 |
//此句代码是为了通知他的父ViewPager现在进行的是本控件的操作,不要对我的操作进行干扰 |
44 |
getParent().requestDisallowInterceptTouchEvent(true); |
47 |
if(arg0.getAction()
== MotionEvent.ACTION_UP){ |
48 |
//在up时判断是否按下和松手的坐标为一个点 |
49 |
//如果是一个点,将执行点击事件,这是我自己写的点击事件,而不是onclick |
50 |
if(downP.x==curP.x
&& downP.y==curP.y){ |
56 |
return super.onTouchEvent(arg0); |
62 |
public void onSingleTouch()
{ |
63 |
if (onSingleTouchListener!= null)
{ |
65 |
onSingleTouchListener.onSingleTouch(); |
74 |
public interface OnSingleTouchListener
{ |
75 |
public void onSingleTouch(); |
78 |
public void setOnSingleTouchListener(OnSingleTouchListener
onSingleTouchListener) { |
79 |
this.onSingleTouchListener
= onSingleTouchListener; |
为什么要自己定义onSingleTouch呢?
因为在ViewPager的onTouchEvent中我对onDown进行了操作,进行了操作后就无法将touch事件继续往下传给onClick和其内部控件的任何事件,所以自己做了判断,做了个singleTouch来实现点击的事件
方法二可以完美解决双层ViewPager嵌套后子ViewPager的触摸滑动问题
- Android 使用ViewPager实现左右循环滑动图片
ViewPager这个小demo实现的是可以左右循环滑动图片,下面带索引,滑到最后一页在往右滑动就要第一页,第一页往左滑动就到最后一页,先上效果图,用美女图片是我一贯的作风,呵呵 1. 首先看一 ...
- 解决ViewPager与百度地图滑动冲突
一.问题描述 ViewPager中嵌套百度地图的时候会出现百度地图滑动冲突. 二.期望结果: 滑动地图的时候只有地图滑动,滑动其他区域可以切换viewpager. 三.解决方法 自定义viewpage ...
- android笔记:ViewPager实现界面的滑动
最近在学习ViewPager实现界面的滑动,拜读了郭神的博客文章,并抽取归纳了自己对ViewPager的理解. ViewPager实现界面滑动的步骤如下: 1.在xml布局内加入控件android.s ...
- Android使用ViewPager实现左右循环滑动及轮播效果
边界的时候会看到一个不能翻页的动画,可能影响用户体验.此外,某些区域性的ViewPager(例如展示广告或者公告之类的ViewPager),可能需要自动轮播的效果,即用户在不用滑动的情况下就能够看到其 ...
- viewpager双层嵌套,子viewpager无限循环无法手动滑动
项目中首页是用viewpager+fragment集成的,第一个fragment有广告轮播图使用viewpager实现的,开始就遇到是广告图无法手动滑动,事件被外层的viewpager拦截响应切换到下 ...
- viewPager双层嵌套的事件问题
问题描述: ViewPager嵌套viewPager, 当childViewPager中加入了Onclick事件, 导致childViewpager的滑动消息被拦截掉. 很无奈. 解决方法: 重写c ...
- Android 解决ScrollView下嵌套ListView进页面不在顶部的问题
以下为整理: 方法1 刚开始还可以,后来再调试时就不行了. 为了解决scrollview和listview冲突 设置了listview的高度 结果进页面就不是在顶部了 . 解决方案1:Scrol ...
- Android之ViewPager组件实现左右滑动View
什么是ViewPager VIewPager是安卓3.0之后提供的新特性,继承自ViewGroup,专门用来实现左右滑动切换View的效果.如果想向下兼容需要 android-support-v4.j ...
- android 解决ListView点击与滑动事件冲突
如果你的ListView的Item有滑动功能,但又点击Item跳转到其它activity,这样若是在Adapter里面写点击事件是会导致滑动事件获取不到焦点而失效: 解决方法:不要在adapter里面 ...
随机推荐
- statistics specify some columns count
# -k1 follow the first column nr
- Iso language code table之(软件国际化)
ISO 639是用来区分所有已知的语言规范的术语.每种语言都分配两个字母(639-1)或三个英文字母(639-2和639-3),小写字母的缩写,修订后的版本命名的.该系统是非常有用的语言学家和人类学家 ...
- php传参方式1--ajax
AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术. AJAX = 异步 JavaScript和 ...
- hdu 5730 Shell Necklace fft+cdq分治
题目链接 dp[n] = sigma(a[i]*dp[n-i]), 给出a1.....an, 求dp[n]. n为1e5. 这个式子的形式显然是一个卷积, 所以可以用fft来优化一下, 但是这样也是会 ...
- FAQ:Python 断点调试
Python程序调试:断点调试是必须有的功能,以Pycharm开发工具为例: 一.理论知识: 1. step into(F7)就是单步执行,遇到子函数就进入并且继续单步执行: 2 step over ...
- WPF中的触发器简单总结
原文 http://blog.sina.com.cn/s/blog_5f2ed5cb0100p3ab.html 触发器,从某种意义上来说它也是一种Style,因为它包含有一个Setter集合,并根据一 ...
- C语言入门(11)——switch分支语句
C语言提供了一种用于多分支选择的switch语句, 其一般形式为: switch(表达式) { case 常量表达式1:语句1; break; case 常量表达式2:语句2; break; .... ...
- android:configChanges 屏幕横竖屏切换
出处:http://blog.csdn.net/djy1992/article/details/9378195 ---> android:screenOrientation="por ...
- 截取字符串一之substr
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- CSS3 grayscale滤镜图片变黑白实例页面
在网站加入友情链接的LOGO时,因为不同logo颜色的问题,和主题色调可能产生冲突, 我选择用CSS3滤镜让logo变黑白,hover时变回原本的彩色 CSS代码: .gray { -webkit-f ...