【WinForm详细教程一】WinForm中的窗体、Label、TextBox及Button控件、RadioButton和CheckBox、ListBox

news2025/1/10 23:55:28

文章目录

    • 1.WinForm文件结构
    • 2. 窗体的常用属性、方法与事件
      • 2.1 常用属性(可直接在属性中设置)
      • 2.2 常用方法
      • 2.3 常用事件
    • 3.Label、TextBox及Button控件
    • 4.RadioButton和CheckBox
    • 5.ListBox(列表框)

1.WinForm文件结构

.sln文件 :解决方案文件 位置引用
bin文件夹: 存放项目的编译结果 exe dll debug 调试 release 发布 pdb 位置信息–调试
obj文件夹 object 编译过程中生成的中间临时文件 加快编译速度
Properties 引用 添加引用 --选择需要的程序集
App.config 配置文件
.csproj 项目文件 位置引用 双击打开项目

Program.cs :程序入口

Form.cs 源代码(窗口处理代码)
Form.Designer.cs 窗体布局代码 自动生成对应的控件代码
Form.resx 窗体的资源

2. 窗体的常用属性、方法与事件

image-20231023181932153

2.1 常用属性(可直接在属性中设置)

属性名称描述示例代码
Text窗体的标题this.Text = "My Application";
Size窗体的尺寸this.Size = new Size(800, 600);
Location窗体在屏幕上的位置this.Location = new Point(100, 100);
WindowState窗体的状态(正常、最小化、最大化)this.WindowState = FormWindowState.Maximized;
BackColor窗体的背景颜色this.BackColor = Color.Red;
FormBorderStyle窗体边框的样式this.FormBorderStyle = FormBorderStyle.FixedDialog;
StartPosition窗体的初始位置this.StartPosition = FormStartPosition.CenterScreen;

2.2 常用方法

方法名称描述示例代码
Show()显示窗体this.Show();
ShowDialog()模态显示窗体this.ShowDialog();
Hide()隐藏窗体this.Hide();
Close()关闭窗体this.Close();
Activate()激活窗体this.Activate();
Invalidate()强制重新绘制窗体this.Invalidate();

Show()ShowDialog() 是用于显示窗体的两个不同方法,区别如下:

  • Show()

    • 非模态窗体(Non-modal): 当你使用 Show() 方法显示一个窗体时,用户可以自由地在新打开的窗体和原窗体之间切换。

    • 并行交互: 用户可以同时与父窗体和子窗体交互。

    • 代码继续执行: 在 Show() 方法后面的代码会立即执行,不会等待新打开的窗体关闭。

  • ShowDialog()

    • 模态窗体(Modal): 当你使用 ShowDialog() 打开一个窗体时,用户必须首先关闭该窗体才能继续与父窗体交互。

    • 串行交互: 用户在关闭新窗体之前不能与父窗体交互。

    • 代码等待: ShowDialog() 后面的代码会等待用户关闭新打开的窗体才会执行。

2.3 常用事件

事件名称描述示例用途
Load窗体加载时触发初始化窗体内容
Click在窗体上单击时触发处理单击事件
MouseMove鼠标在窗体上移动时触发实现自定义的鼠标跟踪
KeyPress键盘按键被按下时触发处理键盘输入
FormClosing窗体即将关闭时触发弹出确认对话框或保存设置
Resize窗体尺寸改变时触发动态调整控件位置和大小

3.Label、TextBox及Button控件

Label(标签)控件:

  1. 属性:
    • Name:控件的名称,用于在代码中引用它,一般以lbl开头,例如: lblUserName
    • Text:设置或获取显示在标签上的文本信息。
    • Image:用于显示图像。
    • ImageList:图像集控件。
    • Size:控件的尺寸,包括Width和Height。
    • Tag:与控件相关的自定义数据。
    • Enabled:确定是否启用标签。
    • Location:控件在窗体上的位置,包括X和Y坐标。
  2. 事件:
    • Click:当用户单击标签时触发。
    • TextChanged:当标签的文本内容发生更改时触发。

