C# WinForm —— 27 28 29 30 ListView 介绍与应用

1. 简介

和ListBox的外观类似,都可以多列显示,但 ListView 功能更强大,提供了5种不同的显示方式

2. 属性

属性解释
(Name)控件ID,在代码里引用的时候会用到
Enabled控件是否启用
CheckBoxes复选框是否显示在项旁边
ContextMenuStrip当用户右键该控件时显示的快捷菜单
Dock定义要绑定到容器的控件边框
ItemsListView中的项的集合
AlignmentListView中各项的对齐方式:Default、Left、Top(默认)、SnapToGrid
View显示项的5种不同视图:
LargeIcon:大图标,添加项的时候,默认是多列显示的
SmallIcon:小图标
Details:详细信息
List:列表
Tile:
Columns“详细信息” 视图中显示的列
在这里插入图片描述
AllowColumnReorder是否允许用户重新排列 ”详细信息“视图中各列的顺序
FullRowSelect当项被选中时,其所有子项是否同该项一起突出显示
GridLines在项和子项周围显示网格线。仅在”详细信息“视图中显示
HeaderStyle”详细信息“视图中列标头的样式:Clickable、NonClickable、None
AutoArrange在 大图标 和小图标 视图中,项是否自动进行排列,默认true
LargeImageList大图标、Tile视图中,用于显示的大图标图像集合(ImageList)
SmallImageList除大图标、Tile视图外所有视图中,用于显示的图标图像集合(ImageList)
GroupsListView中的组,集合
LabelEdit是否允许用户就地编辑项标签
labelWrap确定标签文本是否可以换到新行
MultiSelect是否允许选择多项
Scrollable如果控件包含的项过多,超出工作区的范围时,该控件是否显示滚动条
ShowGroups指示控件是否以组的形式显示项
ShowItemToolTips允许ListViewItems显示工具提示
Sorting对项进行排序的方式:None、Ascending、Descending
StateImageListListView为自定义状态所使用的ImageList控件
CheckedIndices所有勾选了复选框的项的索引集合
CheckedItems所有勾选了复选框的项的集合
SelectedIndices所有选中的项的索引集合
SelectedIndex所选中的单个项的索引
SelectedItems所有选定的项

3. 方法

方法解释
BeginUpdate()和 EndUpdate()在大量通过Items方法加载项的时候,在加载项的语句前后分别加上 BeginUpdate() 和 EndUpdate() 语句,可以避免控件出现闪烁
Clear()清空项
EnsureVisible确保指定项在控件中是可见的,必要时滚动控件内容
FindItemWithText找到第一个指定文本开头的项
FindNearestItem按照指定的搜索方向,从指定点开始查找下一个项

4. 事件

事件解释
SelectedIndexChanged每当此ListView的 ”SelectedIndex“属性更改时发生
ColumnClick在单击列标头时发生
AfterLabelEdit在用户已编辑项文本时发生
BeforeLabelEdit在用户将要编辑项文本时发生
ItemCheck指示某项的选中状态将要更改,直到事件发生后,该值才会更新
ItemChecked当ListView项的Checked属性更改时引发的事件
ItemSelectionChanged当某项的选定状态更改时引发的事件

5. 列的集合的操作

操作方法
访问列从集合中获取具有指定键值 / 索引值的列标题
在这里插入图片描述
添加列Add方法,可以指定键名,列名,宽度,对齐方式,图标索引
列的数量Count方法
设置列只读IsReadOnly方法
添加单列Add(ColumnHeader value)
添加多列AddRange(ColumnHeader[] values)
清空所有列Clear()
判断列是否存在Contains(ColumnHeader value)
ContainsKey(string key)
获取列的索引IndexOf(ColumnHeader value)
IndexOfKey(string key)
插入列Insert
移除列Remove(ColumnHeader column)
RemoveAt(int index)
RemoveByKey(string key)

在这里插入图片描述

6. 项的集合的操作

操作方法
访问项从集合中获取具有指定键值 / 索引值的项
设置项只读IsReadOnly
项的数量Count
添加项Add方法,可以指定键名,文本,图标索引/图标键值
添加项的集合AddRange方法
清除项Clear方法
判断项是否存在Contains(ListViewItem item)
ContainsKey(string key)
复制项CopyTo(Array dest, int index)
查找项Find(string key, bool searchAllSubItems)
获取项的索引IndexOf(ListViewItem item)
IndexOfKey(string key)
插入项Insert,可以设置输入项的索引、键值、文本、图像索引/图像键值
移除项Remove(ListViewItem item)
RemoveAt(int index)
RemoveByKey(string key)

7. 组的集合的操作

操作方法
访问组通过指定键值 / 索引值访问
组的数量Count
添加组Add, AddRange
清除组Clear
判断组是否存在Contains(ListViewGroup value)
复制组CopyTo(Array array, int index)
获取组的索引IndexOf(ListViewGroup value)
插入组Insert
移除组Remove(ListViewGroup group)
RemoveAt(int index)

在这里插入图片描述

8. 不同的视图

  1. 拖控件
    在这里插入图片描述
    在这里插入图片描述
  2. 加载图像到 ImageList 组件
