OCNYang の 博客

Android 开发者,亦涉猎 Flutter

0%

ListView 特殊属性 & 常见问题

这里向大家介绍一些我个人认为比较特别的属性,通过设置这样的属性可以做出更加美观的列表

一. ListView的一些特殊属性

1. stackFromBottom属性

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

2. transciptMode属性

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

3. cacheColorHint属性

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

4. divider属性

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

5. headerDividersEnabled属性

__android:headerDividersEnabled=”false”__设成flase时,此ListView将不会在页眉视图前画分隔符。缺省值为true
android:footerDividersEnabled 设成flase时,此ListView将不会在页脚视图前画分隔符。此属性缺省值为true

6. fadingEdge属性

上边和下边有黑色的阴影(类似边框的东西)
android:fadingEdge=”none” 设置后没有阴影了~

7. scrollbars属性

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

8. fadeScrollbars属性

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

9. fastScrollEnabled属性

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

10. drawSelectorOnTop属性

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

11. listSelector属性

android:listSelector=”#00000000 “ 改变选中item时的颜色。默认为橙黄底色(依手机系统而定)

12. scrollingCache属性

__android:scrollingCache=”false”__去除拖动时ListView背景为黑色

13. soundEffectsEnabled属性

android:soundEffectsEnabled=”false” 点击和触摸时是否有声音效果,缺省值为true(只有系统设置中开启了触摸提示音才有效)

二. 解决ListView item中含有Button或者Checkable的子类控件点击时冲突

由于在你自己定义的Item中存在诸如Button或者Checkable的子类控件,此时这些子控件会将焦点获取到,所以常常当点击item时变化的是子控件,item本身的点击没有响应。这时候就可以使用descendantFocusability来解决啦,API描述如下:

android:descendantFocusability
Defines the relationship between the ViewGroup and its descendants when looking for a View to take focus.
Must be one of the following constant values.

该属性是当一个为view获取焦点时,定义viewGroup和其子控件两者之间的关系。
属性的值有三种:

  • __beforeDescendants__:viewgroup会优先其子类控件而获取到焦点
  • __afterDescendants__:viewgroup只有当其子类控件不需要获取焦点时才获取焦点
  • __blocksDescendants__:viewgroup会覆盖子类控件而直接获得焦点

所以解决办法:

  1. 在Item布局的根布局加上__android:descendantFocusability=”blocksDescendants”__的属性。
  2. 在当前ListView的xml里添加__android:descendantFocusability=”blocksDescendants”__ 在item的xml里的Button添加__android:focusable=”false”__的属性。

三. listview的item点击事件会使里面的Button也出现按压的效果

两个方案:

  1. 放弃listview的onItemClickedListener()。listview.setOnItemClickedListener(null);
  2. 使用自定义的Button,判断他的父控件是否press,如果是就把这个事件消耗掉,不向下传递即可;
import android.content.Context;  
import android.util.AttributeSet;  
import android.view.View;  
import android.widget.Button;  

public class CustomButton extends Button {  
    public CustomButton(Context context) {  
        super(context);  
    }  

    public CustomButton(Context context, AttributeSet attrs) {  
        super(context, attrs);  
    }  

    public CustomButton(Context context, AttributeSet attrs, int defStyle) {  
        super(context, attrs, defStyle);  
    }  

    @Override  
    public void setPressed(boolean pressed) {  
        if (pressed && getParent() instanceof View && ((View) getParent()).isPressed()) {  
            return;  
        }  
        super.setPressed(pressed);  
    }  

}  

参考来源:
“一勤天下无难事” 博客
CSDN博客