博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ListView 中使用onItemClick和onItemLongClick的常见问题
阅读量:5173 次
发布时间:2019-06-13

本文共 1449 字,大约阅读时间需要 4 分钟。

用过Listview 的朋友,可能会遇到这样的问题,当Listview的某一行有button存在时,无法弹出contextMenu;或者onItemClick 和onItemLongClick

同时执行的等问题。下面就一些常见问题疏理一下。

  

  1.ListView

本身可不可以调用setOnClickListner()代码上可以,但是运行马上会丢出异常,所以是不可以拦截Listview本身的click事件。

  2.ListView.setOnItemClickListener

设置的listener什么时候会被调用?

  

当点击某行内容是会被调用,但是如果这行内容中包含Button,ImgButton等控件时就不会被调用,为什么以及怎么解决见后面。

  

3.ListView.setOnItemLongClickListener设置的listener什么时候被调用?

  当长按某一行时会被调用,而且在抬起之前就已经调用了。

  

4.onItemLongClick的调用后还会调用onItemClick吗?

  

这个要根据onItemLongClick的返回值来决定。

 

lv.setOnItemClickListener(new OnItemLongClickListener() {    

           public boolean onItemClick(AdapterView<?> parent, View view, int position, long id) {    

               System.out.println("Item LONG clicked. Position:" + position);    

               return false;    

           }    

       });   

lv.setOnItemLongClickListener(new OnItemLongClickListener() { 

  public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) { 

           System.out.println("Item LONG clicked. Position:" + position); 

           return false/true; 

  } 

 }); 

如果返回false那么onItemClick仍然会被调用。而且是先调用onItemLongClick,然后调用onItemClick。  

如果返回true那么click就会被吃掉,onItemClick就不会再被调用了。 

5.监听onItemClick以及onItemLongClick影响弹出菜单吗?  nItemClick不影响;onItemLongClick如果返回true那么就会吃掉click事件,导致菜单不能弹。

 

6.如何让包含button的item也能弹出菜单,回调onItemClick以及onItemLongClick的监听器呢?  

需要设置Button属性: 

android:focusable="false"   

android:focusable="false" 

android:longClickable="true"   

android:longClickable="true" 

否则无法收到onItemLongClick 以上基本上就是Listview使用时常见问题了,欢迎各位补充说明!

 

转载于:https://www.cnblogs.com/zhanganju/p/3965846.html

你可能感兴趣的文章
2016腾讯全球合作伙伴大会马化腾《给合作伙伴的一封信》
查看>>
Javascript学习笔记-基本概念-数据类型
查看>>
ES6总结
查看>>
c#隐藏tabcontrol选项卡
查看>>
LeetCode "Combinations"
查看>>
LeetCode "Integer to English Words"
查看>>
palm qq
查看>>
ADO.NET 学习笔记
查看>>
php设计模式之原型模式
查看>>
关于圆角border-radius
查看>>
站在K2角度审视流程--任务的独占与释放
查看>>
表格布局TableLayout
查看>>
jQuery实现的简单文字提示效果模拟title(转)
查看>>
设计模式:单例
查看>>
单机/伪分布式Hadoop2.4.1安装文档
查看>>
十进制 转换成 二进制
查看>>
钻石操作符
查看>>
[LeetCode 题解]: Minimum Depth of Binary Tree
查看>>
LoadRunner脚本增强
查看>>
python集成安装环境——Anaconda 3.5的安装
查看>>