private void FrmListView2_Load(object sender, EventArgs e)
{
	// 加载 Form 的时候,默认显示 大图标
	LoadImgList(); //加载图片
	lvList.Items.Clear();
	lvList.ShowGroups = false; // 不分组显示
	if (largeList != null && largeList.Images.Count > 0)
	{
		for (int i=0; i<lareList.Images.Count; i++) // 对于 lareList 中的每张图
		{
			string iText = largeList.Images.Keys[i];  // 图的名字
			// 添加ListView控件中的项
			ListViewItem li = new ListViewItem();
			li.Text = iText;
			li.ImageIndex = i;
			LvList.Items.Add(li);
		}
	}
	lvList.View = View.LargeIcon; // 指定 大图标显示
	lvList.largeImageList = largeList; // 大图标、Tile视图 使用的ImageList
	lvList.SmallImageList = smallList; // 除大图标、Tile视图以外,所有视图使用的ImageList
}

Dictionary<int, string> dic = new Dictionary<int, string>;

private void LoadImgList() // 加载图片集合
{
	string path = @"D:\课件\录制课件\WF\WFFormUse\WFFormUse\Imgs";
	if (Directory.Exists(path))
	{
		string[] files = Directory.GetFiles(path);
		if (files.Length > 0)
		{
			largeList.Images.Clear();
			smallList.Images.Clear();
			int index = 0;
			string[] fileType = {".jpg", ".png"};
			foreach (string fpath in files)
			{
				if (fileType.Contains(Path.GetExtension(fpath)))
				{
					Image img = Image.FromFile(fpath);
					string key = Path.GetFileNameWithoutExtension(fpath);
					largeList.Images.Add(key, img);
					smallList.Images.Add(key, img);
					dic.Add(index, fpath);
					index++;
				}
			}
			// 指定图片尺寸
			largeList.ImageSize = new Size(50, 50);
			smallList.ImageSize = new Size(20, 20);
		}
	}
}
  1. 运行
    大图标的样式:最大化图标,下面显示文本标签
    在这里插入图片描述

  2. 点击 “大图标”按钮,以大图标的样式显示

在这里插入图片描述

  1. 点击 “小图标”按钮,以小图标的样式显示

在这里插入图片描述
小图标的样式:小图标,右边显示文本标签
在这里插入图片描述

  1. 点击 “List”按钮,以列表的样式显示:小图标,右边显示文本标签,各项排列在列中,没有列标头
    在这里插入图片描述

在这里插入图片描述

  1. 点击 "Tile”按钮,以 Tile 的样式显示:大图标, 关联的是largeList,右边显示文本标签,如果还有其他SubItems信息,也显示在右边
    在这里插入图片描述
    在这里插入图片描述
  2. “详细信息”视图:分列显示,第一列显示小图标,右边显示文本,其他列只显示文本,有列标头
private void btnDetails_Click(object sender, EventArgs e)
{
	lvList.Items.Clear();
	lvList.Column.Clear();
	lvList.ShowGroups = false;
	lvList.View = View.Details; 
	// 列的添加
	lvList.Columns.Add("文件名", 100, HorizontalAlignment.Left); // 设置列名,列宽,对齐方式
	lvList.Columns.Add("修改日期", 150, HorizontalAlignment.Left);
	lvList.Columns.Add("类型", 80, HorizontalAlignment.Left);
	lvList.Columns.Add("大小", 60, HorizontalAlignment.Left);
	// 项
	for (int i = 0; i < dic.Count; i++)
	{
		ListViewItem li = new ListViewItem();
		li.ImageIndex = i;
		li.Text = smallList.Images.Keys[i]; // 文件名
		li.SubItems.Add(File.getCreationTime(dic[i]).ToString()); // 修改日期
		li.SubItems.Add(Path.getExtension(dic[i])); // 类型
		long length = new FileInfo(dic[i]).Length; // 获取文件大小,以字节为单位
		li.SubItems.Add((length/1024).ToString()); // 文件大小, kb为单位
		lvList.Items.Add(li);
	}
	lvList.GridLines = true; // 显示网格
}

在这里插入图片描述
再点击“Tile”按钮时:
在这里插入图片描述

  1. 分组功能
    在这里插入图片描述
private void btnGroup_Click(object sender, EventArgs e)
{
	lvList.ShowGroups = true;
	//添加组
	lvList.Groups.Clear();
	lvList.Groups.Add(new ListViewGroup("花", HorizontalAlignment.Center));
	lvList.Groups.Add(new ListViewGroup("动物", HorizontalAlignment.Center));
	lvList.Groups.Add(new ListViewGroup("人物", HorizontalAlignment.Center));
	lvList.Groups.Add(new ListViewGroup("风景", HorizontalAlignment.Center));
	// 组名--图片名称中包含了分组信息
	Dictionary<string, string> dicGroup = new Dictionary<string, string>();
	dicGroup.Add("花", "04");
	dicGroup.Add("动物", "01");
	dicGroup.Add("人物", "02");
	dicGroup.Add("风景", "03");
	// 分组
	for (int i = 0; i < lvList.Items.Count; i++)
	{
		foreach(ListViewGroup lvg in lvList.Groups)
		{
			// 判断项文本的前两个字符是否与组所对应的编号一致,如果一致,就将该项分到这一组
			if (lvList.Items[i].Text.Substring(0,2) == dicGroup[lvg.Header])
			{
				lvList.Items[i].Group = lvg; // 设置项所属的组
				break;
			}
		}
	}
}

运行,点击 “分组显示” 按钮,大图标视图:
在这里插入图片描述
小图标视图:
在这里插入图片描述
List视图 不支持分组显示
在这里插入图片描述
先点 “分组显示” ,再点 “详细信息”,因为点击 “详细信息”的时候,清空了ListView控件中的信息后重新添加项和列的,所以没有分组信息:
在这里插入图片描述
先点 “详细信息”,再点 “分组显示”:
在这里插入图片描述
Tile视图:
在这里插入图片描述

参考:2023年C#之WinForm零基础教程50讲

  • 27
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值