开源项目MultiChoiceAdapter详解(三)——MulitChoiceNormalArrayAdapter的使用

  MulitChoiceNormalArrayAdapter是我自己定义的一个类,其实就是实现了MulitChoiceArrayAdapter,为什么做这个简单的实现类呢,因为这样我们在不用ActionMode的时候就不用每次要写一个类来继承MulitChoiceArrayAdapter了,直接实例化MulitChoiceNormalArrayAdapter即可。下面贴一个compat包下的MulitChoiceNormalArrayAdapter的源码。

MulitChoiceNormalArrayAdapter.java

package com.manuelpeinado.multichoiceadapter.compat;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

import android.content.Context;
import android.os.Bundle;
import android.support.v7.view.ActionMode;
import android.view.Menu;
import android.view.MenuItem;

public class MulitChoiceNormalArrayAdapter<T> extends MultiChoiceArrayAdapter<T> {

    public MulitChoiceNormalArrayAdapter(Bundle savedInstanceState,
            Context context, int resource, int textViewResourceId) {
        super(savedInstanceState, context, resource, textViewResourceId);
        // TODO 自动生成的构造函数存根
    }

    public MulitChoiceNormalArrayAdapter(Bundle savedInstanceState,
            Context context, int resource, int textViewResourceId,
            List<T> objects) {
        super(savedInstanceState, context, resource, textViewResourceId, objects);
        // TODO 自动生成的构造函数存根
    }

    public MulitChoiceNormalArrayAdapter(Bundle savedInstanceState,
            Context context, int resource, int textViewResourceId, T[] objects) {
        this(savedInstanceState,context,resource,textViewResourceId,new ArrayList<T>(Arrays.asList(objects)));
        // TODO 自动生成的构造函数存根
    }

    @Override
    public boolean onActionItemClicked(ActionMode arg0, MenuItem arg1) {
        // TODO 自动生成的方法存根
        return false;
    }

    @Override
    public boolean onCreateActionMode(ActionMode arg0, Menu arg1) {
        // TODO 自动生成的方法存根
        return false;
    }

    @Override
    public boolean onPrepareActionMode(ActionMode arg0, Menu arg1) {
        // TODO 自动生成的方法存根
        return false;
    }

}

好了,知道了这个后我们来看怎么简单的来使用这个适配器进行多选。

1.写布局文件

2.实例化MultiChoiceAdapter

3.设置showActionMode(false)来表示不使用ActionMode

4.setAdapterView();来设置要用适配器的view对象

5.设置下监听器来进行各种扩展的操作

一、布局文件

listview_normal_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <ListView
         android:id="@+id/normal_listView"
         android:layout_width="match_parent"
         android:layout_height="wrap_content"
         android:layout_weight="1" >
    </ListView>

    <LinearLayout
        android:id="@+id/setting_linearLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom">

        <Button
            android:id="@+id/selectAll_button"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="全选"
            android:layout_weight="1"
            android:onClick="buttonListener"/>

        <Button
            android:id="@+id/cancle_button"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="取消"
            android:layout_weight="1"
            android:onClick="buttonListener"/>

        <Button
            android:id="@+id/delete_button"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="删除"
            android:onClick="buttonListener"/>

        <Button
            android:id="@+id/share_button"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="分享"
            android:layout_weight="1"
            android:onClick="buttonListener"/>

    </LinearLayout>

</LinearLayout>

item.xml

<?xml version="1.0" encoding="utf-8"?>
<com.manuelpeinado.multichoiceadapter.view.CheckableLinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"

    android:background="@drawable/custom_list_item_background"

    android:orientation="horizontal">
    <!-- 上面必须要用自定义的layout,否则不会有选中的效果!!! -->

    <LinearLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:padding="16dp"
        android:orientation="horizontal" >

        <TextView
            android:id="@+id/item_textView"
            android:layout_width="200dp"
            android:layout_height="wrap_content"
            android:layout_marginLeft="30dp"
            android:layout_gravity="center_vertical"
            android:textColor="#000000"
            android:layout_weight="1"
            android:textAppearance="?android:attr/textAppearanceLarge" />

    </LinearLayout>
