今天在作项目的时候用了自定义listview以及自定义的item、adapter。如今把其中须要注意的地方记录下来:android
一、item内若是有button等控件时,在监听listview的onitemclick事件时,焦点会被item内的button、imagebutton等控件抢走,从而致使在listview设置了onitemclick事件后不会被触发。解决方法是在初始化item的时候屏蔽掉其内部button等控件的焦点获取,具体方法能够在自定义item的根控件中调用:
ide
setDescendantFocusability(ViewGroup.FOCUS_BLOCK_DESCENDANTS);
spa
这样就能阻塞字控件抢夺焦点,listview的onitemclick就能被正确触发,同时对item内部的button等控件也没有影响,他们在被点击时照样能够触发自身的点击事件。事件
二、当listview须要添加headerview时,能够经过调用listview的addHeaderView(headView, null, false) 方法,该方法还有一个重载方法 addHeaderView(headView);这两个方法的区别是前一个方法能够控制header是否能够被selected,若是不想被selected则将第三个参数设置成false;get
三、接着上面说的添加header,添加header时调用的addHeaderView方法必须放在listview.setadapter前面,意思很明确就是若是想给listview添加头部则必须在给其绑定adapter前添加,不然会报错。缘由是当咱们在调用setAdapter方法时会android会判断当前listview是否已经添加header,若是已经添加则会生成一个新的HeaderViewListAdapter,这个新的HeaderViewListAdapter包含咱们设置的adapter全部内容以及listview的header和footer。因此当咱们在给listview添加了header后在程序中调用listview.getadapter时返回的是tempadapter而不是咱们经过setadapter传进去的adapter。若是没有设置adapter则HeaderViewListAdapter与咱们本身的adapter是同样的。listview.getadapter().getcount()方法返回值会比咱们预期的要大,缘由是添加了header。it
四、接着上面的HeaderViewListAdapter说,咱们自定义adapter里面的getitem方法里面返回的position是不包括header的,是咱们自定义adapter中数据position编号从0开始,也就是说与咱们传进去的list的位置是同样的。
io
@Override
cli
public View getView(int position, View convertView, ViewGroup parent) {
List
// TODO Auto-generated method stub
select
Log.i("adapter", "position:"+position); //这个position就是咱们数据的真实位置
}
而listview的onitemclick方法中:
public void onItemSelected(AdapterView<?> parent, View view, int position, long id)
position是当前click的位置,这个位置是指在HeaderViewListAdapter中的位置,从0开始若是listview中添加了header则0表明header。