android ListView中Checkbox实现单选,全选,全不选功能

简介:

 
@Override
 protected void onCreate(Bundle savedInstanceState) {
  // TODO Auto-generated method stub
  super.onCreate(savedInstanceState);
  setContentView(R.layout.group_list2);
  
  initBottomBar();
  
  listView = (ListView) findViewById(R.id.groupListView);
  
  GroupService service = new GroupService(this);
  groupList = service.getGroupList(null);
  adapter = new GroupListAdapter(this, groupList);
  listView.setAdapter(adapter);
  
  listView.setOnItemClickListener(new OnItemClickListener() {

   @Override
   public void onItemClick(AdapterView<?> adapterView, View view, int position,
     long arg3) {
    // TODO Auto-generated method stub
    Group group = groupList.get(position);
    CheckBox ctb = (CheckBox) view.findViewById(R.id.checkBox);
    ctb.toggle();
    adapter.selectedMap.put(group.id, ctb.isChecked());
    adapter.notifyDataSetChanged();
    if(adapter.selectedMap.containsValue(true)){
     add2ScanListBtn.setEnabled(true);
    }else{
     add2ScanListBtn.setEnabled(false);
    }
   }
  });
  
 }

 

 private  void initBottomBar(){
  bottomBarView = (LinearLayout) findViewById(R.id.bottomBar);
  add2ScanListBtn = (Button) bottomBarView.findViewById(R.id.add2ScanListBtn);
  add2ScanListBtn.setEnabled(false);
  checkBtn = (Button) bottomBarView.findViewById(R.id.checkBtn);
  closeCheckBtn = (Button) bottomBarView.findViewById(R.id.closeCheckBtn);
  
  add2ScanListBtn.setOnClickListener(this);
  checkBtn.setOnClickListener(this);
  closeCheckBtn.setOnClickListener(this);
 }
@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		menu.add(0, MENU_EDITOR, 0, "编辑");
		return super.onCreateOptionsMenu(menu);
	}
	
	@Override
	public boolean onOptionsItemSelected(MenuItem item) {
		switch (item.getItemId()) {
		case MENU_EDITOR:
			setCheckBoxVisible(View.VISIBLE);
			adapter.notifyDataSetChanged();
			break;

		default:
			break;
		}
		return super.onOptionsItemSelected(item);
	}
	
	@Override
	public void onClick(View v) {
		switch (v.getId()) {
		case R.id.add2ScanListBtn:
			GroupService service = new GroupService(this);
			service.add2ScanList(adapter.selectedMap);
			for (Group group : groupList) {
				adapter.selectedMap.put(group.id, false);
			}
			setCheckBoxVisible(View.GONE);
			adapter.notifyDataSetChanged();
			break;
		case R.id.checkBtn:
			CharSequence text = checkBtn.getText();
			if (getText(R.string.checkAll).equals(text)) {
				for (int i = 0; i < adapter.getCount(); i++) {
					Group group = groupList.get(i);
					adapter.selectedMap.put(group.id, true);
				}
				checkBtn.setText(getText(R.string.checkNeither));
				add2ScanListBtn.setEnabled(true);
			}else if(getText(R.string.checkNeither).equals(text)){
				for (int i = 0; i < adapter.getCount(); i++) {
					Group group = groupList.get(i);
					adapter.selectedMap.put(group.id, false);
				}
				checkBtn.setText(getText(R.string.checkAll));
				add2ScanListBtn.setEnabled(false);
			}
			
			adapter.notifyDataSetChanged();
			break;
		case R.id.closeCheckBtn:
			setCheckBoxVisible(View.GONE);
			adapter.notifyDataSetChanged();
			break;
		default:
			break;
		}
	}

 

//设置checkbox是否可见
	private void setCheckBoxVisible(int state){
		bottomBarView.setVisibility(state);
		for (int i = 0; i < adapter.getCount(); i++) {
			Group group = groupList.get(i);
			adapter.visibleMap.put(group.id, state);
		}
	} 


class GroupListAdapter extends BaseAdapter{
		