</com.manuelpeinado.multichoiceadapter.view.CheckableLinearLayout> 

二、实现适配器和绑定适配器

        final LinearLayout settingLL = (LinearLayout)findViewById(R.id.setting_linearLayout);
        settingLL.setVisibility(View.GONE);

        ListView normalListView = (ListView)findViewById(R.id.normal_listView);

        String[] data = {"android","ios","wp","c++",
                 "java","c#","javascript","vb",
                 "delphi","PB","ASP","SQL"};

        //ArrayList<String> items = new ArrayList<>(Arrays.asList(data));

        normalAdapter = new MulitChoiceNormalArrayAdapter<String>(savedInstanceState,
                getApplicationContext(), R.layout.item, R.id.item_textView, data);

        normalAdapter.showActionMode(false);//设置为显示actionmode的普通模式
        normalAdapter.setAdapterView(normalListView);
        normalAdapter.setOnItemClickListener(new MyItemClick(normalAdapter));

三、写一些回调方法来优化,比如选中时点击返回后取消选中

    @Override
    protected void onSaveInstanceState(Bundle outState) {
        normalAdapter.save(outState);
    }

    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event) {
        if (keyCode == KeyEvent.KEYCODE_BACK ) {
            if (normalAdapter.getCheckedItemCount() > 0) {
                cancleAll(normalAdapter);
                return true;
            }
        }
        return super.onKeyDown(keyCode, event);
    }

四、绑定监听器

setOnItemClickListener是在item被点击时触发的

setOnSelectedStateChangeListener是item被选中或者取消选中时触发的

        normalAdapter.setOnItemClickListener(new MyItemClick(normalAdapter));
        normalAdapter.setOnSelectedStateChangeListener(new OnSelectedStateChangeListener() {

            /**
             * checkedItemCount = 已经选中的item数目
             */
            @Override
            public void onSelectedStateChanged(int checkedItemCount) {
                if (checkedItemCount != 0) {
                    settingLL.setVisibility(View.VISIBLE);
                }
                else {
                    settingLL.setVisibility(View.GONE);
                }
            }
        });

    /**
     * @author:Jack Tony
     * @tips  :点击事件的监听器
     * @date  :2014-10-20
     */
    private class MyItemClick implements OnItemClickListener{

        private MultiChoiceArrayAdapter<String> mAdapter;

        public MyItemClick(MultiChoiceArrayAdapter<String> adapter) {
            mAdapter = adapter;
        }

        @Override
        public void onItemClick(AdapterView<?> arg0, View arg1, int position, long arg3) {
            Toast.makeText(getApplicationContext(), "点击了: " + mAdapter.getItem(position), Toast.LENGTH_SHORT).show();
        }

    }

五、通过按钮进行操作(这是扩展性的重要体现)

    public void buttonListener(View v) {
        switch (v.getId()) {
        case R.id.selectAll_button:
            selectAll(normalAdapter);
            break;
        case R.id.cancle_button:
            cancleAll(normalAdapter);
            break;
        case R.id.delete_button:
            delectItems(normalAdapter);
            break;
        case R.id.share_button:
            Toast.makeText(getApplicationContext(), "分享"+Arrays.toString(getSelectedItems(normalAdapter)), 1).show();
            cancleAll(normalAdapter);
            break;
        default:
            break;
        }
    }

    /**
     * 全选
     * @param adapter
     */
    private void selectAll(MultiChoiceArrayAdapter<String>  adapter) {
        for (int i = 0; i < adapter.getCount(); ++i) {
            adapter.setItemChecked(i, true);
        }
    }

    /**
     * 取消所有选择效果
     * @param adapter
     */
    private void cancleAll(MultiChoiceArrayAdapter<String>  adapter) {
        for (int i = 0; i < adapter.getCount(); ++i) {
            adapter.setItemChecked(i, false);
        }
    }

    /**
     * 得到已经选中的items
     * @param adapter
     * @return
     */
    private String[] getSelectedItems(MultiChoiceArrayAdapter<String> adapter) {
        //得到选中的items
        Set<Long> selection = adapter.getCheckedItems();
        String[] items = new String[selection.size()];
        int i = 0;
        for (long position : selection) {
            items[i++] = adapter.getItem((int)position);
        }
        return items;
    }

    /**
     * 删除已经选中的items
     * @param adapter
     */
    private void delectItems(MultiChoiceArrayAdapter<String>  adapter) {
        //通过判断名字来remove掉这些items
        for (String item : getSelectedItems(adapter)) {
            /**
             * 这里用remove时要注意传入适配器的不能是String[] items对象。否则会报错
             * 这里我已经在构造函数中进行了处理,传入String数组也不会出错了~
             */
            adapter.remove(item);
        }
        cancleAll(adapter);
    }

