ListView中CheckBox批量删除item

ListView中CheckBox批量删除item的笔记,在这里记录一下,方便以后的使用。

首先效果图:
这里写图片描述

  1. 实体bean
public class Bean {

    private String username;

    private int age;

    private boolean isChecked;

    public Bean(String username, int age) {
        this.username = username;
        this.age = age;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public boolean isChecked() {
        return isChecked;
    }

    public void setChecked(boolean checked) {
        isChecked = checked;
    }

    @Override
    public String toString() {
        return "Bean{" +
                "username='" + username + '\'' +
                ", age=" + age +
                ", isChecked=" + isChecked +
                '}';
    }
}
  1. item布局文件
<?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="wrap_content"
    android:orientation="horizontal"
    android:padding="15dp">


    <CheckBox
        android:id="@+id/cb_check"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1" />

    <TextView
        android:id="@+id/tv_username"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="2"
        android:text="小黑" />

    <TextView
        android:id="@+id/tv_age"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="2"
        android:text="12" />


</LinearLayout>
  1. 适配器 adapter
public class Adapter extends BaseAdapter {

    private List<Bean> dataList;

    private Context context;

    private List<Boolean> flagList;


    public Adapter(List<Bean> dataList, Context context) {
        this.dataList = dataList;
        this.context = context;
        flagList = new ArrayList<>();
        for (int i = 0; i < dataList.size(); i++) {
            flagList.add(false);
        }
    }

    @Override
    public int getCount() {
        return dataList.size();
    }

    @Override
    public Object getItem(int position) {
        return dataList.get(position);
    }

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

    @Override
    public View getView(final int position, View convertView, ViewGroup parent) {
        final ViewHolder holder;
        if (convertView == null) {
            holder = new ViewHolder();
            convertView = View.inflate(context, R.layout.layout_item, null);
            holder.cb_check = (CheckBox) convertView.findViewById(R.id.cb_check);
            holder.tv_username = (TextView) convertView.findViewById(R.id.tv_username);
            holder.tv_age = (TextView) convertView.findViewById(R.id.tv_age);
            convertView.setTag(holder);

        } else {
            holder = (ViewHolder) convertView.getTag();
        }

        final Bean bean = dataList.get(position);
        holder.cb_check.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

                if (holder.cb_check.isChecked()) {
                    bean.setChecked(true);
                    flagList.set(position, true);


                } else {
                    bean.setChecked(false);
                    flagList.set(position, false);
                }
                Log.i("debug", "flagList=" + flagList);
            }
        });

        holder.tv_username.setText(bean.getUsername());
        holder.tv_age.setText(bean.getAge() + "");
        holder.cb_check.setChecked(bean.isChecked());


        return convertView;
    }

    static class ViewHolder {
        public CheckBox cb_check;

        public TextView tv_username;

        public TextView tv_age;
    }


    public List<Boolean> getFlagList() {
        return flagList;
    }


    public void setFlagList(List<Boolean> list) {
        flagList = list;
    }


    public void updateData(List<Bean> list) {
        dataList = list;
        notifyDataSetChanged();
    }

}
  1. 主要布局和Activity
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context="com.an.listview.MainActivity">


    <ListView
        android:id="@+id/listView"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />


    <android.support.design.widget.FloatingActionButton
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="right|bottom"
        android:layout_marginBottom="20dp"
        android:layout_marginRight="20dp"
        android:onClick="click"
        android:src="@drawable/delete"
        app:elevation="6dp"
        app:pressedTranslationZ="12dp"
        app:rippleColor="#33728dff" />


</FrameLayout>
public class MainActivity extends AppCompatActivity {

    private ListView listView;

    private Adapter adapter;

    private List<Bean> list;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        listView = (ListView) findViewById(R.id.listView);
        list = new ArrayList<>();
        for (int i = 0; i < 20; i++) {
            list.add(new Bean("Tom->" + i, 20 + i));
        }
        if (adapter == null) {
            adapter = new Adapter(list, this);
            listView.setAdapter(adapter);
        } else {
            adapter.notifyDataSetChanged();
        }
    }

    public void click(View view) {
        List<Boolean> flagList = adapter.getFlagList();
        Log.i("debug", "get " + flagList);
        for (int i = 0; i < flagList.size(); ) {
            if (flagList.get(i)) {
                flagList.remove(i); //当删除一个数据时,紧接它后面的数据会移到删除数据的位置上,所以这时不应该i++
                list.remove(i);
                continue;
            }
            i++;
        }
        adapter.setFlagList(flagList);
        adapter.updateData(list);
    }

}
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是在Android生成ListView长按删除item的代码示例: 首先,在XML布局文件定义ListView: ``` <ListView android:id="@+id/my_listview" android:layout_width="match_parent" android:layout_height="wrap_content"/> ``` 然后,在Java代码,为ListView设置长按监听器,并创建自定义的Adapter类: ``` // 获取ListView ListView listView = findViewById(R.id.my_listview); // 创建Adapter并设置给ListView MyAdapter adapter = new MyAdapter(this, dataList); listView.setAdapter(adapter); // 给ListView设置长按监听器 listView.setOnItemLongClickListener(new AdapterView.OnItemLongClickListener() { @Override public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) { // 弹出删除确认对话框 AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this); builder.setMessage("确定要删除该项吗?"); builder.setPositiveButton("确定", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { // 删除数据源对应的数据项 dataList.remove(position); // 更新ListView adapter.notifyDataSetChanged(); } }); builder.setNegativeButton("取消", null); builder.show(); return true; } }); // 自定义Adapter类 class MyAdapter extends BaseAdapter { private Context mContext; private List<String> mDataList; public MyAdapter(Context context, List<String> dataList) { mContext = context; mDataList = dataList; } @Override public int getCount() { return mDataList.size(); } @Override public Object getItem(int position) { return mDataList.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder; if (convertView == null) { convertView = LayoutInflater.from(mContext).inflate(R.layout.list_item, parent, false); holder = new ViewHolder(); holder.textView = convertView.findViewById(R.id.item_textview); convertView.setTag(holder); } else { holder = (ViewHolder) convertView.getTag(); } String item = mDataList.get(position); holder.textView.setText(item); return convertView; } class ViewHolder { TextView textView; } } ``` 在上面的代码,我们首先为ListView设置了长按监听器,在监听器弹出一个确认对话框,如果用户点击确定,则从数据源删除对应的数据项,并调用adapter.notifyDataSetChanged()方法来更新ListView。 自定义Adapter类,我们实现了getView()方法来设置ListView每个item的样式。ViewHolder类用于缓存item的TextView,以提高ListView的性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值