TextBox(文本框)控件:

  1. 属性:
    • Name:控件的名称。一般以txt开头,例如:txtUserName
    • Text:用于输入和获取文本信息。
    • MultiLine:确定文本框是否支持多行文本输入。
    • WordWrap:确定是否可以自动换行。
    • PasswordChar:指定密码框中的密码字符。
    • Size:控件的尺寸。
    • Enabled:确定是否启用文本框。
    • Location:控件在窗体上的位置。
  2. 方法:
    • AppendText(text):将指定的text文本追加到文本框的末尾。
    • Clear():清除文本框中的文本。
    • Focus():使文本框获取焦点。
    • Select():选择文本框中的文本。
    • SelectAll():选择文本框中的所有文本。
  3. 事件:
    • TextChanged:当文本框的文本内容发生更改时触发。
    • Click:一般不用于文本框,通常用于按钮等控件。

Button(按钮)控件:

  1. 属性:
    • Name:控件的名称。
    • Text:用于显示在按钮上的文本。
    • BackgroundImage:背景图片。
    • Image:按钮上显示的图像。
    • BackColor:背景色。
    • ForeColor:文本颜色。
    • Visible:确定按钮是否可见。
  2. 事件:
    • Click:当用户单击按钮时触发,通常用于执行与按钮相关的命令。

案例:做一个简单的登录界面

image-20231024105614900

代码

 public partial class FrmUser : Form
 {
     public FrmUser()
     {
         InitializeComponent();
         txtName.Text = "请输入账户";
         txtPassword.Text = "请输入密码";
         txtName.ForeColor = Color.Gray;
         txtPassword.ForeColor = Color.Gray;
     }

     private void Form1_Load(object sender, EventArgs e) //sender事件触发的对象
     {
     }

     private void textBox2_TextChanged(object sender, EventArgs e)
     {
         txtPassword.ForeColor = Color.Black;
     }

     private void txtName_TextChanged(object sender, EventArgs e)
     {
         txtName.ForeColor = Color.Black;
     }
     
     private void button2_Click(object sender, EventArgs e)
     {
         string UserName = txtName.Text.Trim();
         string userPwd = txtPassword.Text;

         if (string.IsNullOrEmpty(UserName) || UserName == "请输入账户")
         {
             MessageBox.Show("请输入用户名!", "登录页面", MessageBoxButtons.OK, MessageBoxIcon.Error);
             return;
         }
         if (string.IsNullOrEmpty(userPwd) || UserName == "请输入密码")
         {
             MessageBox.Show("请输入密码!", "登录页面", MessageBoxButtons.OK, MessageBoxIcon.Error);
             return;
         }
         MessageBox.Show("登录成功!", "进入主界面中....", MessageBoxButtons.OK, MessageBoxIcon.Information);
     }

     private void btn_Click(object sender, EventArgs e)
     {
         this.Close();
     }
 }

代码实现了一个基本的用户登录界面,用户可以输入用户名和密码,点击 “登录” 按钮进行登录,或者点击 “关闭” 按钮关闭窗体。同时,也包含了一些用户友好的功能,如在文本框中显示提示文本,输入文本时改变文本颜色,以及在输入验证时显示错误消息框。

image-20231024110514232
image-20231024110446593

4.RadioButton和CheckBox

RadioButton(单选按钮)

RadioButton 用于在一组选项中选择单一选项。在一组单选按钮中,只能选中其中一个,互相排斥。

属性

  • Name: 控件的名称
  • Text: 显示在界面上的文本
  • Checked: 是否被选中,返回布尔值
  • AutoCheck: 自动更改其他 RadioButton 的选中状态,默认为 true。

事件

  • CheckedChanged: 当选中状态改变时触发该事件。

应用场景

  • 角色选择登录
  • 性别选择

