网上有很多Listview与Checbox结合的例子,大多都存在这样那样的问题,要么选择异常,要么滚动Listview后选择消失,要么删除异常,要么无法正常显示选择结果。
以下为真正无误的,实用的Listview与Checkbox结合实现选择,删除,显示选择结果。
MainActivity.java
package com.example.listviewcheckbox;
import java.util.ArrayList;
import java.util.List;
import com.example.listviewcheckbox.R;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.CheckBox;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends Activity {
Button show;
Button select;
Button deselect;
ListView lv;
Context mContext;
MyListAdapter adapter;
List<Integer> selected = new ArrayList<Integer>();
private List<Item> items;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
//mContext = getApplicationContext();
mContext = MainActivity.this;
select = (Button)findViewById(R.id.select);
deselect = (Button)findViewById(R.id.deselect);
show = (Button)findViewById(R.id.show);
lv = (ListView)findViewById(R.id.lv);
items = new ArrayList<Item>();
for(int i=0;i< 50;i++){
Item item = new Item();
item.name = "wxz"+i;
item.address = "ZhengZhou";
item.checked = false;
items.add(item);
}
adapter = new MyListAdapter(items);
lv.setAdapter(adapter);
lv.setOnItemClickListener(new android.widget.AdapterView.OnItemClickListener(){
@Override
public void onItemClick(AdapterView<?> parent, View view, int position,
long id) {
// TODO Auto-generated method stub
items.get(position).checked = !items.get(position).checked;
adapter.notifyDataSetChanged();
Toast.makeText(mContext, "单击:"+items.get(position).name +",id:"+id, Toast.LENGTH_SHORT).show();
}
});
select.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
int k = items.size();
for(int i=0; i<k; i++){
items.get(i).checked = true;
}
adapter.notifyDataSetChanged();
}
});
deselect.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
int k = items.size();
for(int i=0; i<k; i++){
items.get(i).checked = false;
}
adapter.notifyDataSetChanged();
}
});
show.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
selected.clear();
int k = items.size();
for(int i=0; i<k; i++){
if(items.get(i).checked){
selected.add(i);
}
}
k = selected.size();
if(k ==0){
AlertDialog.Builder builder1 = new AlertDialog.Builder(MainActivity.this);
builder1.setMessage("没有选中任何记录");
builder1.show();
}else{
StringBuilder sb = new StringBuilder();
for(int i=0; i<k; i++){
int j = selected.get(i);
sb.append("ID="+(j)+" Name ="+items.get(j).name+"\n");
}
AlertDialog.Builder builder2 = new AlertDialog.Builder(MainActivity.this);
builder2.setMessage(sb.toString());
builder2.show();
}
}
});
}
//自定义ListView适配器
class MyListAdapter extends BaseAdapter{
//private Context context;
LayoutInflater inflater;
public List<Item> items;
public MyListAdapter(List<Item> items){
this.items = items;
inflater = LayoutInflater.from(mContext);
}
@Override
public int getCount() {
// 返回值控制该Adapter将会显示多少个列表项
return items == null ? 0 : items.size();
}
@Override
public Object getItem(int position) {
// 返回值决定第position处的列表项的内容
return items.get(position);
}
@Override
public long getItemId(int position) {
// 返回值决定第position处的列表项的ID
return position;
}
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
ViewHolder holder = null;
Item item = items.get(position);
if (convertView == null) {
Log.e("MainActivity","position1 = "+position);
convertView = inflater.inflate(R.layout.listitem, null);
holder = new ViewHolder();
holder.btnDel = (Button)convertView.findViewById(R.id.btnDel);
holder.cbCheck = (CheckBox)convertView.findViewById(R.id.cbCheck);
holder.tvName = (TextView)convertView.findViewById(R.id.tvName);
holder.tvAddress = (TextView)convertView.findViewById(R.id.tvAddress);
holder.tvName.setText(item.name);
holder.tvAddress.setText(item.address);
convertView.setTag(holder);
}else{
Log.e("MainActivity","position2 = "+position);
holder = (ViewHolder)convertView.getTag();
holder.cbCheck.setChecked(item.checked);
holder.tvName.setText(item.name);
holder.tvAddress.setText(item.address);
}
holder.btnDel.setOnClickListener(new OnClickListener(){
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
//删除list中的数据
items.remove(position);
//通知列表数据修改
adapter.notifyDataSetChanged();
}
});
holder.cbCheck.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
CheckBox cb = (CheckBox)v;
items.get(position).checked = cb.isChecked();
}
});
return convertView;
}
}
static class ViewHolder{
public CheckBox cbCheck;
public TextView tvName;
public TextView tvAddress;
public Button btnDel;
}
class Item {
private String name;
private String address;
private Boolean checked;
}
}
列表项listitem.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:descendantFocusability="blocksDescendants"
android:orientation="horizontal" >
<CheckBox
android:id="@+id/cbCheck"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:focusable="false" />
<ImageView
android:id="@+id/ivPhoto"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_launcher"/>
<TextView
android:id="@+id/tvName"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:layout_weight="1"
android:text="Name"
android:textSize="18sp" />
<TextView
android:id="@+id/tvAddress"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:layout_weight="1"
android:text="Address"
android:textSize="18sp" />
<Button
android:id="@+id/btnDel"
android:layout_width="wrap_content"
android:layout_height="40dp"
android:layout_marginRight="16dp"
android:layout_marginTop="5dp"
android:focusable="false"
android:text="删除"
android:textSize="16sp" />
</LinearLayout>
main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<LinearLayout
android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="wrap_content" >
<Button
android:id="@+id/select"
android:layout_width="100dp"
android:layout_height="wrap_content"
android:text="Select"/>
<Button
android:id="@+id/deselect"
android:layout_width="100dp"
android:layout_height="wrap_content"
android:text="Deselect" />
<Button
android:id="@+id/show"
android:layout_width="100dp"
android:layout_height="wrap_content"
android:text="Show"/>
</LinearLayout>
<ListView
android:id="@+id/lv"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:fastScrollEnabled="true"
android:fastScrollAlwaysVisible="true"/>
</LinearLayout>
源码:http://download.csdn.net/detail/xinzheng_wang/5973407
分享到:
相关推荐
在这个特定的场景中,我们关注的是如何将CheckBox集成到ListView中,实现多种交互模式,如单选、多选、全选、取消全选以及删除功能,并能实时显示选择结果。 1. **ListView与CheckBox的结合**: 在自定义ListView...
本篇文章将详细探讨如何在Android中实现一个具有多选、反选、删除和全选功能的ListView,结合CheckBox的使用。 首先,我们需要创建一个自定义的ListView项布局,包含一个TextView用于显示数据,以及一个CheckBox...
在ListView中实现删除功能,通常需要在CheckBox旁边添加一个删除按钮或提供长按操作。当用户勾选CheckBox后,可以将选中的数据项添加到一个临时集合中,然后通过遍历这个集合并从数据源中移除对应的项,最后再次调用...
综上所述,实现"Android中使用ListView和CheckBox实现购物车多选功能"涉及到ListView的自定义Adapter、CheckBox的状态管理、全选/全不选功能、多选操作的实现以及性能优化等多个环节。这个过程中需要充分理解Android...
通过以上步骤,我们成功实现了ListView与Checkbox的结合,让用户能够方便地选择多个项目进行批量删除。这个功能在许多应用中都非常实用,例如邮件客户端、联系人管理器等。在实际开发中,我们还需要考虑用户体验,...
在这个特定的示例"listview+checkbox选中删除,全选,item点击"中,我们关注的是如何结合ListView和CheckBox实现一系列交互功能,包括单选、多选、全选以及删除列表项,并解决ListView中的item点击事件无法正常触发...
当这两者结合时,可以实现用户在ListView中进行多项选择,例如全选、取消选中以及删除操作。以下是关于"ListView CheckBox"的相关知识点详解: 1. **ListView的使用**: - `ListView`是Android中一个可滚动的视图...
本资源提供了一个高级应用的源码示例,实现了ListView与CheckBox结合的UI设计,包括全选、全不选以及删除等功能。这个功能在许多应用中都有广泛应用,如通讯录、购物车等场景。 1. **ListView基础** ListView是...
本篇将详细介绍如何在Android中通过ListView与CheckBox结合,实现数据的批量选择,包括全选、反选和全不选。 首先,我们需要创建一个布局文件`list_item_data.xml`,作为ListView的每一项内容。在这个布局中,包含...
这篇内容将详细介绍如何在Android中结合ListView和CheckBox来实现这一功能。 首先,我们需要创建一个自定义的ListView适配器。这个适配器应该继承自BaseAdapter,因为BaseAdapter是ListView的基础,它可以让我们...
在Android开发中,"android 仿淘宝京东购物车 ...实际开发中,还需要结合具体需求,考虑如何实现商品的添加、删除、更新功能,以及与服务器的数据交互等问题。通过实践这些知识点,可以创建出功能完善的购物车界面。
将ListView与CheckBox结合,可以实现更丰富的交互功能,比如在列表中进行多项选择,进行全选、撤销、删除等操作。 在“ListView结合checkBox”的场景下,我们需要做以下几个关键步骤来实现功能: 1. **自定义...
总之,实现Android ListView的批量删除功能,需要结合Adapter、CheckBox以及数据源的管理。理解ListView的工作原理和Adapter模式,以及如何处理用户的交互,是完成这一功能的关键。通过以上步骤,可以为用户提供一个...
在安卓开发中,ListView是常用的一种...总之,这个教程涵盖了安卓开发中常见的ListView和CheckBox结合使用场景,通过源码示例,帮助开发者实现全选、全不选及删除功能,对于理解和掌握安卓UI设计有着积极的指导作用。
总之,这份源码示例涵盖了Android开发中常见的ListView与CheckBox结合使用场景,包括全选、全不选和删除功能的实现,对于初学者和有经验的开发者来说都是一个很好的学习资源。通过深入研究并理解这些代码,可以提升...
将ListView与CheckBox结合使用,可以创建出类似于手机短信应用中选择联系人进行删除的功能。 1. **ListView基本概念** - ListView是Android提供的一个视图容器,用于显示多行数据,它可以动态加载数据,提高应用...
总的来说,这个"ListView+CheckBox UI 完美版"项目展示了如何在Android应用中集成和管理复杂的用户交互,包括CheckBox与ListView的协同工作,以及实现全选、全不选和删除等实用功能。对于初学者来说,这是一个很好的...
然而,当ListView与CheckBox结合使用时,可能会出现一种常见的问题:ListView滚动时,CheckBox的状态与对应的数据显示错位。这个问题通常由于ListView的复用机制导致,即ListView的每个Item(ViewHolder)在滚动时会...
在Android开发中,ListView是一种常用的UI组件,用于展示大量数据列表。...这个例子不仅展示了如何结合ListView与Checkbox,还涉及了适配器、事件监听以及数据管理的基本概念,对Android应用开发具有重要的实践意义。