WinForms零基础进阶控件教程(超实用详细版)

文章目录

  • 树型控件TreeView
    • 常用属性
    • 常用事件
    • 添加、删除树节点
    • 通过代码添加树节点
    • 通过代码删除树节点:
    • 管理节点图标
    • 响应事件,获取选中节点
  • 列表视图ListView
    • 常用属性
    • 常用事件
    • 添加、删除项
    • 使用ListViewItem集合编辑器添加,删除项:
    • 通过代码添加 / 删除项
    • 响应事件,获取选中项目内容。
    • 结合右键实现删除以及视图切换
      • 删除菜单响应代码:
      • 各种视图菜单响应代码:
  • 数据显示DataGridView
    • 绑定数据到控件
    • 根据内容自动调整控件size
    • AutoSizeColumnsMode属性
  • 音乐播放控件MediaPlayer
    • Winform添加打开MediaPlayer控件:
    • 常用属性及方法
  • 总结

在上一篇博客中,我们介绍了WinForms基础控件的使用。今天,我们将深入探讨更高级的控件,包括树型控件(TreeView)、列表视图(ListView)和数据显示控件(DataGridView),以及音乐播放控件(MediaPlayer)。我们将通过实际代码示例,帮助大家更好地理解和应用这些控件。

树型控件TreeView

TreeView控件用于显示具有层次结构的数据。它由层叠的节点(Node)分支构成,每个节点由图像标签组成。节点可以展开或折叠,显示其子节点。

常用属性

  • Name: 获取或设置控件的名称。
  • Dock: 控件在父容器中的停靠方式。
  • Nodes: TreeView控件根节点集合。
  • SelectedNode: 获取或设置当前TreeView控件中选定的树节点。
  • ImageList: 获取或设置TreeView中所使用的图像集。

常用事件

  • AfterCollapse: 在折叠树节点后触发。
  • AfterExpand: 在展开树节点后触发。
  • AfterSelect: 在更改选中节点后触发。
  • Click: 在点击TreeView控件时触发。

添加、删除树节点

我们可以通过两种方式添加、删除树节点:

  1. TreeNode编辑器中添加、删除树节点。

在这里插入图片描述
2. 通过代码添加、删除树节点。

通过代码添加树节点

窗体添加Load事件,在事件处理函数中编码添加树节点