		private Context context;
		private List<Group> groupList;
		private Map<Integer, Boolean> selectedMap;//保存checkbox是否被选中的状态
		private Map<Integer, Integer> visibleMap ;
		public GroupListAdapter(Context context, List<Group> groupList) {
			this.context = context;
			this.groupList = groupList;
			selectedMap = new HashMap<Integer, Boolean>();
			visibleMap = new HashMap<Integer, Integer>();
			for (Group group : groupList) {
				selectedMap.put(group.id, false);
				visibleMap.put(group.id, View.GONE);
			}
		}
		@Override
		public int getCount() {
			// TODO Auto-generated method stub
			return groupList.size();
		}

		@Override
		public Object getItem(int position) {
			// TODO Auto-generated method stub
			return position;
		}

		@Override
		public long getItemId(int position) {
			// TODO Auto-generated method stub
			return position;
		}

		@Override
		public View getView(int position, View convertView, ViewGroup parent) {
			final ViewHolder holder;
			if (convertView == null) {
				holder = new ViewHolder();
				convertView = LayoutInflater.from(context).inflate(R.layout.group_list2_item, null);
				holder.groupNameCTV = (TextView) convertView.findViewById(R.id.groupNameTV);
				holder.checkBox = (CheckBox) convertView.findViewById(R.id.checkBox);
				convertView.setTag(holder);
			} else {
				holder = (ViewHolder) convertView.getTag();
			}
			Group group = groupList.get(position);
			holder.groupNameCTV.setText(group.m_strGroupName);
			holder.checkBox.setVisibility(visibleMap.get(group.id));
			holder.checkBox.setChecked(selectedMap.get(group.id));
			return convertView;
		}
		
		private class ViewHolder{
			TextView groupNameCTV;
			CheckBox checkBox;
		}
	}


group_list2.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="fill_parent"
  android:orientation="vertical">
  	  <LinearLayout android:layout_height="0dip"
	  	android:layout_width="match_parent"
	  	android:layout_weight="1">
	  	<ListView android:id="@+id/groupListView"
	  		android:layout_width="match_parent"
	  		android:layout_height="match_parent"
	  		android:divider="#999999"
	  		android:dividerHeight="1sp"
	  		/>
  		</LinearLayout>
  		
  		<LinearLayout android:id="@+id/bottomBar"
  			android:layout_height="wrap_content"
		  	android:layout_width="match_parent" android:gravity="center_horizontal"
		  	android:padding="5dip" android:background="@drawable/buttonbar"
		  	android:visibility="gone">
		  	<Button android:id="@+id/add2ScanListBtn"
			    android:layout_width="wrap_content"
			    android:layout_height="wrap_content" 
			    android:text="@string/add2ScanList"/>
		    <Button android:id="@+id/checkBtn"
			    android:layout_width="wrap_content"
			    android:layout_height="wrap_content"
			    android:text="@string/checkAll" />
			<Button android:id="@+id/closeCheckBtn"
			    android:layout_width="wrap_content"
			    android:layout_height="wrap_content"
			    android:text="@string/cancel" />
  		</LinearLayout>
</LinearLayout>


group_list2_item.xml

 

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="horizontal"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:layout_gravity="center_horizontal"
  >
  
  		<TextView android:id="@+id/groupNameTV"
		  	android:layout_width="wrap_content"
		  	android:layout_height="wrap_content"
		  	android:textSize="20dip"
		  	android:layout_alignParentLeft="true"
		  	android:textColor="@android:color/white"
		  	android:layout_marginTop="12dip"
		  	android:layout_marginLeft="5dip"
		  	android:paddingBottom="12dip"
		  	/>

		<CheckBox android:id="@+id/checkBox"
			android:layout_width="wrap_content"
	    	android:layout_height="wrap_content"
	  		android:layout_alignParentRight="true"
	  		android:layout_marginRight="5dip"
	  		android:clickable="false"
		  	android:focusable="false"
		  	android:focusableInTouchMode="false"
	    />
  
</RelativeLayout>


 

 

 


