前三天收到位网友的私信求助,问题大概如标题所示。具体是下面的情况,个人感觉,这个问题挺有趣,也会在实际项目开发中很常见。不想看前奏的请直接跳至解决方法。
问题原型:
父控件是自定义的 LinearLayout,目的是实现下拉刷新,这个自定义View的实现下拉操作思想是通过检测 onTouch 事件,然后,子控件有一个 scrollView,它是完全为了实现下滚和滚到底部实现加载更多的监听。看到这,我相信任何一个有类似项目开发经验的人,都会感到很熟悉的。下拉刷新+下滑加载更多。
在 scrollView 里面的第一层View里面有很多一样的自定义的 View,每个有具备自身的 onClick 和 onTouch 事件,目的是为了在用户点击的时候实现变色和相应。
问题来了,根据他说的,每次点击,总是先实现 自定义View的 onTouch 的down,然后是 onClick,而 父 Linearlayout的 onTouch是最后实现,而且,父的 action_down 没有执行,这样就直接导致了父View 拿不到用户的 点击坐标,下拉刷新出问题!就是说,各种冲突。
我们知道,在同一个 View中,注意,是同一个 View,没嵌套的情况下,用户手势事件执行顺序是:
onTouch->onLongClick->onClick。
交谈细节:
我问:你自己百度过了吗?
他答:嗯,百度上有onClick和onTouch的冲突例子,但是全都是针对同一个 View的情况下,而且 无论onTouch返回false不阻断还是true阻断继续传送下去,都是无作用。
他的回答很清晰,他的这个状况的冲突是 嵌套的,大家大可百度下,因为我在帮他的时间里,也百度过,基本无答案。最能接近的是父View的onTouch里面使用 requestDisallowInterceptTouchEvent 来允许这个手势事件能传给 子View,但是,他的这个问题是,儿子不爽父亲先的。确实蛋碎。
我再问:是不是你的布局有问题,怎么会是子 View 阻断 父 View?
他再答:他的布局就是正常的嵌套。
在无语了一会之后,想了下,觉得这样应该可以搞定。
解决方法:
既然传统的解决方法解决不了,我当时想到的是:
1:子View 使用父类的 onTouch 接口来实现点击和改变颜色,总之就是子View不要自己再实现 onClick和onTouch;
2:父View 实现个接口,供子View实现自己的onTouch内容;
3:当用户onTouch的时候,父View 在恰当的时候调用该接口,实现子View的请求的功能。
这样所会产生的问题:
因为它的这个父View是整个使用onTouch来实现下拉的,所以:
1:用户点击后会产生两次的 onTouch执行,一次是子 View,第二次是 父View。
这样就需要他来使用逻辑区分了,逻辑区分不难,几个 boolean 即可,所用内存几个 bit。
最后问他,这样能否接受,他说试试先,刚刚发信息来,完美解决。逐有感而发此文。
在我们百度或请教人都解决不了的问题的情况下,应该自己思考下动手解决!
|