解决SlidingMenu 侧滑与ViewPager冲突问题
2013-09-15 19:15
246 查看
由于使用了Github上的开源项目,开始以为需要自己在CustomViewAbove中改写OnInterceptTouchEvent(MotionEvent ev);
参看了一下百度视频App,发现它在首页里的ViewPager控件在下拉后,只有上面部分可以响应左右滑动事件,下面的部分却不可以,于是我猜想它把上面部分写死了,先调用view.getHitRect(rect)来获得viewpager的矩形框位置,然后,判断触摸的点是否在矩形框内。
本以为要自己写的。后来在查看CustomViewAbove的OnInterceptTouchEvent(MotionEvent ev)方法时,看到有个方法thisTouchAllowed(ev);
于是展开去看
居然后有个方法,isInIgnoreView(),如果不在忽略的View中,就会返回true传给CustomViewAbove自己的onTouchEvent()来消费该事件,于是猜想是不是有个方法可以可以把slidingMenu把想忽视侧滑这一触摸事件的View加入判断中,
原来mIgnoredViews是一个ArrayList<View>,而且还有一个这样的方法。
SlidingMenu类中又调用了CustomViewAbove的addIgnoreView()
于是找到解决办法了,如果是MainActivity继承SlidingFragmentActivity的这种情况,可以做如下处理:
在自己定义的Fragment中:
大功告成!
参看了一下百度视频App,发现它在首页里的ViewPager控件在下拉后,只有上面部分可以响应左右滑动事件,下面的部分却不可以,于是我猜想它把上面部分写死了,先调用view.getHitRect(rect)来获得viewpager的矩形框位置,然后,判断触摸的点是否在矩形框内。
Rect rect = new Rect(); viewPager.getHitRect(rect); if(rect.contains(event.getX(), event.getY()) return false;
本以为要自己写的。后来在查看CustomViewAbove的OnInterceptTouchEvent(MotionEvent ev)方法时,看到有个方法thisTouchAllowed(ev);
case MotionEvent.ACTION_DOWN: mActivePointerId = ev.getAction() & ((Build.VERSION.SDK_INT >= 8) ? MotionEvent.ACTION_POINTER_INDEX_MASK : MotionEvent.ACTION_POINTER_INDEX_MASK); mLastMotionX = mInitialMotionX = MotionEventCompat.getX(ev, mActivePointerId); mLastMotionY = MotionEventCompat.getY(ev, mActivePointerId); if (thisTouchAllowed(ev)) { mIsBeingDragged = false; mIsUnableToDrag = false; if (isMenuOpen() && mViewBehind.menuTouchInQuickReturn(mContent, mCurItem, ev.getX() + mScrollX)) { mQuickReturn = true; } } else { mIsUnableToDrag = true; } break;
于是展开去看
private boolean thisTouchAllowed(MotionEvent ev) { int x = (int) (ev.getX() + mScrollX); if (isMenuOpen()) { return mViewBehind.menuOpenTouchAllowed(mContent, mCurItem, x); } else { switch (mTouchMode) { case SlidingMenu.TOUCHMODE_FULLSCREEN: return !isInIgnoredView(ev); case SlidingMenu.TOUCHMODE_NONE: return false; case SlidingMenu.TOUCHMODE_MARGIN: return mViewBehind.marginTouchAllowed(mContent, x); } } return false; }
居然后有个方法,isInIgnoreView(),如果不在忽略的View中,就会返回true传给CustomViewAbove自己的onTouchEvent()来消费该事件,于是猜想是不是有个方法可以可以把slidingMenu把想忽视侧滑这一触摸事件的View加入判断中,
private boolean isInIgnoredView(MotionEvent ev) { Rect rect = new Rect(); for (View v : mIgnoredViews) { v.getHitRect(rect); if (rect.contains((int) ev.getX(), (int) ev.getY())) return true; } return false; }
原来mIgnoredViews是一个ArrayList<View>,而且还有一个这样的方法。
public void addIgnoredView(View v) { if (!mIgnoredViews.contains(v)) { mIgnoredViews.add(v); } }
SlidingMenu类中又调用了CustomViewAbove的addIgnoreView()
/** * Add a View ignored by the Touch Down event when mode is Fullscreen * * @param v * a view to be ignored */ public void addIgnoredView(View v) { mViewAbove.addIgnoredView(v); }
于是找到解决办法了,如果是MainActivity继承SlidingFragmentActivity的这种情况,可以做如下处理:
public static SlidingMenu mSlidingMenu = getSlidingMenu();
在自己定义的Fragment中:
ActMain.mSlidingMenu.addIgnoredView(viewPager);
大功告成!
相关文章推荐
- 解决SlidingMenu 侧滑与ViewPager冲突问题
- 解决SlidingMenu 侧滑与ViewPager冲突问题
- 解决SlidingMenu 侧滑与ViewPager冲突问题
- android 解决SlidingMenu 侧滑与ViewPager冲突问题
- 解决侧滑中ViewPager和SlidingMenu的滑动冲突
- 解决android-Ultra-Pull-To-Refresh 和ViewPager冲突的问题
- Android中SlidingMenu(侧滑框)的使用、ViewPager冲突处理
- Android中Scrollview与ViewPager冲突问题解决方案
- 自定义 viewpager 解决viewpager 嵌套到其他滚动父控件时候冲突的问题
- 完美解决DrawerLayout全屏滑动及嵌套viewpager滑动冲突问题
- 自定义viewpager实现滑动拦截与分发解决嵌套listview等滑动冲突问题
- 完美解决ScrollView嵌套ViewPager滑动失效和无法正常滑动冲突问题
- android scrollView 内嵌ViewPager或Gallery等水平滑动控件冲突问题解决实现同时滑动
- android listview嵌套viewpager,viewpager嵌套gridview,解决内嵌无法显示以及时间冲突的问题
- React Native通过修改ScrollableTabView和ViewPager来解决左右滑动冲突的问题
- 解决viewpager嵌套viewpager和其他view 冲突问题
- 解决ScrollView嵌套ViewPager出现的滑动冲突问题
- SlidingMenu(侧滑框)的使用、ViewPager冲突处理
- 解决SlideDetailsLayout与ViewPager垂直滚动事件冲突问题
- 解决ViewPager横向的ViewGroup滑动冲突的问题,例如HorizontalListView,RecyclerView,各种layout等