- 浏览: 2149072 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (1240)
- mac/IOS (287)
- flutter (1)
- J2EE (115)
- android基础知识 (582)
- android中级知识 (55)
- android组件(Widget)开发 (18)
- android 错误 (21)
- javascript (18)
- linux (70)
- 树莓派 (18)
- gwt/gxt (1)
- 工具(IDE)/包(jar) (18)
- web前端 (17)
- java 算法 (8)
- 其它 (5)
- chrome (7)
- 数据库 (8)
- 经济/金融 (0)
- english (2)
- HTML5 (7)
- 网络安全 (14)
- 设计欣赏/设计窗 (8)
- 汇编/C (8)
- 工具类 (4)
- 游戏 (5)
- 开发频道 (5)
- Android OpenGL (1)
- 科学 (4)
- 运维 (0)
- 好东西 (6)
- 美食 (1)
最新评论
-
liangzai_cool:
请教一下,文中,shell、C、Python三种方式控制led ...
树莓派 - MAX7219 -
jiazimo:
...
Kafka源码分析-序列5 -Producer -RecordAccumulator队列分析 -
hp321:
Windows该命令是不是需要安装什么软件才可以?我试过不行( ...
ImageIO读jpg的时候出现javax.imageio.IIOException: Unsupported Image Type -
hp321:
Chenzh_758 写道其实直接用一下代码就可以解决了:JP ...
ImageIO读jpg的时候出现javax.imageio.IIOException: Unsupported Image Type -
huanghonhpeng:
大哥你真强什么都会,研究研究。。。。小弟在这里学到了很多知识。 ...
android 浏览器
布局用的是RelativeLayout这种布局方式,要指定位置,不太好,以后如果有其它好的方式再修改
main.xml布局文件:
list_items.xml布局文件:
MyList.java类:
MyCheckBoxAdapter.java类:
这篇文章主要是学习BaseAdapter类的使用,发的文章都是经过运行可以跑起来的,并且代码全会发到上面。
下面是运行结果:
main.xml布局文件:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="fill_parent" android:layout_height="fill_parent"> <ListView android:layout_width="fill_parent" android:layout_height="wrap_content" android:id="@+id/MyListView"> </ListView> </LinearLayout>
list_items.xml布局文件:
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="wrap_content" android:id="@+id/myListItem" android:paddingBottom="5dip" android:paddingLeft="12dip" android:paddingRight="12dip"> <ImageView android:id="@+id/img" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true"></ImageView> <TextView android:layout_height="wrap_content" android:layout_width="wrap_content" android:id="@+id/itemTitle" android:textSize="20dip" android:paddingTop="15px" android:layout_marginLeft="70px"> </TextView> <CheckBox android:id="@+id/cb" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentRight="true" android:focusable="false"></CheckBox> </RelativeLayout>
MyList.java类:
package iaiai.test; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import android.app.Activity; import android.app.AlertDialog; import android.content.DialogInterface; import android.os.Bundle; import android.view.ContextMenu; import android.view.ContextMenu.ContextMenuInfo; import android.view.MenuItem; import android.view.View; import android.view.View.OnCreateContextMenuListener; import android.widget.AdapterView; import android.widget.AdapterView.AdapterContextMenuInfo; import android.widget.AdapterView.OnItemClickListener; import android.widget.ListView; import android.widget.Toast; public class MyList extends Activity { private ListView list; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); list = (ListView) findViewById(R.id.MyListView); // 配置适配器 MyCheckBoxAdapter adapter = new MyCheckBoxAdapter(this,getData()); // 布局里的控件id // 添加并且显示 list.setAdapter(adapter); // 添加点击 list.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) { setTitle("点击第" + arg2 + "个项目"); Toast.makeText(MyList.this, "点击第" + arg2 + "个项目", Toast.LENGTH_LONG).show(); } }); // 添加长按点击 list.setOnCreateContextMenuListener(new OnCreateContextMenuListener() { @Override public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) { // menu.setHeaderIcon(R.drawable.icon); //字义图片样式 menu.setHeaderTitle("长按菜单选项:"); menu.add(1, 0, 0, "编辑"); menu.add(0, 1, 0, "删除"); } }); } @Override public boolean onContextItemSelected(MenuItem item) { int selectedPosition = ((AdapterContextMenuInfo) item.getMenuInfo()).position; // 刚才选择的 Map<String, String> map = (HashMap) list .getItemAtPosition(selectedPosition); // ListView中的数据 Toast.makeText(MyList.this, "你选择的:" + selectedPosition + ",内容为:" + map.get("itemTitle"), Toast.LENGTH_LONG).show(); // 显示那条数据 String temp = ""; switch (item.getItemId()) { case 0: temp = "编辑"; break; case 1: temp = "删除"; break; default: break; } // Toast.makeText(this, temp + "處理", Toast.LENGTH_LONG).show(); return super.onContextItemSelected(item); } private List<Map<String, String>> getData() { // 组织数据源 List<Map<String, String>> mylist = new ArrayList<Map<String, String>>(); for (int i = 0; i < 10; i++) { Map<String, String> map = new HashMap<String, String>(); map.put("" + i, i + ""); map.put("itemTitle", "文章" + i); mylist.add(map); } return mylist; } /** * listview中点击按键弹出对话框 */ public void showInfo() { new AlertDialog.Builder(this).setTitle("我的listview") .setMessage("介绍...") .setPositiveButton("确定", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { } }).show(); } }
MyCheckBoxAdapter.java类:
package iaiai.test; import java.util.HashMap; import java.util.List; import java.util.Map; import android.content.Context; import android.view.LayoutInflater; import android.view.View; import android.view.View.OnClickListener; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.CheckBox; import android.widget.ImageView; import android.widget.TextView; import android.widget.Toast; public class MyCheckBoxAdapter extends BaseAdapter { private LayoutInflater mInflater; private List<Map<String, String>> listData; private Map<Integer, Map<String, String>> selectMap = new HashMap<Integer, Map<String, String>>(); private class ViewHolder { public ImageView img; public TextView title; public CheckBox checkBox; } public MyCheckBoxAdapter(Context context, List<Map<String, String>> listData) { this.mInflater = LayoutInflater.from(context); this.listData = listData; } @Override public int getCount() { return listData.size(); } @Override public Object getItem(int position) { return listData.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(final int position, View convertView, ViewGroup parent) { ViewHolder holder = null; if (convertView == null) { holder = new ViewHolder(); convertView = mInflater.inflate(R.layout.list_items, null); final View view = convertView; holder.img = (ImageView) convertView.findViewById(R.id.img); holder.title = (TextView) convertView.findViewById(R.id.itemTitle); holder.checkBox = (CheckBox) convertView.findViewById(R.id.cb); holder.checkBox.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { if (selectMap.get(position) != null) { selectMap.remove(position); } else { selectMap.put(position, listData.get(position)); } Toast.makeText(view.getContext(), "你选择了:" + selectMap.size() + "个.", Toast.LENGTH_LONG).show(); } }); convertView.setTag(holder); } else { holder = (ViewHolder) convertView.getTag(); } holder.img.setBackgroundResource(R.drawable.icon); holder.title.setText(listData.get(position).get("itemTitle")); if (selectMap.get(position) != null) { holder.checkBox.setChecked(true); } else { holder.checkBox.setChecked(false); } return convertView; } }
这篇文章主要是学习BaseAdapter类的使用,发的文章都是经过运行可以跑起来的,并且代码全会发到上面。
下面是运行结果:
发表评论
-
带你深入理解 FLUTTER 中的字体“冷”知识
2020-08-10 23:40 576本篇将带你深入理解 Flutter 开发过程中关于字体和文 ... -
Flutter -自定义日历组件
2020-03-01 17:56 1036颜色文件和屏幕适配的文件 可以自己给定 import ... -
Dart高级(一)——泛型与Json To Bean
2020-02-23 19:13 930从 Flutter 发布到现在, 越来越多人开始尝试使用 Da ... -
flutter loading、Progress进度条
2020-02-21 17:03 1044Flutter Progress 1 条形无固定值进度条 ... -
Flutter使用Https加载图片
2020-02-21 01:39 907Flutter使用Https加载图片 使用http加载图片出 ... -
flutter shared_preferences 异步变同步
2020-02-21 00:55 772前言 引用 在开发原生iOS或Native应用时,一般有判断上 ... -
Flutter TextField边框颜色
2020-02-19 21:31 861监听要销毁 myController.dispose(); T ... -
flutter Future的正确用法
2020-02-18 21:55 739在flutter中经常会用到异步任务,dart中异步任务异步处 ... -
记一次Flutter简单粗暴处理HTTPS证书检验方法
2020-02-18 14:13 836最近在做Flutter项目到了遇到一个无解的事情,当使用Ima ... -
flutter 获取屏幕宽度高度 通知栏高度等屏幕信息
2019-07-27 08:39 1231##MediaQuery MediaQuery.of(con ... -
关于flutter RefreshIndicator扩展listview下拉刷新的问题
2019-07-10 19:40 1001当条目过少时listview某些嵌套情况下可能不会滚动(条目 ... -
flutter listview 改变状态的时候一直无限添加
2019-07-10 16:01 683setstate的时候会一直无限的调用listview.bui ... -
Flutter Android端启动白屏问题的解决
2019-07-09 00:51 1409问题描述 Flutter 应用在 Android 端上启动时 ... -
Flutter中SnackBar使用
2019-07-08 23:43 687底部弹出,然后在指定时间后消失。 注意: build(Bui ... -
Flutter 之点击空白区域收起键盘
2019-07-08 18:43 1670点击空白处取消TextField焦点这个需求是非常简单的,在学 ... -
Flutter 弹窗 Dialog ,AlertDialog,IOS风格
2019-07-08 18:04 1295import 'package:flutter/mate ... -
flutter ---TextField 之 输入类型、长度限制
2019-07-08 14:30 2208TextField想要实现输入类型、长度限制需要先引入impo ... -
【flutter 溢出BUG】键盘上显示bottom overflowed by 104 PIXELS
2019-07-08 11:13 1451一开始直接使用Scaffold布局,body:new Colu ... -
解决Flutter项目卡在Initializing gradle...界面的问题
2019-07-07 12:53 800Flutter最近很火,我抽出了一点时间对Flutter进行了 ... -
关于android O 上 NotificationChannel 的一些注意事项
2019-07-04 11:47 892最近在适配android O,遇到个问题,应用中原本有设置界面 ...
相关推荐
有源码有实例,delphi Listview复选框checkbox实现单选的功能,代码很精简实用,测试完美!
C#的ListView添加各种自定义控件,CheckBox,ComboBox等
这个项目是Android studio的,eclipse的朋友可以复制一下资源就能用了。知识点:1、解决listView滚动时checkBox的选择状态会发生变化(絮乱);2、ListView的Item长按,点击时间并存,实现同一UI控件多需求响应各类...
android 的listview 内部item的布局包含checkbox控件简单好用!
本文主要实现在自定义的ListView布局中加入CheckBox控件,通过判断用户是否选中CheckBox来对ListView的选中项进行相应的操作。通过一个Demo来展示该功能,选中ListView中的某一项,然后点击Button按钮来显示选中了...
博客《 带checkbox的ListView实现(二)——自定义Checkable控件的实现方法》对应源码,博客地址:http://blog.csdn.net/harvic880925/article/details/40475367
在delphi中使用listview控件,启用checkbox选项后,默认是多选,此示例实现单选功能,在Delphi7下测试通过。
WPF 使用MVVM设计模式对进行增删改操作 具体内容可以看我的博客:https://blog.csdn.net/Dear200892/article/details/78849632
通过自定义Checkable控件,来实现点击ListView中的Item来监听其中的cheakbox.体验效果更好
主要实现了 listview 中添加checkbox 控件 并处理了焦点问题 可以实现 我们在常用软件上看到的功能 如国想用在项目中 的需要和数据库相关联 我这里没有给出
android的listview中包含checkbox,并且有全选反选和清楚选择的操作,效果图见http://www.eoeandroid.com/forum.php?mod=viewthread&tid=300663&page=1&extra=#pid3057257
完美的解决listview嵌套checkbox遇到的各种问题 以及checkbox选中后获得的值
一个list的类,带有树形控件、checkbox,选中行,颜色会变
andorid listview由于复用控件的问题,再布局上使用checkbox时会造成选中状态错乱的问题,该项目可以解决该问题
ListView在项目里面会经常遇到,但是有时候在使用的过程中会遇到一些让我们意想不到的问题,在这里实现了个关于ListView Item里面含有RadioButton、CheckBox、星星、EditText控件的demo,详情请前往博客浏览...
这个文档是解决listview中添加checkbox控件,选中checkbox后listview上下滑动,checkbox对应的item不发生移位,代码比较简单,适合新手
c#中一个很有用的控件listview,在其上添加checkbox,实现全部、反选等功能
本文主要实现在自定义的ListView布局中加入CheckBox控件,通过判断用户是否选中CheckBox来对ListView的选中项进行相应的操作。通过一个Demo来展示该功能,选中ListView中的某一项,然后点击Button按钮来显示选中了...