ListView的属性和注意事项

本文详细介绍了ListView的各种属性,包括stackFromBottom、transcriptMode、cacheColorHint、divider、fadingEdge、scrollbars、fadeScrollbars、fastScrollEnabled、drawSelectorOnTop和descendantFocusability。还提到了在使用ListView时的注意事项,如item内控件焦点问题、添加HeaderView的正确时机以及getitem方法中的position解析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ListView的使用及注意事项

一:ListView的几种使用方式
ListView分页加载

1.手动加载

        ① View view=LayoutInflater.from(this).inflate(R.layout.foot,null); 
        加载更多控件
        ② addHeaderView();  加到ListView的头,底部
        ③ addFooterView() 点击按钮加载数据,适配器刷新

2.自动加载

        ① OnScrollListener()  设置滑动监听事假
        ② 重写onScroll(),onScrollStateChanged()
        ③ 在onScroll()中判断firstVisibleItem+visibleItemCount==totalItemCount&&totalItemCount&&total>0,就是最后一个item
        ④ 在OnScrollStateChanged()中判断是否是最后一条并且屏幕是静止状态
            scrollState==SCROLL_STATE_IDLE  手指未接触屏幕,且屏幕页面保持静止
            scrollState==SCROLL_STATE_TOUCH_SCROLL  手指按住屏幕滚动(未脱离屏幕)
            scrollState==SCROLL_STATE_FLING  手指离开屏幕,页面依然保持滚动

3.放图片错乱

        原因:在于convertView的重用
        解决:viewHolder.img.setTag(student.getImg());  给img设置Tag(路径)
        if(img.getTag()!=null&&img.getTag().equals(str)){img.setImageBitmap(bitmap);} 
         当img.setImageBitmap之前判断设置的路径和Tag的路径是否一致

二:ListView的一些常用属性

1、stackFromBottom属性

设置该属性之后你做好的列表就会显示在你列表的最下面,值为true和false
android:stackFromBottom=”true”

2、transciptMode属性

需要用ListView或者其它显示大量Items的控件实时跟踪或者查看信息,并且希望最新的条目可以自动滚动到可视范围内。通过设置控件的transcriptMode属性就可以将Android平台的控件(支持ScrollBar)自动滑动到最底部。
android:transcriptMode=”alwaysScroll”

3、cacheColorHint属性

很多人希望能够改变一下ListView的背景,使他能够符合整体的UI设计,改变背景背很简单只需要准备一张图片然后指定属性android:background=”@drawable/bg”,不过不要高兴地太早,当你这么做以后,发现背景是变了,但是当你拖动,或者点击list空白位置的时候发现ListItem都变成黑色的了,破坏了整体效果。
如果你只是换背景的颜色的话,可以直接指定android:cacheColorHint为你所要的颜色,如果你是用图片做背景的话,那也只要将android:cacheColorHint指定为透明(#00000000)就可以了

4、divider属性

该属性作用是每一条item之间需要设置一个图片做为间隔,或是去掉item之间的分割线
android:divider=”@drawable/list_driver” 其中 @drawable/list_driver 是一个图片资源,
如果不想显示分割线则只要设置为android:divider=”@drawable/@null” 就可以了

5、fadingEdge属性

上边和下边有黑色的阴影android:fadingEdge=”none”设置后就没有阴影了

6、scrollbars属性

该属性的作用是隐藏listView的滚动条,
android:scrollbars=”none”与setVerticalScrollBarEnabled(true);的效果是一样的,不活动的时候隐藏,活动的时候也隐藏

7、fadeScrollbars属性

android:fadeScrollbars=”true” 配置ListView布局的时候,设置这个属性为true就可以实现滚动条的自动隐藏和显示。

8、fastScrollEnabled属性

很多开发者不知道ListView列表控件的快速滚动滑块是如何启用的,辅助滚动滑块只需要一行代码就可以搞定,如果你使用XML布局只需要在ListView节点中加入 android:fastScrollEnabled=”true” 这个属性即可,而对于Java代码可以通过myListView.setFastScrollEnabled(true); 来控制启用,参数false为隐藏。 还有一点就是当你的滚动内容较小,不到当前ListView的3个屏幕高度时则不会出现这个快速滚动滑块,同时该方法仍然是AbsListView的基础方法,可以在ListView或GridView等子类中使用快速滚动辅助。

9、drawSelectorOnTop属性

android:drawSelectorOnTop=”true” 点击某一条记录,颜色会显示在最上面,记录上的文字被遮住,所以点击文字不放,文字就看不到
android:drawSelectorOnTop=”false”点击某条记录不放,颜色会在记录的后面,成为背景色,但是记录内容的文字是可见的

10、descendantFocusability属性

该属性是当一个为view获取焦点时,定义viewGroup和其子控件两者之间的关系。
属性的值有三种:
beforeDescendants:viewgroup会优先其子类控件而获取到焦点
afterDescendants:viewgroup只有当其子类控件不需要获取焦点时才获取焦点
blocksDescendants:viewgroup会覆盖子类控件而直接获得焦点

ListView的一些注意事项

1、
item内如果有button等控件时,在监听listview的onitemclick事件时,焦点会被item内的button、imagebutton等控件抢走,从而导致在listview设置了onitemclick事件后不会被触发。解决方法是在初始化item的时候屏蔽掉其内部button等控件的焦点获取,具体方法可以在自定义item的根控件中调用:
[java] view plaincopy
setDescendantFocusability(ViewGroup.FOCUS_BLOCK_DESCENDANTS);

这样就能阻塞字控件抢夺焦点,listview的onitemclick就能被正确触发,同时对item内部的button等控件也没有影响,他们在被点击时照样可以触发自身的点击事件。

2、
当listview需要添加headerview时,可以通过调用listview的addHeaderView(headView, null, false) 方法,该方法还有一个重载方法 addHeaderView(headView);这两个方法的区别是前一个方法可以控制header是否可以被selected,如果不想被selected则将第三个参数设置成false;

3、
接着上面说的添加header,添加header时调用的addHeaderView方法必须放在listview.setadapter前面,意思很明确就是如果想给listview添加头部则必须在给其绑定adapter前添加,否则会报错。原因是当我们在调用setAdapter方法时会android会判断当前listview是否已经添加header,如果已经添加则会生成一个新的tempadapter,这个新的tempadapter包含我们设置的adapter所有内容以及listview的header和footer。所以当我们在给listview添加了header后在程序中调用listview.getadapter时返回的是tempadapter而不是我们通过setadapter传进去的adapter。如果没有设置adapter则tempadapter与我们自己的adapter是一样的。listview.getadapter().getcount()方法返回值会比我们预期的要大,原因是添加了header。
4、
接着上面的tempadapter说,我们自定义adapter里面的getitem方法里面返回的position是不包括header的,是我们自定义adapter中数据position编号从0开始,也就是说与我们传进去的list的位置是一样的。

[java] view plaincopy

@Override
public View getView(int position, View convertView, ViewGroup parent) {
// TODO Auto-generated method stub
Log.i(“adapter”, “position:”+position); //这个position就是我们数据的真实位置
}

而listview的onitemclick方法中:

[java] view plaincopy

public void onItemClick(AdapterView

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值