全部搞定了!!!

下面是全部代码:

package com.kale.multichoiceadaptertest;

import java.util.Arrays;
import java.util.Set;

import android.app.Activity;
import android.os.Bundle;
import android.view.KeyEvent;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.Toast;

import com.manuelpeinado.multichoiceadapter.base.OnSelectedStateChangeListener;
import com.manuelpeinado.multichoiceadapter.compat.MulitChoiceNormalArrayAdapter;
import com.manuelpeinado.multichoiceadapter.compat.MultiChoiceArrayAdapter;

/**
 * 如果不用到ActionMode对象的话可以放心大胆的继承activity,也不用导入ActionMode了。
 *
 * 其实在不用ActionMode时导入
 * import com.manuelpeinado.multichoiceadapter.normal.MulitChoiceNormalArrayAdapter;
 * import com.manuelpeinado.multichoiceadapter.normal.MultiChoiceArrayAdapter;
 * 或者是
 * import com.manuelpeinado.multichoiceadapter.compat.MulitChoiceNormalArrayAdapter;
 * import com.manuelpeinado.multichoiceadapter.compat.MultiChoiceArrayAdapter;
 * 都一样的,只是为了以后的扩展,还是按需导入吧。
 * 4.0以上的导入normal包下面的,兼容2.0的导入compat包下的
 */

public class ArrayAdapterNormalTestActivity extends Activity{

