为什么ListView.setOnItemClickListener、setOnCreateContextMenuListener会无效为什么ListView.setOnItemClickListen

如果ListView中的单个Item的view中存在checkbox,button等view,会导致ListView.setOnItemClickListener无效,

事件会被子View捕获到,ListView无法捕获处理该事件.

解决方法:

在checkbox、button对应的view处加

 

android:focusable="false"

android:clickable="false"

android:focusableInTouchMode="false"

 

 

其中focusable是关键

从OnClickListener调用getSelectedItemPosition(),Click 和selection是不相关的,Selection是通过D-pad or trackball 来操作的,Click通常是点击操作的。

arg2参数才是点击事件位置的参数

第二种方法 就是在自己的getView中

 

convertView = mInflater . inflate ( R . layout . list_item_text , null ); 

convertView . setClickable ( true ); 

convertView . setOnClickListener ( clickListener ); 

public OnClickListener myClickListener = new OnClickListener () { 

public void onClick ( View v ) { 

                  //code to be written to handle the click event 

    } 

}; 

 

 

刚刚在网上找到问题的关键,终于解决了:

 如果你的自定义ListViewItem中有Button或者Checkable的子类控件的话,那么默认focus是交给了子控件,而ListView的Item能被选中的基础是它能获取Focus,也就是说我们可以通过将ListView中Item中包含的所有控件的focusable属性设置为false,这样的话ListView的Item自动获得了Focus的权限,也就可以被选中了,也就会响应onItemClickListener中的onItemClick()方法,然而将ListView的ItemLayout的子控件focusable属性设置为false有点繁琐,我们可以通过对ItemLayout的根控件设置其android:descendantFocusability=”blocksDescendants”即可,这样ItemLayout就屏蔽了所有子控件获取Focus的权限,不需要针对ItemLayout中的每一个控件重新设置focusable属性了,如此就可以顺利的响应onItemClickListener中的onItenClick()方法了。



你可能感兴趣的:(contextMenu)