项目尾声(ListView+CheckBox进行批量删除)

项目的最后就是显示截图记录,从一开始简单的在每个item右侧添加一个CheckBox的方式,改成了长按 某行item,每个item的CheckBox才显现出来,并且显现底部菜单栏进行编辑。

为了满足需求,需要重新订制Adapter,以下是我编写的Adapter的源码

import android.content.Context;

import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.CheckBox;
import android.widget.CompoundButton;
import android.widget.TextView;

import java.io.File;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.List;

public class MyAdapter extends BaseAdapter {
    private List<File> mData;
    private LayoutInflater mInflater;
    private Context context;
    private ViewHolder viewHolder;
    private HashMap<Integer, Integer> isVisibleMap;// 用来控制CheckBox的显示状况
    private HashMap<Integer, Boolean> isCheckMap;//用来控制CheckBox的选择状况

    public MyAdapter(Context context,List<File> mData){
        this.context=context;
        this.mInflater=LayoutInflater.from(context);
        this.mData=mData;
        isVisibleMap=new HashMap<>();
        isCheckMap=new HashMap<>();
        initDate();
    }

    @Override
    public int getCount() {
        int number = 0;
        if (mData!= null) {number = mData.size();}
        return number;
    }

    @Override
    public Object getItem(int position) {
        return null!=mData.get(position)?mData.get(position):null;
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

    // 初始化isSelectedMap的数据
    private void initDate() {
        for (int i = 0; i < mData.size(); i++) {
            getIsVisibleMap().put(i,CheckBox.GONE);
            getIsCheckMap().put(i,false);
        }
    }

    public HashMap<Integer, Integer> getIsVisibleMap() {
        return isVisibleMap;
    }
    public HashMap<Integer,Boolean> getIsCheckMap(){
        return isCheckMap;
    }

    private class ViewHolder{
        private TextView fileName;
        private TextView modifyName;
        private CheckBox checkBox;
    }

    @Override
    @SuppressWarnings("ResourceType")
    public View getView(final int position, View convertView, ViewGroup parent) {
        final File file= (File) getItem(position);
        if(convertView==null){
            convertView=mInflater.inflate(R.layout.pic_list_view,null);
            viewHolder=new ViewHolder();
            viewHolder.fileName= (TextView) convertView.findViewById(R.id.tvFileName);
            viewHolder.modifyName= (TextView) convertView.findViewById(R.id.tvModifyTime);
            viewHolder.checkBox= (CheckBox) convertView.findViewById(R.id.the_checkbox);
            final ViewHolder finalViewHolder=viewHolder;
            viewHolder.checkBox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
                @Override
                public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                    int radiaoId = (int) finalViewHolder.checkBox.getTag();
                    if(isChecked)
                    {
                        //将选中的放入hashmap中
                        isCheckMap.put(radiaoId, true);
                    }else {
                        isCheckMap.put(radiaoId,false);
                    }
                }
            });
            convertView.setTag(viewHolder);
            viewHolder.checkBox.setTag(position);
        }else {
            viewHolder= (ViewHolder) convertView.getTag();
            viewHolder.checkBox.setVisibility(getIsVisibleMap().get(position));
            viewHolder.checkBox.setTag(position);
        }
        viewHolder.fileName.setText(file.getName());
        SimpleDateFormat simpleDateFormat=new SimpleDateFormat("yyyy-MM-dd  HH:mm:ss");
        String time=simpleDateFormat.format(new Date(file.lastModified()));
        viewHolder.modifyName.setText(time);
        //找到需要选中的条目
        if(isCheckMap!=null && isCheckMap.containsKey(position))
        {
            viewHolder.checkBox.setChecked(isCheckMap.get(position));
        }
        else
        {
            viewHolder.checkBox.setChecked(false);
        }
        return convertView;
    }
}

下面来解释一下我的做法
1、实现CheckBox的隐藏和显现
核心代码是以下:

private HashMap<Integer, Integer> isVisibleMap;// 用来控制CheckBox的显示状况

// 初始化isSelectedMap的数据
    private void initDate() {
        for (int i = 0; i < mData.size(); i++) {
            getIsVisibleMap().put(i,CheckBox.GONE);
            getIsCheckMap().put(i,false);
        }
    }
 viewHolder.checkBox.setVisibility(getIsVisibleMap().get(position));

首先选择hashmap是因为其特性,键是唯一的不可重复,我这里将每个item的位置position做为键,就可以对应每个item,
然后在对map进行初始化,否则map为空会引起空指针,
最后就是通过position获取显示状态。
2、获取CheckBox被选中的item
这个和显示类似,核心代码如下:

private HashMap<Integer, Boolean> isCheckMap;

viewHolder.checkBox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
                @Override
                public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                    int radiaoId = (int) finalViewHolder.checkBox.getTag();
                    if(isChecked)
                    {
                        //将选中的放入hashmap中
                        isCheckMap.put(radiaoId, true);
                    }else {
                        isCheckMap.put(radiaoId,false);
                    }
                }
            });

//找到需要选中的条目
        if(isCheckMap!=null && isCheckMap.containsKey(position))
        {
            viewHolder.checkBox.setChecked(isCheckMap.get(position));
        }
        else
        {
            viewHolder.checkBox.setChecked(false);
        }

也用一个hashmap来控制选中状态,监听CheckBox的选中改变事件,然后分类进行赋值,其实上面两个if代码块可以不用进行判断。
第一个直接就isCheckMap.put(radiaoId, isChecked);
第二个的判断更是多余,直接viewHolder.checkBox.setChecked(isCheckMap.get(position))即可。
解决CheckBox错乱的方法就是viewHolder.checkBox.setTag(position);
没错我是对当前位置进行保存,然后通过getTag()的方法赋值给radiaoId,就不会错乱了。

总结
实现就是这么简单,两个hashmap解决,至于长按之后出现菜单诸如全选、删除、撤销等只是简单的逻辑问题,可以参考一下我的全部源码
地址:https://github.com/YougeView/myTestSignal

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值