记录|自建Form窗口,实现消息提示+自动消失

2024-08-29 14:12

本文主要是介绍记录|自建Form窗口,实现消息提示+自动消失,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 前言
  • 一、UI准备
    • Step1. 创建窗体控件
    • Step2. 设置FormAlert的属性
    • Step3. 增加Label
    • Step4. 增加Button
    • Step1~4 效果展示:
  • 二、Icon和Timer准备
    • Step5. 准备相应的icon
    • Step6. 添加PictureBox
    • Step7. 添加定时器Timer
  • 三、代码编写
  • 四、代码调用
    • Step8. 创建Button
    • Step9. Form中调用
  • 五、效果展示
  • 更新时间


前言

参考视频:
C# Winform - Custom Notification自定义通知提示

想实现:点击相应按钮会出现相应的信息提示,在显示几秒后自动消失。
这个功能还是需要自己写个组件来实现比较方便,属于一劳永逸了。
在这里插入图片描述


一、UI准备

Step1. 创建窗体控件

  • 新建一个FormAlert的窗体控件【如下图,下面的名字写错了哈,应该是FormAlert】
    在这里插入图片描述

Step2. 设置FormAlert的属性

  • Font:Century Gothic, 14pt
  • FormBordeStyle:None
  • BackColor:Highlight
    如下图:
    在这里插入图片描述

Step3. 增加Label

  • FontColor:White
  • Text:MessageText

Step4. 增加Button

  • Name:lblMsg
  • FlatStyle:Flat
  • FontColor:White 【这里没想到,会影响Button边框,使其也变为White】
  • FlatAppearance中的BorderSize:0

Step1~4 效果展示:

在这里插入图片描述


二、Icon和Timer准备

Step5. 准备相应的icon

  • 这边处于管理的考虑,建立了Icons资源文件,将该FormAlter所用的Icons进行了管控。【如下图】
    在这里插入图片描述
    在这里插入图片描述
    对刚才的Button中的Image属性添加“closeMsg.png”图片,效果如下:
    在这里插入图片描述

Step6. 添加PictureBox

  • 将属性中的图片模式设置为Zoom,如下图
    在这里插入图片描述
  • 添加图片 ,效果如下:
    在这里插入图片描述

Step7. 添加定时器Timer

  • Name:timerAlert

三、代码编写

FormAlert中的代码如下:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using ZHCH_winform_2.Properties;namespace ZHCH_winform_2.manager
{/// <summary>/// 自定义的提示窗口控件/// </summary>public partial class FormAlert : Form{public FormAlert(){InitializeComponent();}public enum enmAction{wait,start,close}public enum enmType{Success,Warning,Error,Info}private FormAlert.enmAction action;private int x, y;private void btnClose_Click(object sender, EventArgs e){timerAlert.Interval = 1;action = enmAction.close;}private void timerAlert_Tick(object sender, EventArgs e){switch (this.action){case enmAction.wait:timerAlert.Interval = 5000;action = enmAction.close;break;case enmAction.start:timerAlert.Interval = 1;this.Opacity += 0.1;if(this.x < this.Location.X){this.Left--;}else{if (this.Opacity == 1.0){action = enmAction.wait;}}break;case enmAction.close:timerAlert.Interval = 1;this.Opacity -= 0.1;this.Left -= 3;if (base.Opacity == 0.0){base.Close();}break;}}public void showAlert(string msg, enmType type ){this.Opacity = 0.0;this.StartPosition = FormStartPosition.Manual;string fname;for(int i = 0; i < 3; i++){fname = "提示:" + i.ToString();FormAlert frm = (FormAlert)Application.OpenForms[fname];if(frm == null){this.Name = fname;this.x = Screen.PrimaryScreen.WorkingArea.Width - this.Width + 15;this.y = Screen.PrimaryScreen.WorkingArea.Height/9 - this.Height * i;this.Location = new Point(this.x,this.y);break;}}this.x = Screen.PrimaryScreen.WorkingArea.Width - base.Width - 5;switch (type){case enmType.Success:this.picBoxAlert.Image = Resources.success;this.BackColor = Color.SeaGreen;break;case enmType.Error:this.picBoxAlert.Image = Resources.error;this.BackColor = Color.DarkRed;break;case enmType.Info:this.picBoxAlert.Image = Resources.info;this.BackColor = Color.RoyalBlue;break;case enmType.Warning:this.picBoxAlert.Image = Resources.warning;this.BackColor = Color.DarkOrange;break;}this.lblMsg.Text = msg;this.Show();this.action = enmAction.start;this.timerAlert.Interval = 1;timerAlert.Start();}}
}
  • 注意,需要将Icon图片全部导入到Resource资源中,这样才能在编写Resources.success时才能调用到图片【如下所示】
    在这里插入图片描述

四、代码调用

Step8. 创建Button

  • 创建个按钮,去检验其是否能重新调用
  • Name:altSubmit
    在这里插入图片描述
  • 创建Button的点击事件,代码如下:
        private void btnSubmit_Click(object sender, EventArgs e){this.Alert("成功调用",FormAlert.enmType.Success);}

Step9. Form中调用

  • 创建 Alert方法函数,代码如下:
        public void Alert(string msg,FormAlert.enmType type){FormAlert frm = new FormAlert();frm.showAlert(msg,type);}

五、效果展示

在这里插入图片描述


更新时间

  • 2024.08.29:创建+验证通过。

这篇关于记录|自建Form窗口,实现消息提示+自动消失的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1118085

相关文章

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

SpringIntegration消息路由之Router的条件路由与过滤功能

《SpringIntegration消息路由之Router的条件路由与过滤功能》本文详细介绍了Router的基础概念、条件路由实现、基于消息头的路由、动态路由与路由表、消息过滤与选择性路由以及错误处理... 目录引言一、Router基础概念二、条件路由实现三、基于消息头的路由四、动态路由与路由表五、消息过滤

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

基于SpringBoot实现文件秒传功能

《基于SpringBoot实现文件秒传功能》在开发Web应用时,文件上传是一个常见需求,然而,当用户需要上传大文件或相同文件多次时,会造成带宽浪费和服务器存储冗余,此时可以使用文件秒传技术通过识别重复... 目录前言文件秒传原理代码实现1. 创建项目基础结构2. 创建上传存储代码3. 创建Result类4.

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

SpringBoot中封装Cors自动配置方式

《SpringBoot中封装Cors自动配置方式》:本文主要介绍SpringBoot中封装Cors自动配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot封装Cors自动配置背景实现步骤1. 创建 GlobalCorsProperties