相关文章
|
3月前
|
Android开发
Android开发表情emoji功能开发
本文介绍了一种在Android应用中实现emoji表情功能的方法,通过将图片与表情字符对应,实现在`TextView`中的正常显示。示例代码展示了如何使用自定义适配器加载emoji表情,并在编辑框中输入或删除表情。项目包含完整的源码结构,可作为开发参考。视频演示和源码详情见文章内链接。
90 4
Android开发表情emoji功能开发
|
3月前
|
安全 Android开发 iOS开发
Android vs iOS:探索移动操作系统的设计与功能差异###
【10月更文挑战第20天】 本文深入分析了Android和iOS两个主流移动操作系统在设计哲学、用户体验、技术架构等方面的显著差异。通过对比,揭示了这两种系统各自的独特优势与局限性,并探讨了它们如何塑造了我们的数字生活方式。无论你是开发者还是普通用户,理解这些差异都有助于更好地选择和使用你的移动设备。 ###
73 3
|
5月前
|
编解码 测试技术 Android开发
Android经典实战之用 CameraX 库实现高质量的照片和视频拍摄功能
本文详细介绍了如何利用CameraX库实现高质量的照片及视频拍摄功能,包括添加依赖、初始化、权限请求、配置预览与捕获等关键步骤。此外,还特别针对不同分辨率和帧率的视频拍摄提供了性能优化策略,确保应用既高效又稳定。
568 1
Android经典实战之用 CameraX 库实现高质量的照片和视频拍摄功能
|
4月前
|
Android开发 开发者
Android平台无纸化同屏如何实现实时录像功能
Android平台无纸化同屏,如果需要本地录像的话,实现难度不大,只要复用之前开发的录像模块的就可以,对我们来说,同屏采集这块,只是数据源不同而已,如果是自采集的其他数据,我们一样可以编码录像。
|
5月前
|
图形学 Android开发
小功能⭐️Unity调用Android常用事件
小功能⭐️Unity调用Android常用事件
|
7月前
|
API Android开发 开发者
`RecyclerView`是Android API 21引入的UI组件,用于替代ListView和GridView
【6月更文挑战第26天】`RecyclerView`是Android API 21引入的UI组件,用于替代ListView和GridView。它提供高效的数据视图复用,优化的布局管理,支持多种布局(如线性、网格),并解耦数据、适配器和视图。RecyclerView的灵活性、性能(如局部刷新和动画支持)和扩展性使其成为现代Android开发的首选,特别是在处理大规模数据集时。
90 2
|
7月前
|
数据库 Android开发 数据安全/隐私保护
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
302 2
|
7月前
|
Android开发
Android中如何快速的实现RecycleView的拖动重排序功能
使用`ItemTouchHelper`和自定义`Callback`,在`RecyclerView`中实现拖动排序功能。定义`ItemTouchHelperAdapter`接口,`Adapter`实现它以处理`onItemMove`方法。`SimpleItemTouchHelperCallback`设置拖动标志,如`LEFT`或`RIGHT`(水平拖动),并绑定到`RecyclerView`以启用拖动。完成这些步骤后,即可实现拖放排序。关注公众号“AntDream”获取更多内容。
133 3
|
7月前
|
前端开发 API Android开发
25. 【Android教程】列表控件 ListView
25. 【Android教程】列表控件 ListView
274 2
|
8月前
|
移动开发 监控 Android开发
构建高效Android应用:从内存优化到电池寿命代码之美:从功能实现到艺术创作
【5月更文挑战第28天】 在移动开发领域,特别是针对Android系统,性能优化始终是关键议题之一。本文深入探讨了如何通过细致的内存管理和电池使用策略,提升Android应用的运行效率和用户体验。文章不仅涵盖了现代Android设备上常见的内存泄漏问题,还提出了有效的解决方案,包括代码级优化和使用工具进行诊断。同时,文中也详细阐述了如何通过减少不必要的后台服务、合理管理设备唤醒锁以及优化网络调用等手段延长应用的电池续航时间。这些方法和技术旨在帮助开发者构建更加健壮、高效的Android应用程序。

热门文章

最新文章