    MulitChoiceNormalArrayAdapter<String> normalAdapter;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.listview_normal_layout);

        final LinearLayout settingLL = (LinearLayout)findViewById(R.id.setting_linearLayout);
        settingLL.setVisibility(View.GONE);

        ListView normalListView = (ListView)findViewById(R.id.normal_listView);

        String[] data = {"android","ios","wp","c++",
                 "java","c#","javascript","vb",
                 "delphi","PB","ASP","SQL"};

        //ArrayList<String> items = new ArrayList<>(Arrays.asList(data));

        normalAdapter = new MulitChoiceNormalArrayAdapter<String>(savedInstanceState,
                getApplicationContext(), R.layout.item, R.id.item_textView, data);

        normalAdapter.showActionMode(false);//设置为显示actionmode的普通模式
        normalAdapter.setAdapterView(normalListView);
        normalAdapter.setOnItemClickListener(new MyItemClick(normalAdapter));
        normalAdapter.setOnSelectedStateChangeListener(new OnSelectedStateChangeListener() {

            /**
             * checkedItemCount = 已经选中的item数目
             */
            @Override
            public void onSelectedStateChanged(int checkedItemCount) {
                if (checkedItemCount != 0) {
                    settingLL.setVisibility(View.VISIBLE);
                }
                else {
                    settingLL.setVisibility(View.GONE);
                }
            }
        });
    }

    @Override
    protected void onSaveInstanceState(Bundle outState) {
        normalAdapter.save(outState);
    }

    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event) {
        if (keyCode == KeyEvent.KEYCODE_BACK ) {
            if (normalAdapter.getCheckedItemCount() > 0) {
                cancleAll(normalAdapter);
                return true;
            }
        }
        return super.onKeyDown(keyCode, event);
    }  

    public void buttonListener(View v) {
        switch (v.getId()) {
        case R.id.selectAll_button:
            selectAll(normalAdapter);
            break;
        case R.id.cancle_button:
            cancleAll(normalAdapter);
            break;
        case R.id.delete_button:
            delectItems(normalAdapter);
            break;
        case R.id.share_button:
            Toast.makeText(getApplicationContext(), "分享"+Arrays.toString(getSelectedItems(normalAdapter)), 1).show();
            cancleAll(normalAdapter);
            break;
        default:
            break;
        }
    }

    /**
     * 全选
     * @param adapter
     */
    private void selectAll(MultiChoiceArrayAdapter<String>  adapter) {
        for (int i = 0; i < adapter.getCount(); ++i) {
            adapter.setItemChecked(i, true);
        }
    }

    /**
     * 取消所有选择效果
     * @param adapter
     */
    private void cancleAll(MultiChoiceArrayAdapter<String>  adapter) {
        for (int i = 0; i < adapter.getCount(); ++i) {
            adapter.setItemChecked(i, false);
        }
    }

    /**
     * 得到已经选中的items
     * @param adapter
     * @return
     */
    private String[] getSelectedItems(MultiChoiceArrayAdapter<String> adapter) {
        //得到选中的items
        Set<Long> selection = adapter.getCheckedItems();
        String[] items = new String[selection.size()];
        int i = 0;
        for (long position : selection) {
            items[i++] = adapter.getItem((int)position);
        }
        return items;
    }

    /**
     * 删除已经选中的items
     * @param adapter
     */
    private void delectItems(MultiChoiceArrayAdapter<String>  adapter) {
        //通过判断名字来remove掉这些items
        for (String item : getSelectedItems(adapter)) {
            /**
             * 这里用remove时要注意传入适配器的不能是String[] items对象。否则会报错
             * 这里我已经在构造函数中进行了处理,传入String数组也不会出错了~
             */
            adapter.remove(item);
        }
        cancleAll(adapter);
    }

    /**
     * @author:Jack Tony
     * @tips  :点击事件的监听器
     * @date  :2014-10-20
     */
    private class MyItemClick implements OnItemClickListener{

        private MultiChoiceArrayAdapter<String> mAdapter;

        public MyItemClick(MultiChoiceArrayAdapter<String> adapter) {
            mAdapter = adapter;
        }

        @Override
        public void onItemClick(AdapterView<?> arg0, View arg1, int position, long arg3) {
            Toast.makeText(getApplicationContext(), "点击了: " + mAdapter.getItem(position), Toast.LENGTH_SHORT).show();
        }

    }
}
时间: 2024-10-19 11:13:46

开源项目MultiChoiceAdapter详解(三)——MulitChoiceNormalArrayAdapter的使用的相关文章

开源项目MultiChoiceAdapter详解(五)——可扩展的MultiChoiceBaseAdapter

上次写到了开源项目MultiChoiceAdapter详解(四)——MultiChoiceBaseAdapter的使用,其实我们仍旧可以不使用ActionMode的,所以这里就写一个自己扩展的方法. 一.布局文件 listview_normal_layout.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.andr

开源项目MultiChoiceAdapter详解(六)——GridView和MultiChoiceBaseAdapter配合使用

这篇其实没啥重要的,主要就算是个总结吧. 一. 这里实现的是类似于上图的多图选择的效果.关键在于item布局文件的写法.这也就是这个框架奇葩的一点,莫名其妙的要在一个自定义控件里面再放一个自定义的控件,如果不这样就出不了选中的效果.分析下原因是这里整个item被图片所覆盖了,仅仅设置一个有选择效果的父控件会被图片所覆盖,所以还得用一个可以选中的iamgeview进行替换imageview. 下面就是这个布局文件 item_gridview.xml <?xml version="1.0&qu

