码迷,mamicode.com
首页 > 移动开发 > 详细

Android ListView多选模式

时间:2018-04-09 17:17:18      阅读:301      评论:0      收藏:0      [点我收藏+]

标签:ListView

ListView使用多选模式好处

交互与数据分离,在多选状态下不需要修改数据源,在最后确定的时候获取选择索引来确定选择的数据。

ListView模式

  • CHOICE_MODE_NONE:普通模式;
  • CHOICE_MODE_SINGLE:单选模式;
  • CHOICE_MODE_MULTIPLE:多选模式;
  • CHOICE_MODE_MULTIPLE_MODAL:多选模式(与ActionMode配合使用)。

设置方式

  1. XML布局文件设置(多选模式设置):
    <ListView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:choiceMode="multipleChoice"/>
  2. 代码设置:
    listView.setChoiceMode(ListView.CHOICE_MODE_MULTIPLE);

选择

ListView多选状态是记录到ListView控件中,由其父类AbsListView实现。
列表Item最外层需要实现Checkable接口,比如CheckBox、CheckedTextView等控件。
如果需要使用容器类控件比如LinearLayout,可以重写控件,实现Checkable接口。
比如:

public class CheckableLinearLayout extends LinearLayout implements Checkable {

    private boolean mChecked = false;

    public CheckableLinearLayout(Context context) {
        super(context);
    }

    public CheckableLinearLayout(Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);
    }

    public CheckableLinearLayout(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    @Override
    public void toggle() {
        setChecked(!mChecked);
    }

    @Override
    public boolean isChecked() {
        return mChecked;
    }

    @Override
    public void setChecked(boolean checked) {
        if (mChecked != checked) {
            mChecked = checked;
            refreshDrawableState();
            for (int i = 0, len = getChildCount(); i < len; i++) {
                View child = getChildAt(i);
                if(child instanceof Checkable){
                    ((Checkable) child).setChecked(checked);
                }
            }
        }
    }

}

获取选择数据

获取到最终选择结果为选中项索引集合,是一个SparseBooleanArray,记录了操作过的item选择状态(如果选中item再取消同样会记录,状态为false)。
SparseBooleanArray checkedItemPositions = listView.getCheckedItemPositions();

Android ListView多选模式

标签:ListView

原文地址:http://blog.51cto.com/9098858/2096094

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!