网站首页 > 资源文章 正文
ListView是WinForm中的一个Windows 列表视图控件,可以通过5种不同的视图形式来动态显示数据的集合。ListView提供了很多基本属性和事件,通过定义属性和事件我们可以设计出符合我们需求的样式及功能。
?ListView的View视图属性
要想用好ListView控件我们需要先来了解下ListView的视图模式,ListView提供了五种视图显示模式,分别是:
LargeIcon:每项都显示一个最大化图标和一个标签(标签在图标的下方);
Details:需要有列表头(否则不显示内容),可以显示任意的列,但只有第一栏可以包含一个小图标和标签(标签在图标的右方),其它的列项可以显示文字信息或控件(显示控件可以通过重写ListView方法来实现);
SmallIcon:每个项都显示一个小图标和一个标签(标签在图标的右方);
List:跟SmallIcon差不多,每个项都显示一个小图标和一个标签(标签在图标的右方);各项排列在列中,没有列标头
Tile:每个项都显示一个完整大小的图标,右边显示一个标签和子项信息(仅Windows XP 和 Windows Server 2003 系统支持)。
我的Dome是要获取文件夹下载所有文件信息并将文件信息显示在ListView列表中,它每项需要显示多列数据显然只有Details视图适合我们。ListView默认视图为LargeIcon,我们只要选择控件在属性中找到view属性,选择Details即可。
?Details视图结构
在Details视图模式中,ListView为我们整个视图控件,跟Excel表格相似有列和行的概念。Columns定义ListView标题(不算入列表数据中,就是个列表头);items定义ListView显示的数据项,是Item的集合;Item定义到items中的每一行(通过实例化ListViewItem获取);SubItem则定位到了Item中的具体单元格。
?创建列表头
Details有个特点就是必须创建列表头不然就算你添加了数据也无法显示的,创建列表头我们可以通过ColumnHeader来实现,每显示一列就需要有一个列表头。如果通过ColumnHeader实例化添加比较麻烦的话可以使用下面这种方式添加比较简洁,如果列表较多的话可以用循环遍历实现。
列表项添加数据
向列表项中添加数据我们可以通过ListView中的item属性来添加,多行数据可以通过for或者foreach来遍历数据集。这里通过folderBrowserDialog控件来选择文件夹并拿到文件夹中的所有对象,通过foreach遍历对象判断对象是否文文件夹,如果是文件夹则获取文件夹名称如果是文件则获取文件名,最后通过Add方法将该信息添加到ListView中的item属性中。
向列表项中添加多列数据
上面我们将文件名写入了列表项中,但你会发现每行只有一条数据,在没有定义item时默认只有一条数据。如果我们一行需要写入多条数据该怎么操作呢,这时候我们可以通过ListViewItem来实例化item对象,再使用SubItems.Add()方法将当行内单元格的数据添加到item集合中,最后把item集合抛给items即可。当然你也可以通过指定items下标来对指定行追加每列数据,SubItems.Add()方法会依次向后添加一列数据(注意:该列必须定义列表头方能显示数据)。
列表绑定图标
首先使用imagelist控件先生成一个图片列表,右键imagelist控件->选择图像->添加,将你准备的图标(支持ico图标)添加进来。然后通过与imageList列表集合绑定来获取每项图标 ,选择的不同视图模式对应不同的绑定属性,Details、SmallIcon、List视图使用listView1.SmallImageList属性,LargeIcon、Tile视图使用listView1.LargeImageList属性,否则图标将无法正常显示。
? 绑定只需通过ListViewItem的ImageIndex属性指向imageList的下标即可,如果用foreach遍历我们需要自行添加一个变量来指定下标。
更多C#实战技巧可以参考专栏:C#实战系列
猜你喜欢
- 2024-12-10 一个监控PLC的Android应用的开发过程-2
- 2024-12-10 android学习,listview
- 2024-12-10 ListView和RecyclerView的区别
- 2024-12-10 轻松学会:滑动组件ListView和GridView的使用
- 2024-12-10 常见面试题之ListView的复用及如何优化
- 2024-12-10 那些技术—Listview的性能提高篇
- 2024-12-10 Excel VBA,通过ListView查阅工作表数据、外部数据源数据(1/5)
- 2024-12-10 Android中ListView的使用方法
- 2024-12-10 PC SDK二次开发:基于C#语言编写的ABB机器人控制器扫描程序
- 2024-12-10 Excel vba 如何导入导出工作表,数据管理方法介绍
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- 电脑显示器花屏 (79)
- 403 forbidden (65)
- linux怎么查看系统版本 (54)
- 补码运算 (63)
- 缓存服务器 (61)
- 定时重启 (59)
- plsql developer (73)
- 对话框打开时命令无法执行 (61)
- excel数据透视表 (72)
- oracle认证 (56)
- 网页不能复制 (84)
- photoshop外挂滤镜 (58)
- 网页无法复制粘贴 (55)
- vmware workstation 7 1 3 (78)
- jdk 64位下载 (65)
- phpstudy 2013 (66)
- 卡通形象生成 (55)
- psd模板免费下载 (67)
- shift (58)
- localhost打不开 (58)
- 检测代理服务器设置 (55)
- frequency (66)
- indesign教程 (55)
- 运行命令大全 (61)
- ping exe (64)
本文暂时没有评论,来添加一个吧(●'◡'●)