码迷,mamicode.com
首页 > 其他好文 > 详细

自定义控件(视图)2期笔记11:View的滑动冲突之 概述

时间:2016-07-24 13:35:36      阅读:150      评论:0      收藏:0      [点我收藏+]

标签:

1. 引入:

 滑动冲突可以说是日常开发中比较常见的一类问题,也是比较让人头疼的一类问题,尤其是在使用第三方框架的时候,两个原本完美的控件,组合在一起之后,忽然发现整个世界都不好了。

那到底是为什么会产生滑动冲突呢 ?

答:其实在界面中只要存在内外两层同时可以滑动,这个时候就会产生滑动冲突。

 

2. 常见的滑动冲突的场景:

  • 场景1:外部滑动方向和内部滑动方向不一致
  • 场景2:外部滑动方法和内部滑动方向一致
  • 场景3:上面两种的嵌套

技术分享

 

场景1:主要是将ViewPager 和Fragment配合使用所组成的页面滑动效果,这种效果之中,可以通过左右滑动来切换页面,而每个页面内部往往又是一个ListView 。这种情况本来是有滑动冲突的,但是ViewPager内部处理了这种滑动冲突,因此我们采用ViewPager时候无须关注这个问题。但是如果我们使用的不是Viewpager,而是ScrollView,那么就需要手动处理滑动冲突

场景2:系统无法知道用户希望让哪一层滑动,所以当手指滑动的时候会出现问题,要么只有一层能滑动,要么就是内外两层同时滑动得很卡顿。实际开发中主要是内外两层同时能上下滑动 或者 内外两层同时能左右滑动

场景3:本质是上面两个场景的叠加。

 

3. 滑动冲突的解决方式:

场景1:外部拦截法 或者 内部拦截法

外部拦截法:点击事件通过父容器拦截处理,如果父容器需要就拦截,不需要就不拦截。

内部拦截法:点击事件父容器不拦截处理,所有的事件都传递给子元素,如果资源需要就直接消耗掉,否则就交给父容器进行处理。

 

场景2 和 场景 3:根据用户需求的逻辑进行解决

 

技术分享

自定义控件(视图)2期笔记11:View的滑动冲突之 概述

标签:

原文地址:http://www.cnblogs.com/hebao0514/p/5700558.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!