简单记录一个BUG。
问题
android,使用windowmanager,addView来添加一个Layout漂浮显示一个View.
并且给这个Layout,设置onTouchListener,又给它的子控件Button添加点击事件onClickListener。
问题是:
父布局(即整个Layout的)onTouchListener能够触发,而子控件的OnClick不触发。
(补充:先看分析过程再看补充这里:即使父布局没有onTouchListener,仍然不触发,android4.2才有这个bug!)
几个思路与分析过程:
- 立刻怀疑父布局的onTouch,return true/false是否消费点击和拦截, 对子控件onClick事件的影响,进行了尝试未果;而且在尝试中,将父布局的onTouch事件去掉仍然有问题,显然就不是
onTouch和Onclick分发
的问题了; - 又有人提到dispatchTouchEvent()的方法重写, 于是又折腾重写布局,使用java重写后的布局放入xml,仍然不行;
- 回退上述2次修改;开始从不同版本入手。发现,
android4.2的机器有问题
!其他版本没有问题。
于是,反复查看自己写的代码发现一个问题:
在View的创建,肯定是优先于addView的。设置各种监听也在这个时候;
在某种情况下,addView之后,会将他的位置进行变位置(update)。但是代码写成了removeView,然后重新addView。在新的android版本没有问题,android4.2就会产生设置后的事件,在removeView的时候丢失了!再重新addView以后,就没有点击事情了。
在此进行记录,android framework的代码就不做分析了。最近太忙。