【窗体】Winform两个窗体之间通过委托事件进行值传递,基础篇

2023年,第38周。给自己一个目标,然后坚持总会有收货,不信你试试!
在实际项目中,我们可能会用到一些窗体做一些小工具或者小功能。比如:运行程序,在主窗体A基础上,点击某个按钮希望能够弹出B窗体,
在B窗体完成操作后,希望能够把值传递回到A窗体,然后进行其他业务操作。

目录

  • 一、显示线上图片
  • 二、显示本地图片
  • 三、A窗体打开B窗体
  • 四、事件机制传递值
    • 4.1、订阅事件
    • 4.2、事件机制
  • 五、基础概念
    • 5.1、委托(Delegate)
    • 5.2、事件(Event)
    • 5.3、消息(Message)
    • 5.4、发布(Publish)和订阅(Subscribe)

在这里插入图片描述

一、显示线上图片

要在C# WinForm中动态为PictureBox控件赋值图片链接,你可以使用Image.FromUrl方法来加载远程图片,并将其分配给PictureBox的Image属性。

  • 下面是一个简单的示例代码:

首先,在你的WinForm窗体上添加一个PictureBox控件。

然后,在窗体的代码文件中,添加以下引用:

using System;
using System.Drawing;
using System.Windows.Forms;
using System.Net;

接下来,在你想赋值图片链接的事件中(如按钮点击事件),添加以下代码:

private void button1_Click(object sender, EventArgs e)
{try{// 获取图片链接string imageUrl = "https://example.com/image.jpg"; // 替换为你的图片链接// 使用WebClient下载图片WebClient client = new WebClient();byte[] imageData = client.DownloadData(imageUrl);MemoryStream ms = new MemoryStream(imageData);// 创建并分配图片给PictureBoxImage image = Image.FromStream(ms);pictureBox1.Image = image;}catch (Exception ex){// 处理异常MessageBox.Show("加载图片时出错:" + ex.Message);}
}

在上述示例中,我们使用WebClient来下载图片数据,并将其转换为Image对象。
然后,我们将该图像分配给PictureBox的Image属性,这样就可以在窗体上显示图片了。

注意,为了正常运行示例,请确保你的应用程序能够访问指定的图片链接。

二、显示本地图片

要在C# WinForm中加载本地图片到PictureBox控件,你可以使用Image.FromFile方法来加载本地图片文件,并将其分配给PictureBox的Image属性。

  • 下面是一个简单的示例代码:

首先,在你的WinForm窗体上添加一个PictureBox控件。

然后,在窗体的代码文件中,添加以下引用:

using System;
using System.Drawing;
using System.Windows.Forms;

接下来,在你想加载本地图片的事件中(如按钮点击事件),添加以下代码:

private void button1_Click(object sender, EventArgs e)
{try{// 获取本地图片文件路径string imagePath = "C:\\path\\to\\your\\image.jpg"; // 替换为你的图片文件路径// 加载本地图片文件Image image = Image.FromFile(imagePath);// 将图片分配给PictureBoxpictureBox1.Image = image;}catch (Exception ex){// 处理异常MessageBox.Show("加载图片时出错:" + ex.Message);}
}

在上述示例中,我们使用Image.FromFile方法加载指定路径的图片文件,并将其转换为Image对象。
然后,我们将该图像分配给PictureBox的Image属性,从而在窗体上显示图片。

请注意,替换示例代码中的imagePath为你实际的本地图片文件路径。

三、A窗体打开B窗体

在C# WinForm中打开另一个窗体,你可以使用Form类的实例来创建一个新的窗体,并调用其ShowShowDialog方法来显示它。

  • 下面是一个简单的示例代码:

假设你已经创建了两个窗体:Form1Form2

Form1窗体中,你可以添加一个按钮,在按钮的点击事件中打开Form2窗体。代码如下:

private void button1_Click(object sender, EventArgs e)
{// 创建Form2窗体实例Form2 form2 = new Form2();// 显示Form2窗体form2.Show();
}

如果你希望以模态的方式打开另一个窗体,即Form2完全显示后才能继续操作Form1,你可以使用ShowDialog方法。

  • 示例代码如下:
private void button1_Click(object sender, EventArgs e)
{// 创建Form2窗体实例Form2 form2 = new Form2();// 以模态方式显示Form2窗体form2.ShowDialog();
}

在上述示例中,我们首先创建了要打开的窗体实例,然后调用Show方法或ShowDialog方法来显示该窗体。

四、事件机制传递值

要将从B窗体选择的值传递给A窗体,你可以通过以下几种方式实现:

4.1、订阅事件

在B窗体中定义一个属性或字段,用于保存所选的值。当B窗体关闭时,将选定的值传递回A窗体。

在B窗体的代码中,可以定义一个公共属性或字段来保存所选的值:

public string SelectedValue { get; set; }

在B窗体中的事件(如按钮点击事件)中,将所选的值赋给SelectedValue

private void button1_Click(object sender, EventArgs e)
{SelectedValue = comboBox1.SelectedItem.ToString();this.Close();
}

在A窗体的代码中,创建B窗体的实例,并订阅B窗体的FormClosing事件来获取所选的值:

private void button1_Click(object sender, EventArgs e)
{BForm bForm = new BForm();bForm.FormClosing += (s, args) =>{if (!string.IsNullOrEmpty(bForm.SelectedValue)){// 使用bForm.SelectedValue在A窗体中进行操作MessageBox.Show(bForm.SelectedValue);}};bForm.ShowDialog();
}

4.2、事件机制

使用委托(Delegate)和事件(Event)机制来传递值。

在B窗体的代码中,首先定义一个委托和事件:

public delegate void ValueSelectedEventHandler(string selectedValue);
public event ValueSelectedEventHandler ValueSelected;

在B窗体中的事件(如按钮点击事件)中,触发事件并传递所选的值:

private void button1_Click(object sender, EventArgs e)
{string selectedValue = comboBox1.SelectedItem.ToString();ValueSelected?.Invoke(selectedValue);this.Close();
}

在A窗体的代码中,创建B窗体的实例,并订阅B窗体的事件来获取所选的值:

private void button1_Click(object sender, EventArgs e)
{BForm bForm = new BForm();bForm.ValueSelected += (selectedValue) =>{// 使用selectedValue在A窗体中进行操作MessageBox.Show(selectedValue);};bForm.ShowDialog();
}

通过上述方法之一,你可以在A窗体中获取从B窗体选择的值,并在需要的地方进行操作。

五、基础概念

在 C# 中,委托(Delegate)、事件(Event)、消息(Message)、发布(Publish)和订阅(Subscribe)是几个相关的概念,它们之间有一些关系和联系。

  • 下面简要介绍它们之间的关系:

5.1、委托(Delegate)

委托是一种类型,它可以引用一个或多个方法,并允许通过委托调用这些方法。委托提供了一种将方法作为参数传递的机制,并允许以回调的方式进行函数调用。

5.2、事件(Event)

事件是基于委托的机制,用于实现一种对象间的通信和互动。对象可以将事件定义为其成员,并在特定条件下引发(触发)事件。其他对象可以订阅(或注册)事件,以便在事件发生时接收通知并执行相应的处理方法。

5.3、消息(Message)

消息是一种用于对象之间交换数据和信息的机制。它在不同的组件之间传递,以触发相应的行为或操作。消息可以是同步或异步的,可以包含参数、事件或其他数据。

5.4、发布(Publish)和订阅(Subscribe)

发布-订阅模式是一种软件设计模式,用于实现对象之间的解耦和松散耦合。在该模式中,一个对象(发布者)通知其他对象(订阅者)发生了某个事件或发出了某个消息,订阅者可以选择性地接收并处理这些事件或消息。

在 C# 中,通常通过定义委托和事件来实现发布-订阅模式,发布者发布事件,而订阅者订阅并处理事件。
事件是一种特殊类型的委托,它可以提供更高级别的封装和安全性。

通过委托和事件,可以实现对象之间的松耦合通信,以实现更灵活、可扩展和可维护的代码结构。

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

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

相关文章

修改mars3d地球背景色

示例链接 示例链接 修改代码

Git: 工作区、暂存区、本地仓库、远程仓库

参考链接: Git: 工作区、暂存区、本地仓库、远程仓库 https://blog.csdn.net/weixin_36750623/article/details/96189838

《C++ primer plus》精炼(OOP部分)——对象和类(5)

“学习是照亮心灵的火炬,它永不熄灭,永不止息。” 文章目录 类的自动和强制类型转换原始类型转换为自定义类型将自定义类型转换为原始类型 类的自动和强制类型转换 原始类型转换为自定义类型 可以用一个参数的构造函数来实现,例如&#xff…

QStandardItem通过setCheckable添加复选框后无法再次通过setCheckable取消复选框的问题

前言 如题所示&#xff0c;通过setCheckable添加复选框后&#xff0c;想要通过setCheckable(false)取消复选框&#xff0c;你会发现根本没有作用的。 问题复现 #include "widget.h" #include "ui_widget.h" #include <QList>Widget::Widget(QWidg…

卡尔曼滤波(Kalman Filter)原理浅析-数学理论推导-1

目录 前言数学理论推导1. 递归算法2. 数学基础结语参考 前言 最近项目需求涉及到目标跟踪部分&#xff0c;准备从 DeepSORT 多目标跟踪算法入手。DeepSORT 中涉及的内容有点多&#xff0c;以前也就对其进行了简单的了解&#xff0c;但是真正去做发现总是存在这样或者那样的困惑…

Java idea编译器工程out目录修改

问题 多个工程在一个文件夹下&#xff0c;有时会变为所有的工程只用一个out文件夹&#xff0c;这时运行会出错。 解决方案是将各自的工程out放在自己的文件夹下面 以上面这个工程为例 如果project structure里面有则直接按照下面的指标设置&#xff0c;如果没有则添加到里面再…

ABB 1TGE120010R1300 控制主板模块

ABB 1TGE120010R1300 控制主板模块是一种用于控制和监测电力设备的模块&#xff0c;具有以下功能&#xff1a; 控制和监测电力设备&#xff1a;该模块可以通过与电力设备连接来控制和监测设备的性能和状态&#xff0c;例如启停设备、调节电压和功率等。 通信功能&#xff1a;该…

docker 和k8s 入门

docker 和k8s 入门 本文是云原生的学习记录&#xff0c;可以参考以下文档 k8s https://www.yuque.com/leifengyang/oncloud 相关视频教程可参考如下 https://www.bilibili.com/video/BV13Q4y1C7hS?p2&vd_source0882f549dac54045384d4a921596e234 相对于公有云&#x…

LeetCode 面试题 04.05. 合法二叉搜索树

文章目录 一、题目二、C# 题解 一、题目 实现一个函数&#xff0c;检查一棵二叉树是否为二叉搜索树。 点击此处跳转题目。 示例 1: 输入: 2/ \ 1 3输出: true 示例 2: 输入: 5/ \1 4/ \ 3 6输出: false 解释: 输入为: [5,1,4,null,null,3,6]。 根节点的值为 5 &#xff…

【力扣周赛】第 362 场周赛(⭐差分匹配状态压缩DP矩阵快速幂优化DPKMP)

文章目录 竞赛链接Q1&#xff1a;2848. 与车相交的点解法1——排序后枚举解法2——差分数组⭐差分数组相关题目列表&#x1f4d5;1094. 拼车1109. 航班预订统计2381. 字母移位 II2406. 将区间分为最少组数解法1——排序贪心优先队列解法2——差分数组 2772. 使数组中的所有元素…

与导师沟通2023-09-14

一、学习基本计划: 研一上:我将学习专业知识,提高自身的英语水平以及人文素养,同时做到阅读各领域书籍并努力专攻计算机方向,多阅读中外文杂志,参加各类讲座、会议,确定自己的研究兴趣;跟随导师研究课题(智慧教育),确定一个适合我自身的研究方向(NLP)。 (1)学习并实…

TCP IP网络编程(五) 基于TCP的服务器端、客户端 (补充)

文章目录 回声客户端的完美实现回声客户端出现的问题回声客户端问题解决方法 TCP原理TCP套接字中的I/O缓冲TCP内部工作原理1&#xff1a;与对方套接字的连接TCP内部工作原理2&#xff1a;与对方主机的数据交换TCP内部工作原理3&#xff1a;断开与套接字的连接 回声客户端的完美…

pycharm-2023.1 closing project window stuck

pycharm-2023.1 closing project window stuck 问题描述 pycharm 切换项目/重启&#xff0c;一直卡在 closing project 原因分析 PyCharm 2023.1 issue - closing project window stuck (PyPIPackageUtil.lambda$parsePyPIListFromWeb) 解决方案 升级 pycharm 到 2023.3py…

双向链表的实现(增删查改)——最好理解的链表

双向链表的实现 一&#xff0c;双向链表的特点二&#xff0c;双向链表的结构三&#xff0c;双向链表的内容实现3.1创建node节点3.2初始化3.3打印3.4插入3.4.1尾插3.4.2头插3.4.3在pos位置上插入 3.5删除3.5.1尾删3.5.2头删3.5.3删除pos位置上的数据 四&#xff0c;调试技巧&…

day21算法

常见的七种查找算法&#xff1a; ​ 数据结构是数据存储的方式&#xff0c;算法是数据计算的方式。所以在开发中&#xff0c;算法和数据结构息息相关。今天的讲义中会涉及部分数据结构的专业名词&#xff0c;如果各位铁粉有疑惑&#xff0c;可以先看一下哥们后面录制的数据结构…

Re46:读论文 DAGNN Towards Deeper Graph Neural Networks

诸神缄默不语-个人CSDN博文目录 论文名称&#xff1a;Towards Deeper Graph Neural Networks 模型简称&#xff1a;DAGNN 本文是2020年KDD论文&#xff0c;下载地址是https://www.kdd.org/kdd2020/accepted-papers/view/towards-deeper-graph-neural-networks 本文主要关注在…

【C++学习】继承

目录 一、继承的概念及定义 1、继承的概念 2、继承的定义 2.1 定义格式 2.2 继承关系和访问限定符 2.3 继承基类成员访问方式的变化 二、基类和派生类对象赋值转换 三、继承中的作用域 四、派生类的默认成员函数 五、继承与友元 六、继承与静态成员 七、复杂的菱形…

SpringMvc第五战-【SpringMvcJSR303和拦截器】

前言&#xff1a; 小编阐述了springmvc 中的文件下载&#xff0c;以及jrebel的使用和文件下载以及多文件下载! 在本次小编将会介绍JSR303的概念&#xff0c;应用场景和在具体实例的使用&#xff1b;和拦截器的应用 一.JSR303的介绍 1.什么是JSR303&#xff1f; JSR是Java S…

Aztec的隐私抽象:在尊重EVM合约开发习惯的情况下实现智能合约隐私

1. 引言 Aztec的架构&#xff0c;不同于当前“通过EVM兼容执行环境”所实现的区块链水平扩容趋势。Aztec内部笑称其构建的为首个非zkEVM协议。 Aztec专注于实现&#xff1a; 成为理解和需要智能合约隐私的开发者的终极解决方案。 Aztec为开发者提供构建隐私优先app所需的网…

【微信小程序开发】宠物预约医疗项目实战-环境配置与Vant UI集成

第一章 宠物预约医疗项目实战-环境配置与Vant UI集成 文章目录 前言一、Vant UI是什么&#xff1f;二、使用步骤2.1 安装 node.js2.2 通过 npm 安装vant2.3 修改 app.json2.4 修改 project.config.json2.5 构建 npm 包2.6 使用组件全局引入和局部引入全局引入局部引入 前言 Va…