分组与代码操作: RadioButton 控件通常会放在一个 GroupBox 控件内,以形成一个逻辑分组,从而在这个分组中只能选择一个选项。通过代码也可以轻易地改变 RadioButton 的状态,例如 radioButton1.Checked = true;

事件处理: 你可以在 CheckedChanged 事件的事件处理器中添加逻辑,以响应用户的操作。例如:

csharpCopy codeprivate void radioButton1_CheckedChanged(object sender, EventArgs e)
{
    if (radioButton1.Checked)
    {
        // 执行某些操作
    }
}

CheckBox(复选框)

CheckBox 用于在一组选项中选择一个或多个项。

属性

  • Name: 控件的名称
  • Text: 显示在界面上的文本
  • Checked: 是否被选中,返回布尔值。
  • AutoCheck: 单击时自动更改选中状态,默认为 true,通常不要去修改这个属性。
  • CheckState: 表示三种不同的状态——未选中、选中、中间状态。
  • ThreeState: 控制 CheckBox 是三种状态还是两种,默认为 false。

事件

  • CheckedChanged: 当 Checked 属性值改变时触发。
  • CheckStateChanged: 当 CheckState 改变时触发。

事件触发顺序

  1. CheckedChanged(Checked 属性值改变)
  2. CheckStateChanged(CheckState 改变)

应用场景

  • 权限分配
  • 角色分配

高级用法与代码操作: 当 ThreeState 属性设置为 true 时,CheckBox 可以有三种状态:未选中、选中和中间状态。这在一些复杂的场景中(例如,批量操作)可能会很有用。通过代码也可以轻易地改变 CheckBox 的状态,例如 checkBox1.Checked = true;checkBox1.CheckState = CheckState.Indeterminate;

事件处理: 你可以在 CheckedChangedCheckStateChanged 事件的事件处理器中添加逻辑,以响应用户的操作。例如:

csharpCopy codeprivate void checkBox1_CheckedChanged(object sender, EventArgs e)
{
    if (checkBox1.Checked)
    {
        // 执行某些操作
    }
}

