- 浏览: 2203680 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (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 浏览器
运行效果:
main.xml
list_items.xml
list_items_tag.xml
MyAdapter.java
MainActivity.java
========================================================================
以上为示例所有代码,以下为说明
禁止标签项的响应事件,父类BaseAdapter中提供了isEnable的()方法,我们看看这个方法:
这个方法刚好用来禁用标签项的响应事件。
现在标签项不会再有任何触控效果了,犹如一块死木板。
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"?> <LinearLayout 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="4dip" android:paddingLeft="12dip" android:paddingRight="12dip"> <TextView android:layout_height="wrap_content" android:layout_width="fill_parent" android:id="@+id/itemTitle" android:textSize="20dip" /> </LinearLayout>
list_items_tag.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:background="#555555" android:paddingLeft="10dip"> <TextView android:id="@+id/itemTitle" android:layout_width="wrap_content" android:layout_height="20dip" android:textColor="#ffffff" android:gravity="center_vertical" /> </LinearLayout>
MyAdapter.java
package com.iaiai; import java.util.List; import java.util.Map; import android.content.Context; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.TextView; /** * * <p> * Title: MyAdapter.java * </p> * <p> * E-Mail: 176291935@qq.com * </p> * <p> * QQ: 176291935 * </p> * <p> * Http: iaiai.iteye.com * </p> * <p> * Create time: 2011-10-10 * </p> * * @author 丸子 * @version 0.0.1 */ public class MyAdapter extends BaseAdapter { private LayoutInflater mInflater; private List<Map<String, String>> listData; private List<Map<String, String>> splitData; public MyAdapter(Context context, List<Map<String, String>> listData, List<Map<String, String>> splitData) { this.mInflater = LayoutInflater.from(context); this.listData = listData; this.splitData = splitData; } @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 boolean isEnabled(int position) { if (splitData.contains(listData.get(position))) { return false; } return super.isEnabled(position); } @Override public View getView(final int position, View convertView, ViewGroup parent) { if (splitData.contains(listData.get(position))) { convertView = mInflater.inflate(R.layout.list_items_tag, null); } else { convertView = mInflater.inflate(R.layout.list_items, null); } TextView textView = (TextView) convertView.findViewById(R.id.itemTitle); textView.setText(listData.get(position).get("itemTitle")); return convertView; } }
MainActivity.java
package com.iaiai; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import android.app.Activity; import android.os.Bundle; import android.widget.ListView; /** * * <p> * Title: MainActivity.java * </p> * <p> * E-Mail: 176291935@qq.com * </p> * <p> * QQ: 176291935 * </p> * <p> * Http: iaiai.iteye.com * </p> * <p> * Create time: 2011-10-10 * </p> * * @author 丸子 * @version 0.0.1 */ public class MainActivity extends Activity { private List<Map<String, String>> mylist = new ArrayList<Map<String, String>>(); private List<Map<String, String>> splitList = new ArrayList<Map<String, String>>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); ListView list = (ListView) findViewById(R.id.MyListView); setData(); // 设置数据 // 配置适配器 MyAdapter adapter = new MyAdapter(this, mylist, splitList); // 布局里的控件id // 添加并且显示 list.setAdapter(adapter); } private void setData() { // 组织数据源 Map<String, String> mp = new HashMap<String, String>(); mp.put("itemTitle", "A"); mylist.add(mp); splitList.add(mp); for (int i = 0; i < 3; i++) { Map<String, String> map = new HashMap<String, String>(); map.put("itemTitle", "文章1-" + i); mylist.add(map); } mp = new HashMap<String, String>(); mp.put("itemTitle", "B"); mylist.add(mp); splitList.add(mp); for (int i = 0; i < 6; i++) { Map<String, String> map = new HashMap<String, String>(); map.put("itemTitle", "文章2-" + i); mylist.add(map); } } }
========================================================================
以上为示例所有代码,以下为说明
禁止标签项的响应事件,父类BaseAdapter中提供了isEnable的()方法,我们看看这个方法:
//默认情况,如果这个方法不是分割符,返回true //分隔符是无选中和无点击事件的 //说白了,你想不想把改position项当做分隔符,想的话就返回false,否则返回true public boolean isEnabled (int position)
这个方法刚好用来禁用标签项的响应事件。
@Override public boolean isEnabled(int position) { if (splitData.contains(listData.get(position))) { return false; } return super.isEnabled(position); }
现在标签项不会再有任何触控效果了,犹如一块死木板。
发表评论
-
带你深入理解 FLUTTER 中的字体“冷”知识
2020-08-10 23:40 634本篇将带你深入理解 Flutter 开发过程中关于字体和文 ... -
Flutter -自定义日历组件
2020-03-01 17:56 1110颜色文件和屏幕适配的文件 可以自己给定 import ... -
Dart高级(一)——泛型与Json To Bean
2020-02-23 19:13 1004从 Flutter 发布到现在, 越来越多人开始尝试使用 Da ... -
flutter loading、Progress进度条
2020-02-21 17:03 1180Flutter Progress 1 条形无固定值进度条 ... -
Flutter使用Https加载图片
2020-02-21 01:39 1019Flutter使用Https加载图片 使用http加载图片出 ... -
flutter shared_preferences 异步变同步
2020-02-21 00:55 847前言 引用 在开发原生iOS或Native应用时,一般有判断上 ... -
Flutter TextField边框颜色
2020-02-19 21:31 936监听要销毁 myController.dispose(); T ... -
flutter Future的正确用法
2020-02-18 21:55 807在flutter中经常会用到异步任务,dart中异步任务异步处 ... -
记一次Flutter简单粗暴处理HTTPS证书检验方法
2020-02-18 14:13 978最近在做Flutter项目到了遇到一个无解的事情,当使用Ima ... -
flutter 获取屏幕宽度高度 通知栏高度等屏幕信息
2019-07-27 08:39 1343##MediaQuery MediaQuery.of(con ... -
关于flutter RefreshIndicator扩展listview下拉刷新的问题
2019-07-10 19:40 1140当条目过少时listview某些嵌套情况下可能不会滚动(条目 ... -
flutter listview 改变状态的时候一直无限添加
2019-07-10 16:01 789setstate的时候会一直无限的调用listview.bui ... -
Flutter Android端启动白屏问题的解决
2019-07-09 00:51 1522问题描述 Flutter 应用在 Android 端上启动时 ... -
Flutter中SnackBar使用
2019-07-08 23:43 780底部弹出,然后在指定时间后消失。 注意: build(Bui ... -
Flutter 之点击空白区域收起键盘
2019-07-08 18:43 1791点击空白处取消TextField焦点这个需求是非常简单的,在学 ... -
Flutter 弹窗 Dialog ,AlertDialog,IOS风格
2019-07-08 18:04 1382import 'package:flutter/mate ... -
flutter ---TextField 之 输入类型、长度限制
2019-07-08 14:30 2336TextField想要实现输入类型、长度限制需要先引入impo ... -
【flutter 溢出BUG】键盘上显示bottom overflowed by 104 PIXELS
2019-07-08 11:13 1566一开始直接使用Scaffold布局,body:new Colu ... -
解决Flutter项目卡在Initializing gradle...界面的问题
2019-07-07 12:53 879Flutter最近很火,我抽出了一点时间对Flutter进行了 ... -
关于android O 上 NotificationChannel 的一些注意事项
2019-07-04 11:47 940最近在适配android O,遇到个问题,应用中原本有设置界面 ...
相关推荐
android关于listview之列表分组,像Q上一样显示列表项
总结来说,实现Android的分组ListView并支持折叠功能,需要自定义数据结构和Adapter,处理好分组头和子项的视图类型,监听用户点击事件来切换分组状态,最后在Adapter中根据分组状态动态显示或隐藏子项。这个过程...
本文将详细介绍如何在Android中实现分组ListView,以实现类似于Android通讯录中按字母分组的效果。 首先,我们需要创建样本数据来模拟实际应用中的数据结构。在本例中,我们使用两个列表:`list` 存储所有数据项,...
在标题“android listview分组滑动悬浮”中,提到的功能是ListView的一种高级用法,即实现分组列表并且在滑动过程中对隐藏的分组显示悬浮条。这种设计可以提高用户体验,使用户能够快速定位到特定的分组。 首先,...
分组ListView通常指的是具有层次结构的数据展示方式,每个组包含一个或多个子项。在Android中,我们可以使用`ExpandableListView`来实现这个功能,它不仅支持分组,还支持展开和折叠子项。不过,对于不需要展开和...
5. **数据结构设计**:分组ListView的数据结构通常是一个嵌套的数据模型,例如一个包含多个Group对象的列表,每个Group对象又包含一个Child对象的列表。这样的设计便于我们处理组与子项的关系。 **总结** 分组...
在Android开发中,ListView是一种常用的组件,用于展示可滚动的列表数据。然而,有时我们不仅需要简单的列表,而是需要分组显示数据,这就涉及到自定义ListView。本篇将详细讲解如何在Android中实现一个自定义的...
在分组ListView中,我们需要定义两个数据模型:Group和Child。Group代表一个父项,Child代表父项下的子项。通常,我们使用ArrayList来存储Group对象,每个Group对象内部再用一个ArrayList来存储对应的Child对象。 ...
在Android开发中,ListView是一种常用的组件,用于展示大量的列表数据。在某些应用场景中,比如日程管理、消息通知等,我们可能需要将这些数据按照时间或日期进行分组,以便用户能更清晰地查看和理解信息。本示例...
本篇文章将详细讲解如何在Android中实现“Android仿ios圆角分组listView”这一技术。 首先,我们需要理解iOS中的圆角分组ListView通常指的是具有半圆形或矩形角的列表项,且每个列表项之间有明显的分隔线,形成一种...
总结一下,实现"Android ListView城市列表,按a-z分组字母索引排序"的关键步骤包括: 1. 数据预处理:排序和分组城市名。 2. 创建适配器:处理数据并绑定到ListView。 3. 实现分组头部:根据首字母创建SectionHeader...
在Android应用开发中,ListView是显示大量数据列表的常用组件,它允许用户滚动查看条目,具有很高的可定制性。本篇文章将深入解析ListView的源码,帮助开发者更好地理解和运用这个核心组件。 首先,ListView继承自...
在Android开发中,ListView是一种非常常见的控件,用于展示大量数据列表。它的高效性和可滚动性使其成为数据呈现的理想选择。然而,随着用户需求的多样化,单纯的单列数据展示已经不能满足所有场景,因此,"分组显示...
在Android开发中,ListView是一种常用的组件,用于展示大量的列表数据。`Android-SlideListView(ListView侧滑实现)`项目是针对ListView进行的一种扩展,它引入了侧滑手势来实现更多的交互功能,如滑动删除和滑动展开...
在Android开发中,ListView是一种常用的组件,用于展示可滚动的列表数据。然而,标准的ListView在处理大量数据或需要分组显示时可能会显得不够灵活。为了解决这个问题,开发者可以实现一个可以分段的ListView,这...
8. **分组ListView**:如果数据需要按类别分组,可以使用ExpandableListView。每个父项可以展开显示子项,提供更丰富的交互体验。 9. **异步加载**:对于大量图片的列表,使用像Glide或Picasso这样的库进行异步加载...
在Android开发中,ListView是一个非常重要的组件,它用于展示大量数据列表,通常用于实现滚动效果。这个简单的ListView用法例子将帮助初学者理解和掌握如何在实际项目中运用ListView。 首先,我们来了解一下...