开源项目MultiChoiceAdapter详解(四)——MultiChoiceBaseAdapter的使用

MultiChoiceBaseAdapter是一个可以多选的BaseAdapter,使用的方式相比来说扩展性更强! 使用方式: 1.布局文件 2.写一个类继承MultiChoiceBaseAdapter 3.实现内部的各个方法 4.设置数据源和视图 5.完成保存的回调方法 一.布局文件 listview_actionmode_layout.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayou

开源项目MultiChoiceAdapter详解(二)——MultiChoiceArrayAdapter的使用

MultiChoiceArrayAdapter其实就是可以多选的ArrayAdapter了,ArrayAdpter我们已经很熟悉了.MultiChoiceArrayAdapter这个类是抽象类,所以使用前必须要继承.下面是使用MultiChoiceArrayAdapter的步骤: 0.用自定义的控件来写一个layout 1.写一个类来继承MultiChoiceArrayAdapter 2.实例化这个类 3.用setAdapterView()来设置要加载适配器的控件. 4.写上保存的方法 @Ove

开源项目使用详解过程

开源项目使用详解过程Q-Q:971-041-894定位[手機系列找回刪除等信息]这件事说来也是巧了,也算是他们上级领导的矛盾吧,因为公司与另一个公司之前有一点合同上的纠葛,所以老板在发函以前之前让我跟对方公司现承认一下,看是不是真的要闹到这个地步,因为我是担任这个项目的,相对在状况上回对比的了解,那个时分我刚好在外面,所以只能用自己的手机打以前了,这也没什么,不便是知会一声吗,当然的,两头的利益不是那么快就可以到达的,所以发函这个工作仍是进行了请问我的苹果5s手机被偷关还能机么定位吗.手机没电话

开源项目PullToRefresh详解(二)——PullToRefreshGridView

这里介绍的是PullToRefreshGridView的使用方法,和之前的PullToRefreshListView方法如出一辙,因为这个开源项目模块化很棒,所以很容易实现.等于说我们可以按照之前使用控件的方式来操作,不用考虑其他的问题. 思路: 1.写布局文件,放入可以下拉刷新的控件 2.找到下拉刷新的控件,设置监听器,并且在刷新方法中开启一个异步任务来操作 3.通过这个下拉刷新控件的getRefreshableView()方法来得到GridView对象,按照正常的操作来设置适配器 4.在异步

开源项目PullToRefresh详解(三)——PullToRefreshScrollView

和前几篇文章一样,这里还是先设置布局文件,然后找到这个控件.只不过这里要简单很多. 1.布局文件 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:la

Android 开源项目DiskLruCache 详解

有兴趣的同学可以读完这篇文章以后 可以看看这个硬盘缓存和volley 或者是其他 图片缓存框架中使用的硬盘缓存有什么异同点. 讲道理的话,其实硬盘缓存这个模块并不难写,难就难在 你要考虑到百分之0.1的那种情况,比如写文件的时候 手机突然没电了 之类的,你得保证文件正确性,唯一性等等.今天就来看看这个DiskLruCache是怎么实现这些内容的. 用法大家就自己去谷歌吧,在这里提一句,DiskLruCache 在4.0以上的源码中被编译到了platform 下面的libcore.io这个包路径下

LinearLayout详解三:LayoutInflater创建View过程分析

项目人力资源管理主要有以下几个过程: 编制人力资源管理计划 组建项目团队 建设项目团队 项目团队管理 编制人力资源管理计划 根据什么来编? 直观点就是你要干什么事?干这些事有哪些制约? 这个说起来好像和没说一样,但就我自己做的一些项目来说,有以下困难: 1> 项目前期需求是不具体不明确的 这样直接导致你做项目计划时WBS也是不明确的,进而你细化不了活动,自然你也没法 明确活动需要什么样的人. 这个时候怎么办? 就我个人而言,有2种员工很喜欢: 1> 数学思维强的, 注意不是会做高数题,是指给你