Android Windowmanager addView OnClick事件不触发

简单记录一个BUG。

问题

android,使用windowmanager,addView来添加一个Layout漂浮显示一个View.
并且给这个Layout,设置onTouchListener,又给它的子控件Button添加点击事件onClickListener。
问题是:
父布局(即整个Layout的)onTouchListener能够触发,而子控件的OnClick不触发。
(补充:先看分析过程再看补充这里:即使父布局没有onTouchListener,仍然不触发,android4.2才有这个bug!)

几个思路与分析过程:

  1. 立刻怀疑父布局的onTouch,return true/false是否消费点击和拦截, 对子控件onClick事件的影响,进行了尝试未果;而且在尝试中,将父布局的onTouch事件去掉仍然有问题,显然就不是onTouch和Onclick分发的问题了;
  2. 又有人提到dispatchTouchEvent()的方法重写, 于是又折腾重写布局,使用java重写后的布局放入xml,仍然不行;
  3. 回退上述2次修改;开始从不同版本入手。发现,android4.2的机器有问题!其他版本没有问题。

于是,反复查看自己写的代码发现一个问题:

在View的创建,肯定是优先于addView的。设置各种监听也在这个时候;

在某种情况下,addView之后,会将他的位置进行变位置(update)。但是代码写成了removeView,然后重新addView。在新的android版本没有问题,android4.2就会产生设置后的事件,在removeView的时候丢失了!再重新addView以后,就没有点击事情了。

在此进行记录,android framework的代码就不做分析了。最近太忙。

猜你喜欢

转载自blog.csdn.net/jzlhll123/article/details/84400241