记录|自建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

相关文章

利用Python实现Excel文件智能合并工具

《利用Python实现Excel文件智能合并工具》有时候,我们需要将多个Excel文件按照特定顺序合并成一个文件,这样可以更方便地进行后续的数据处理和分析,下面我们看看如何使用Python实现Exce... 目录运行结果为什么需要这个工具技术实现工具的核心功能代码解析使用示例工具优化与扩展有时候,我们需要将

使用nohup和--remove-source-files在后台运行rsync并记录日志方式

《使用nohup和--remove-source-files在后台运行rsync并记录日志方式》:本文主要介绍使用nohup和--remove-source-files在后台运行rsync并记录日... 目录一、什么是 --remove-source-files?二、示例命令三、命令详解1. nohup2.

Python+PyQt5实现文件夹结构映射工具

《Python+PyQt5实现文件夹结构映射工具》在日常工作中,我们经常需要对文件夹结构进行复制和备份,本文将带来一款基于PyQt5开发的文件夹结构映射工具,感兴趣的小伙伴可以跟随小编一起学习一下... 目录概述功能亮点展示效果软件使用步骤代码解析1. 主窗口设计(FolderCopyApp)2. 拖拽路径

Spring AI 实现 STDIO和SSE MCP Server的过程详解

《SpringAI实现STDIO和SSEMCPServer的过程详解》STDIO方式是基于进程间通信,MCPClient和MCPServer运行在同一主机,主要用于本地集成、命令行工具等场景... 目录Spring AI 实现 STDIO和SSE MCP Server1.新建Spring Boot项目2.a

Spring Boot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)

《SpringBoot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)》:本文主要介绍SpringBoot拦截器Interceptor与过滤器Filter深度解析... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现与实

C#实现访问远程硬盘的图文教程

《C#实现访问远程硬盘的图文教程》在现实场景中,我们经常用到远程桌面功能,而在某些场景下,我们需要使用类似的远程硬盘功能,这样能非常方便地操作对方电脑磁盘的目录、以及传送文件,这次我们将给出一个完整的... 目录引言一. 远程硬盘功能展示二. 远程硬盘代码实现1. 底层业务通信实现2. UI 实现三. De

SpringBoot后端实现小程序微信登录功能实现

《SpringBoot后端实现小程序微信登录功能实现》微信小程序登录是开发者通过微信提供的身份验证机制,获取用户唯一标识(openid)和会话密钥(session_key)的过程,这篇文章给大家介绍S... 目录SpringBoot实现微信小程序登录简介SpringBoot后端实现微信登录SpringBoo

使用Vue-ECharts实现数据可视化图表功能

《使用Vue-ECharts实现数据可视化图表功能》在前端开发中,经常会遇到需要展示数据可视化的需求,比如柱状图、折线图、饼图等,这类需求不仅要求我们准确地将数据呈现出来,还需要兼顾美观与交互体验,所... 目录前言为什么选择 vue-ECharts?1. 基于 ECharts,功能强大2. 更符合 Vue

使用WPF实现窗口抖动动画效果

《使用WPF实现窗口抖动动画效果》在用户界面设计中,适当的动画反馈可以提升用户体验,尤其是在错误提示、操作失败等场景下,窗口抖动作为一种常见且直观的视觉反馈方式,常用于提醒用户注意当前状态,本文将详细... 目录前言实现思路概述核心代码实现1、 获取目标窗口2、初始化基础位置值3、创建抖动动画4、动画完成后

uniapp小程序中实现无缝衔接滚动效果代码示例

《uniapp小程序中实现无缝衔接滚动效果代码示例》:本文主要介绍uniapp小程序中实现无缝衔接滚动效果的相关资料,该方法可以实现滚动内容中字的不同的颜色更改,并且可以根据需要进行艺术化更改和自... 组件滚动通知只能实现简单的滚动效果,不能实现滚动内容中的字进行不同颜色的更改,下面实现一个无缝衔接的滚动