private void Form_Load(object sender, EventArgs e)
{//方案一:使用TreeNode对象进行添加节点// 创建根节点TreeNode root = new TreeNode("北京**********学院");// 将根节点添加至TreeView控件上this.tvSchool.Nodes.Add(root);// 创建专业节点TreeNode tnPro1 = new TreeNode("电子与电气");TreeNode tnPro2 = new TreeNode("电子商务");// 将专业节点添加至根节点root.Nodes.Add(tnPro1);root.Nodes.Add(tnPro2);// 创建课程节点TreeNode tnCourse1 = new TreeNode("C#");TreeNode tnCourse2 = new TreeNode("SQL SERVER");// 将课程节点添加至专业节点tnPro1.Nodes.Add(tnCourse1);tnPro1.Nodes.Add(tnCourse2);// 展开TreeView的所有节点this.tvSchool.ExpandAll();
//方案二:使用键值对的方式进行添加节点
private void TreeViewForm1_Load(object sender, EventArgs e)
{this.tvSchool.Nodes.Add("001", "北京**********学院");this.tvSchool.Nodes["001"].Nodes.Add("001001", "电子与电气");this.tvSchool.Nodes["001"].Nodes.Add("001002", "电子商务");this.tvSchool.Nodes["001"].Nodes["001001"].Nodes.Add("001001001","C#");this.tvSchool.Nodes["001"].Nodes["001001"].Nodes.Add("001001002", "SQL SERVER");this.tvSchool.Nodes["001"].Nodes["001002"].Nodes.Add("001002001", "搜索引擎优化");this.tvSchool.Nodes["001"].Nodes["001002"].Nodes.Add("001002002", "网络营销推广");this.tvSchool.ExpandAll();
}

通过代码删除树节点:

例如在上面添加的节点中删除"搜索引擎优化"节点

//通过节点对象删除
this.tvSchool.Nodes.Remove(tnCourse3);
//通过索引下标删除
this.tvSchool.Nodes[0].Nodes[1].Nodes.RemoveAt(0);
//通过键删除节点
this.tvSchool.Nodes["001"].Nodes["001002"].Nodes.RemoveByKey("001002001");

管理节点图标

为了在TreeView的节点中使用图标,我们需要借助ImageList控件。首先向窗体中添加ImageList控件,并向其中添加需要的图片。然后将ImageList控件与TreeView控件进行关联
给节点设置图标有两种情况:

  1. 所有节点图标都一样

此时直接在属性栏中或者通过代码找到TreeView控件,设置ImageIndex属性(未选中的展示图片索引)和SelectedImageIndex属性(选中情况下的图片索引)。
在这里插入图片描述

  1. 节点的图标不一致
  • 通过编辑器添加的节点,直接在编辑中为每个节点设置ImageIndex属性和SelectedImageIndex属性。
    在这里插入图片描述

  • 通过代码,使用TreeNode对象添加的节点,在代码中为每个TreeNode设置ImageIndex属性和SelectedImageIndex属性。下面代码只为一个节点添加了图标,其他节点省略。

//方案一:
TreeNode root = new TreeNode("北京**********学院",0,1);
//方案二:
TreeNode root = new TreeNode("北京**********学院");
root.ImageIndex = 0;
root.SelectedImageIndex = 1;

  • 通过代码,使用键值对的方式添加的节点,在代码中为每个TreeNode设置ImageIndex属性和SelectedImageIndex属性。下面代码只为一个节点添加了图标,其他节点省略。
//方案一:
this.tvSchool.Nodes.Add("001", "北京**********学院",0,1);
//方案二:
this.tvSchool.Nodes.Add("001", "北京**********学院");
this.tvSchool.Nodes["001"].ImageIndex = 0;
this.tvSchool.Nodes["001"].SelectedImageIndex = 1;

响应事件,获取选中节点

为TreeView控件添加AfterSelect事件,节点被选中后触发,在事件处理函数中,获取选中节点,并提示其标签文本值和key。

TreeNode selectedNode = this.tvSchool.SelectedNode;
//如果在添加节点的时候,并不是以键值对的方式添加的或者没有设置Name值,那么selectedNode.Name里面是空字符串
MessageBox.Show(selectedNode.Text + "," + selectedNode.Name);

在这里插入图片描述
注意,运行时窗体会先弹出目前所选(或上次停留的节点),点击弹窗的按键后,窗体会“消失”,但实际上未关闭,点击下方任务栏中窗体的图标,即可选择其他节点展示。

列表视图ListView

ListView控件可以展示多项数据,每一项均为ListViewItem对象,每个ListViewItem对象中包含SubItems属性表示该项中所有子项的集合。

常用属性

属性说明
Name控件的名称
Dock控件在父容器中的停靠方式
Items包含控件中所有项的集合
Columns控件中显示的所有列标题的集合
View控件的显示视图
LargeImageList当控件以大图标视图显示时使用的ImageList
SmallImageList当控件以小图标视图显示时使用的ImageList
GridLines在包含控件中的行和列之间是否显示网格线
MultiSelect是否可以选择多项
SelectedItems获取在控件选定的项
FullRowSelect单击某项是否选择其所有子项

常用事件

  • Click: 在单击ListView控件时触发。
  • SelectedIndexChanged: 当选定项发生更改时触发。

添加、删除项

我们可以通过两种方式添加、删除项:

  1. 使用ListView编辑器添加、删除项。

  2. 使用代码为ListView添加、删除项。

ListView控件具有5种显示视图,由View属性设置,View属性的值及说明见下表:

属性值说明
Details详细视图,标准的二维表格,第一行为表头
LargeIcon(默认值)大图标,每一项显示为一个大图标
SmallIcon小图标,每一项显示为一个小图标
List列表,每项显示一行
Tile平铺,显示大图标,并在右侧显示详细信息

使用ListViewItem集合编辑器添加,删除项:

实现步骤:

(1)创建窗体,并向其中拖入ListView控件

(2)设置ListView控件的Dock属性在父容器中停靠。

(3)向ListView控件中添加,删除列。

(4)设置ListView控件的显示视图为Detail,此时可以看到列标题
注意:编辑列之后 Details 视图才能正常显示

(5)向ListView控件中添加,删除项(点击右上角三角,编辑项)

(6)添加ListViewItem项目,在text属性中设置第一列内容,在SubItems里面设置其他列内容。

注意:如果该项数据有图片,需要拖入两个ImageList控件,分别存储大图标和小图标的图片。

在这里插入图片描述

  • 点击ListView控件右上角三角,使用LargeImageList\SmallImageList属性将ListView控件与两个ImageList控件关联。
  • 然后直接在该项ListViewItem上设置ImageIndex属性设置图片的索引。

特别注意:如果ListView与ImageList关联,ListView的Detail视图中的行高会随着小图标视图的ImageList的图像高度而改变。而且取消与ImageList的关联后也无法还原,此时可以通过设置ImageList的图像大小来控制行高。

通过代码添加 / 删除项

private void Form_Load(object sender, EventArgs e)
{// 创建ListViewItem对象,设置text值(第一列的值)ListViewItem item1 = new ListViewItem("安琪拉");item1.Name = "itemAjl"; // 设置当前项的名字item1.ImageIndex = 0;  // 设置图标索引// 设置除第一列外其他列数据item1.SubItems.Add("超弱");item1.SubItems.Add("中等");item1.SubItems.Add("超强");item1.SubItems.Add("难");this.lvTimi.Items.Add(item1);// 下面同理,添加其他项// ......
}
//直接通过ListViewItem对象名删除
this.lvTimi.Items.Remove(item1);
//通过索引小标删除
this.lvTimi.Items.RemoveAt(0);
//通过键值对中的键删除,此处的键就是ListViewItem对象的name
this.lvTimi.Items.RemoveByKey("itemAjl");

响应事件,获取选中项目内容。

设置FullRowSelect属性为true,保证单击某项整行选中效果,选择ListView控件的DoubleClick(双击)事件,编写如下代码:

ListViewItem item = this.lvTimi.SelectedItems[0];
if (item == null)return;
string result = "";
result += "名字:" + item.Text + "\n";
result += "生存能力:" + item.SubItems[1].Text +"\n";
result += "攻击伤害:" + item.SubItems[2].Text + "\n";
result += "技能效果:" + item.SubItems[3].Text + "\n";
result += "上手难度:" + item.SubItems[4].Text + "\n";
MessageBox.Show(result);

结合右键实现删除以及视图切换

拖入ConTextMenuStrip控件,制作如下菜单,并设置ListView控件的ContextMenuStrip属性用来关联ListView控件和ContextMenuStrip控件:
在这里插入图片描述

删除菜单响应代码:

private void 删除ToolStripMenuItem_Click(object sender, EventArgs e)
{if (this.lvTimi.SelectedItems.Count == 0){MessageBox.Show("您没有选中项目!");return;}ListViewItem item = this.lvTimi.SelectedItems[0];this.lvTimi.Items.Remove(item);
}

各种视图菜单响应代码:

private void 大图标ToolStripMenuItem_Click(object sender, EventArgs e)
{this.lvTimi.View = View.LargeIcon;
}private void 小图标ToolStripMenuItem_Click(object sender, EventArgs e)
{this.lvTimi.View = View.SmallIcon;
}private void 详细ToolStripMenuItem_Click(object sender, EventArgs e)
{this.lvTimi.View = View.Details;
}private void 列表ToolStripMenuItem_Click(object sender, EventArgs e)
{this.lvTimi.View = View.List;
}private void 平铺ToolStripMenuItem_Click(object sender, EventArgs e)
{this.lvTimi.View = View.Tile;
}

数据显示DataGridView

DataGridView控件是一个强大的数据显示和用户输入控件。它允许用户编辑、更新和排序数据。

属性说明
DataSource要显示的数据集 (源)
ValueMember绑定处理程序标识,给程序员看的
DisplayMember绑定显示的数据,一般是显示给客户看的

绑定数据到控件

DataTable dataTable = new DataTable();
this.dataGridView1.DataSource = dataTable;

根据内容自动调整控件size

private void AutoSizeTable()
{int height = dataGridView1.Height;int width = 0;foreach (DataGridViewColumn col in dataGridView1.Columns){width += col.Width;}width += dataGridView1.RowHeadersWidth;width = (width > 650) ? 650 : width;dataGridView1.ClientSize = new Size(width + 2, height + 2);
}

在这里插入图片描述

AutoSizeColumnsMode属性

更改datagridview的column的AutoSizeMode

成员名称说明
None列宽不会自动调整
AllCells调整列宽,以适合该列中的所有单元格的内容,包括标题单元格
AllCellsExceptHeader调整列宽,以适合该列中的所有单元格的内容,不包括标题单元格
ColumnHeader调整列宽,以适合列标题单元格的内容
DisplayedCells调整列宽,以适合当前屏幕上显示的行的列中的所有单元格的内容,包括标题单元格
DisplayedCellsExceptHeader调整列宽,以适合当前屏幕上显示的行的列中的所有单元格的内容,不包括标题单元格
Fill调整列宽,使所有列的宽度正好填充控件的显示区域,只需要水平滚动保证列宽在MinimumWidth 属性值以上。相对列宽由相对 FillWeight 属性值决定

音乐播放控件MediaPlayer

MediaPlayer控件可以用于播放音频和视频文件。

Winform添加打开MediaPlayer控件:

  1. 工具箱,右键单击选择项点击顶部的Com组件
  2. 向下拉勾选Windows Media Player
    在这里插入图片描述

常用属性及方法

  • music.URL: 设置播放文件的路径。
  • music.Ctlcontrols.currentPosition: 获取播放的当前位置。
  • music.Ctlcontrols.Play: 播放。
  • music.Ctlcontrols.Stop: 停止播放。
  • music.Ctlcontrols.Pause: 暂停播放。
  • music.settings.volume: 设置音量。
  • axWindowsMediaPlayer1.settings.rate: 播放速率。

注意: 该控件的URL必须是绝对路径。


在这里插入图片描述

总结

以上就是本次WinForms零基础进阶教程的全部内容。希望能帮助大家更好地掌握这些控件的使用。在实际开发中,这些控件非常强大,可以构建出功能丰富的桌面应用程序。如果有任何问题,欢迎在评论区留言讨论!

如果觉得文章还不错,可以点赞、收藏和转发,以支持作者继续创作更多教程。 另外本专栏将会持续更新,作者专栏中有已经更新完毕的C#基础教程!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/813023.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LED显示IC-点阵数码管显示驱动/抗干扰数码管驱动VK1650 SOP16/DIP16

产品品牌:永嘉微电/VINKA 产品型号:VK1650 封装形式:SOP16/DIP16 概述 VK1650是一种带键盘扫描电路接口的 LED 驱动控制专用芯片,内部集成有数据锁存器、LED 驱动、键盘扫描等电路。SEG脚接LED阳极,GRID脚接LED阴极&…

WebGL 2.0相较于1.0有什么不同?

作者:STANCH 1.概述 WebGL 1.0自推出以来,已成为广泛支持的Web标准,既能跨平台,还免版税。它通过插件为Web浏览器带来高质量的3D图形,这是迄今为止市场上使用最广泛的Web图形,并得到Apple,Goog…

ControllerAdvice用法

ControllerAdvice用法 ControllerAdvice是一个组件注解,它允许你在一个地方处理整个应用程序控制器的异常、绑定数据和预处理请求。这意味着你不需要在每个控制器中重复相同的异常处理代码,从而使得代码更加简洁、易于管理。 主要特性 全局异常处理&a…

【vue】v-model.lazy等(非实时渲染)

v-model&#xff1a;实时渲染v-model.lazy&#xff1a;失去焦点/按回车后&#xff0c;才渲染v-model.number&#xff1a;值转换为数字v-model.trim&#xff1a;去除首尾空格 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8&qu…

MDK平台 - Code, RO-data , RW-data, ZI-data详解

文章目录 1 . 前言2 . Code, RO-data , RW-data, ZI-data解析3 . RAM上电复位4 . 细节扩展5 . 总结 【全文大纲】 : https://blog.csdn.net/Engineer_LU/article/details/135149485 1 . 前言 MDK编译后&#xff0c;会列出Code, RO-data , RW-data, ZI-data&#xff0c;以下解析…

股票价格预测 | Python使用LSTM预测股票价格

文章目录 效果一览文章概述代码设计效果一览 文章概述 Python使用LSTM预测股票价格 代码设计 import pandas as pd import matplotlib.pyplot as plt import numpy as np import tensorflowfrom numpy import

2024年蓝牙耳机哪个品牌最好?五大热门机型PK,新手必看!

​随着生活节奏的加快&#xff0c;蓝牙耳机已经成为了我们日常生活中不可或缺的伙伴。它不仅让我们的听音乐、观看视频和通话变得更加便捷&#xff0c;还带来了无线的自由体验。面对市场上众多的选择&#xff0c;我为你精挑细选了几款表现优异的蓝牙耳机&#xff0c;希望能帮助…

mybiats-puls-插入测试以及雪花算法

一&#xff0c;测试 /* * 插入测试 * */ Test public void test01() {User user new User();/** 自动帮我们生成id* */user.setName("kuku");user.setAge(3);user.setEmail("2983394967qq.com");final int insert mapper.insert(user);System.out.print…

Redis从入门到精通(十六)多级缓存(一)Caffeine、JVM进程缓存

文章目录 第6章 多级缓存6.1 什么是多级缓存&#xff1f;6.2 搭建测试项目6.2.1 项目介绍6.2.2 新增商品表6.2.3 编写商品相关代码6.2.4 启动服务并测试6.2.5 导入商品查询页面&#xff0c;配置反向代理 6.3 JVM进程缓存6.3.1 Caffeine6.3.2 实现JVM进程缓存6.3.2.1 需求分析6.…

基于springboot仿雀语的文档管理系统

项目介绍 本项目借鉴了雀语的一些UI设计&#xff0c;实现了文档在线管理的功能&#xff0c;知识库可以对不同分类的文档建立不同的库&#xff0c;知识库里面左边可以维护菜单菜单目录&#xff0c;右边实现在线预览。该项目可以防止用户下载和复制文档&#xff0c;只支持在线预…

TSINGSEE青犀AI智能分析网关V4吸烟/抽烟检测算法介绍及应用

抽烟检测AI算法是一种基于计算机视觉和深度学习技术的先进工具&#xff0c;旨在准确识别并监测个体是否抽烟。该算法通过训练大量图像数据&#xff0c;使模型能够识别出抽烟行为的关键特征&#xff0c;如烟雾、手部动作和口部形态等。 在原理上&#xff0c;抽烟检测AI算法主要…

Java 语言程序设计(基础篇)原书第10版 梁勇著 PDF 文字版电子书

简介 Java 语言程序设计&#xff08;基础篇&#xff09;原书第 10 版 是 Java 语言的经典教材&#xff0c;中文版分为基础篇和进阶篇&#xff0c;主要介绍程序设计基础、面向对象程序设计、GUI 程序设计、数据结构和算法、高级 Java 程序设计等内容。本书通过示例讲解问题求解…

蓝桥杯嵌入式(G431)备赛——最后一晚查漏补缺

蓝桥杯嵌入式&#xff08;G431&#xff09;备赛笔记——初始化cubeMX 蓝桥杯嵌入式&#xff08;G431&#xff09;备赛笔记——LED 蓝桥杯嵌入式&#xff08;G431&#xff09;备赛笔记——按键模块设计 蓝桥杯嵌入式&#xff08;G431&#xff09;备赛笔记——LCD按键 蓝桥杯…

杂货铺 | Linux虚拟机Ubuntu操作系统下设置共享文件夹(以及找不到hgfs文件夹怎么办)

文章目录 &#x1f4da;步骤一&#xff1a;配置共享文件夹&#x1f4da;步骤二&#xff1a;配置挂载环境&#x1f4da;步骤三&#xff1a;解决权限问题&#x1f4da;步骤四&#xff1a;解决重启失效问题 &#x1f4da;步骤一&#xff1a;配置共享文件夹 建立本地共享文件夹&…

07.QT信号和槽-2

一、自定义信号和槽 在Qt中&#xff0c;允许⾃定义信号的发送⽅以及接收⽅&#xff0c;即可以⾃定义信号函数和槽函数。但是对于⾃定义的信号函数和槽函数有⼀定的书写规范。 1.基本语法 1.1 自定义信号 &#xff08;1&#xff09;⾃定义信号函数必须写到"signals"…

2024 DTC大会精彩演讲:DBdoctor,基于eBPF重新定义数据库可观测 (附PPT下载和演讲视频)

由中国DBA联盟&#xff08;ACDU&#xff09;和墨天轮社区联合主办的第十三届数据技术嘉年华&#xff08;DTC&#xff09;于北京盛大召开。4月13日上午海信聚好看云平台负责人张纪宽受邀在『数据库生态软件』分论坛发表主题演讲《DBdoctor&#xff1a;利用eBPF技术实现数据库智能…

微信小程序公共组件封装使用

1.在components目录下创建公共组件&#xff0c;以navbar为例 2.完成组件功能 3.调用&#xff0c;如果很多地方都会用到&#xff0c;建议放全局&#xff0c;如果不是则放在需要引用的文件中 3.1全局引用&#xff0c;在app.json做全局引用配置 3.2局部引用&#xff0c;在需要引入…

springcloud第4季 springcloud-alibaba之nacos篇

一 nacos 1.1 nacos作用介绍 nacos是一个分布式的配置中心和注册发现中心。 nacos是 dynamic naming configuration service nacosconfigbus 实现动态刷新&#xff1b;nacosconsul 1.2 各个注册中心对比 注册中心CAP模型控制台管理社区活跃度EureakaAp支持低zkcp不支持中…

初学python记录:力扣2923. 找到冠军 I

题目&#xff1a; 一场比赛中共有 n 支队伍&#xff0c;按从 0 到 n - 1 编号。 给你一个下标从 0 开始、大小为 n * n 的二维布尔矩阵 grid 。对于满足 0 < i, j < n - 1 且 i ! j 的所有 i, j &#xff1a;如果 grid[i][j] 1&#xff0c;那么 i 队比 j 队 强 &…

什么是队头阻塞以及如何解决

前言 通常我们提到队头阻塞&#xff0c;指的可能是TCP协议中的队头阻塞&#xff0c;但是HTTP1.1中也有一个类似TCP队头阻塞的问题&#xff0c;下面各自介绍一下。 TCP队头阻塞 队头阻塞&#xff08;head-of-line blocking&#xff09;发生在一个TCP分节丢失&#xff0c;导致…