示例:

 public partial class frmSubmit : Form
 {
     public frmSubmit()
     {
         InitializeComponent();
     }

     private void btnCancel_Click(object sender, EventArgs e)
     {
         this.Close();
     }

     private void btnOk_Click(object sender, EventArgs e)
     {
         MessageBox.Show("提交成功!", "提交完成", MessageBoxButtons.OK, MessageBoxIcon.Information);
     }
     private void rdWriter_CheckedChanged(object sender, EventArgs e)
     {
         DialogResult result = MessageBox.Show("确定切换吗?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
         // 判断用户的选择
         if (result == DialogResult.OK)
         {
             // 用户选择了 OK,执行相应的操作
             // 这里可以放置你想要执行的代码
         }
         else if (result == DialogResult.Cancel)
         {
             // 用户选择了 Cancel,可以选择不执行任何操作
             // 或者放置一些取消操作的代码
         }

     }
 }

上面代码包含了按钮点击事件和单选按钮选择事件的处理逻辑。在用户与窗体进行交互时,它会显示消息框以获得用户的确认或取消操作,并根据用户的选择执行相应的操作。

在这里插入图片描述

5.ListBox(列表框)

ListBox 是 Windows Forms 中的一个控件,用于显示一列可选项,用户可以选择一项或多项。

属性

  • Name: 控件的名称
  • Items: 列表框中的项集合,可以通过它来添加、移除和操作列表中的项。
  • DataSource: 数据源,用于绑定 ListBox 到外部数据源,通常与 DisplayMemberValueMember 属性一起使用。
  • DisplayMember: 指定绑定数据源时显示的字段的名称。
  • ValueMember: 指定绑定数据源时用作值的字段的名称。

事件

  • SelectedIndexChanged: 当选择项更改时触发的事件,可以用于捕捉用户的选择变化。

示例:

public partial class FrmListBox : Form
{
    public FrmListBox()
    {
        InitializeComponent();
    }

    private void FrmListBox_Load(object sender, EventArgs e)
    {
        //项的清除
        listBox1.Items.Clear();
        //避免控件闪烁的问题
        listBox1.BeginUpdate();//闪烁
        //for循环等加载大量的项 

        listBox1.EndUpdate();
        //添加项
        listBox1.Items.Add(123);
        listBox1.Items.Add("jason");
        string[] list = { "adbc", "admin", "sqlserver" };
        listBox1.Items.AddRange(list);

        listBox1.Items.Insert(3, "micosoft");

        int index = listBox1.Items.IndexOf("admin");//获取索引
        bool bl = listBox1.Items.Contains("sqlserver");//存在
        listBox1.Items.Remove("admin");
        listBox1.Items.RemoveAt(3);
    }
}

在这里插入图片描述

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

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

相关文章

IEEE754 标准存储浮点数

1. IEEE754 标准简介 IEEE754 标准是一种用于浮点数表示和运算的标准,由国际电工委员会(IEEE)制定。它定义了浮点数的编码格式、舍入规则以及基本的算术运算规则,旨在提供一种可移植性和一致性的方式来表示和处理浮点数 IEEE754 …

浅谈电力电容器的故障处理及选型

安科瑞 华楠 【摘要】常见的电力电容器都是为了改善电力系统的电压质量和提高输电线路的输电能力,它们在减少系统功率损耗、提高功率因数、降低运行电流、提升电网电压、释放变压器使用裕度等方面有着显著效果。按电压等级可以划分高、低压两部分。虽然它们可以起着…

Vue mixin混入

可以把多个组件中共有的配置提取出来构成一个混入。 一、配置混入 (一) 创建mixin.js 这里的名字可以自定义,但是为了方便识别,多数场景下都写mixin。 mixin.js 要创建在src目录下,与main.js平级: &…

win10启动venv报错:无法加载文件 venv\Scripts\activate.ps1,因为在此系统上禁止运行脚本。

背景: 最近需要用到python开发,切换虚拟环境时,在win10系统上安装编辑器后创建了虚拟环境,但是执行activate时报错:.\venv\Scripts\activate,报错内容如题: 无法加载文件 venv\Scripts\activa…

HTTPSConnectionPool(host=‘huggingface.co‘, port=443)解决

huggingface,也就是抱抱脸,应该都很熟悉了吧 好用是很好用,就是有一个问题,国内的IP地址总是不灵是吧 今天我就碰到这么个问题 请看图: 。。。。图找不到了,我的问题忘记记录了 我给你们贴上文字吧 (M…

reactNative导入excel文件

组件内导入 import {TouchableOpacity,PermissionsAndroid} from react-native; import RNFS from react-native-fs; import XLSX from xlsx; import DocumentPicker from react-native-document-picker; import {Buffer} from buffer;// 需要安装一下三个,Buffer和react-nati…

Standford Compiler Course Assignment 2

第二部分的作业是语法分析,通过编写cool.y(这个assignment的任务),利用bison将其自动生成语法分析LALR(1)的代码。 语法分析,就是将词法分析阶段已经识别好的token,按照语法的规则,构建抽象语法树的过程。 比如以下的…

读书笔记之《敏捷测试从零开始》(一)

大家好,我是rainbowzhou。 子曰:学而时习之,不亦说乎?今天我想和大家分享一本测试书籍——《敏捷测试从零开始》。以下为我的读书笔记: 精彩片段摘录: 焦虑往往来自于对比,当你在自己的圈子里面…

Elasticsearch之mapping

文章目录 以显式的方式创建一个映射查看某个具体索引的mapping定义向已存在的映射中添加一个新的属性查看映射中指定字段的定义信息更新已存在映射的某个字段 1、 官方文档地址 2、 字段类型 1、定义:映射是定义文档及其包含的字段如何存储和索引的过程。 2、每个…

LabVIEW在 XY Graph中选择一组点

LabVIEW在 XY Graph中选择一组点 问题:有一个包含许多点的XY Graph,在程序开发中,对于显示XY Graph中的多个点,如何进行选取。最好能像图像处理中的ROI一样,并且它们的颜色可以更改,可以在其中选择一些ROI…

企业安全—SDL概述篇

0x00 前言 众所周知,从源头开始就开发安全的代码,比产品已经成型之后付出的代价要小很多,也就是一直在说的安全左移的概念。最好就是从一开始,大家就用最安全的代码,或者是框架,那么开发出来的产品必然会减…

C++ string 类的其他操作

4.3.2 string 类的其他操作 在C新增string类之前,程序员也需要完成诸如给字符串赋值等工作。对于C语言式的字符串,程 序员使用C语言库中的函数来完成这些任务。头文件cstring(以前为string.h)提供了这些函数。例如,可 以使用函数 strcpy()将字符串复制到字符数组中,使用函数…

小样本学习(2)--LibFewShot使用

目录 一、LibFewShot安装 1、LibFewShot代码仓库 2、配置环境 3、测试安装是否正确 二、LibFewShot结构 1、config文件夹 2、core文件夹 3、reproduce文件夹 4、results文件夹 三、如何训练自己的数据集 1、调用主配置文件 2、修改主配置文件 一、LibFewShot安装…

实时流量监控

任何企业的IT管理员的主要目标都是交付一个高度稳定的网络,没有任何压力或重大故障,但是考虑到动态在今天的技术和网络中,这可能需要付出巨大的努力来获得可见性并避免负面影响。 交付高响应的网络和应用程序意味着保持网络正常运行&#xf…

C#开发的OpenRA游戏之金钱系统(5)

C#开发的OpenRA游戏之金钱系统(5) 前面分析了采矿车到矿场采矿的过程,那么采矿车什么时候采满呢?采满之后又是怎么样运送到精炼工厂呢? 首先我们来分析采矿车是怎么样判断采满矿产的,毕竟采矿车不能无限装载矿产资源。所以我们再次回到采矿车类Harvester,来分析它怎么…

推荐几个程序员必逛的个人技术博客网站

1、美团技术团队 地 址: 美团技术团队简 介:美团技术团队的博客,干货满满。推荐指数:⭐⭐⭐⭐⭐ ​ 2、阮一峰的网络日志 地 址: 阮一峰的个人网站 - Ruan YiFengs Personal Website简 介:大神阮一峰,博客风格真正…

期中考核复现

web 1z_php ?0o0[]1A&OoO[]2023a include "flag.php":尝试包含名为 "flag.php" 的文件。这意味着它会尝试引入一个名为 "flag.php" 的脚本文件,其中可能包含一些敏感信息或标志。 error_reporting(0):…

Python中使用cv2.resize()函数批量自定义缩放图像尺寸

目录 常用插值缩放方法缩放示例代码总结 常用插值缩放方法 cv2.resize()函数中的interpolation参数指定了图像缩放时使用的插值方法。以下是常用的插值方法: cv2.INTER_NEAREST:最近邻插值。该方法通过选择最接近目标像素的原始像素来进行插值。它是最…

javaEE -8(9000字详解网络编程)

一:网络编程基础 1.1 网络资源 所谓的网络资源,其实就是在网络中可以获取的各种数据资源,而所有的网络资源,都是通过网络编程来进行数据传输的。 用户在浏览器中,打开在线视频网站,如优酷看视频&#xff…

管理类联考——英语二——阅读篇——题材:环保

文章目录 环保2017 年,Text 4——题材:环保-社会细节题-第一步定位;第二步原文复现细节题-推理细节题-人物观点细节题-原因-原词重现,同义替换细节题-人物观点-排除法 2019 年,Text 4——题材:社会-环保细节…