C# Winform 实现自定义半透明loading加载遮罩层
在网页中通过div+css实现半透明效果不难,今天我们看看一种在winfrom中实现的方法:
效果图如下,正常时:
显示遮罩层时:
自定义遮罩层控件的源码如下:
1 | using System; |
2 | using System.Drawing; |
3 | using System.Windows.Forms; |
4 | using System.ComponentModel; |
5 | |
6 | namespace MyOpaqueLayer |
7 | { |
8 | /// <summary> |
9 | /// 自定义控件:半透明控件 |
10 | /// </summary> |
11 | /* |
12 | * [ToolboxBitmap(typeof(MyOpaqueLayer))] |
13 | * 用于指定当把你做好的自定义控件添加到工具栏时,工具栏显示的图标。 |
14 | * 正确写法应该是 |
15 | * [ToolboxBitmap(typeof(XXXXControl),"xxx.bmp")] |
16 | * 其中XXXXControl是你的自定义控件,"xxx.bmp"是你要用的图标名称。 |
17 | */ |
18 | [ToolboxBitmap(typeof(MyOpaqueLayer))] |
19 | public class MyOpaqueLayer : System.Windows.Forms.Control |
20 | { |
21 | private bool _transparentBG = true;//是否使用透明 |
22 | private int _alpha = 125;//设置透明度 |
23 | |
24 | private System.ComponentModel.Container components = new System.ComponentModel.Container(); |
25 | |
26 | public MyOpaqueLayer() |
27 | : this(125, true) |
28 | { |
29 | } |
30 | |
31 | public MyOpaqueLayer(int Alpha, bool IsShowLoadingImage) |
32 | { |
33 | SetStyle(System.Windows.Forms.ControlStyles.Opaque, true); |
34 | base.CreateControl(); |
35 | |
36 | this._alpha = Alpha; |
37 | if (IsShowLoadingImage) |
38 | { |
39 | PictureBox pictureBox_Loading = new PictureBox(); |
40 | pictureBox_Loading.BackColor = System.Drawing.Color.White; |
41 | pictureBox_Loading.Image = 加载中.Properties.Resources.loading; |
42 | pictureBox_Loading.Name = "pictureBox_Loading"; |
43 | pictureBox_Loading.Size = new System.Drawing.Size(48, 48); |
44 | pictureBox_Loading.SizeMode = System.Windows.Forms.PictureBoxSizeMode.AutoSize; |
45 | Point Location = new Point(this.Location.X + (this.Width - pictureBox_Loading.Width) / 2, this.Location.Y + (this.Height - pictureBox_Loading.Height) / 2);//居中 |
46 | pictureBox_Loading.Location = Location; |
47 | pictureBox_Loading.Anchor = AnchorStyles.None; |
48 | this.Controls.Add(pictureBox_Loading); |
49 | } |
50 | } |
51 | |
52 | |
53 | protected override void Dispose(bool disposing) |
54 | { |
55 | if (disposing) |
56 | { |
57 | if (!((components == null))) |
58 | { |
59 | components.Dispose(); |
60 | } |
61 | } |
62 | base.Dispose(disposing); |
63 | } |
64 | |
65 | /// <summary> |
66 | /// 自定义绘制窗体 |
67 | /// </summary> |
68 | /// <param name="e"></param> |
69 | protected override void OnPaint(System.Windows.Forms.PaintEventArgs e) |
70 | { |
71 | float vlblControlWidth; |
72 | float vlblControlHeight; |
73 | |
74 | Pen labelBorderPen; |
75 | SolidBrush labelBackColorBrush; |
76 | |
77 | if (_transparentBG) |
78 | { |
79 | Color drawColor = Color.FromArgb(this._alpha, this.BackColor); |
80 | labelBorderPen = new Pen(drawColor, 0); |
81 | labelBackColorBrush = new SolidBrush(drawColor); |
82 | } |
83 | else |
84 | { |
85 | labelBorderPen = new Pen(this.BackColor, 0); |
86 | labelBackColorBrush = new SolidBrush(this.BackColor); |
87 | } |
88 | base.OnPaint(e); |
89 | vlblControlWidth = this.Size.Width; |
90 | vlblControlHeight = this.Size.Height; |
91 | e.Graphics.DrawRectangle(labelBorderPen, 0, 0, vlblControlWidth, vlblControlHeight); |
92 | e.Graphics.FillRectangle(labelBackColorBrush, 0, 0, vlblControlWidth, vlblControlHeight); |
93 | } |
94 | |
95 | |
96 | protected override CreateParams CreateParams//v1.10 |
97 | { |
98 | get |
99 | { |
100 | CreateParams cp = base.CreateParams; |
101 | cp.ExStyle |= 0x00000020; //0x20; // 开启 WS_EX_TRANSPARENT,使控件支持透明 |
102 | return cp; |
103 | } |
104 | } |
105 | |
106 | /* |
107 | * [Category("myOpaqueLayer"), Description("是否使用透明,默认为True")] |
108 | * 一般用于说明你自定义控件的属性(Property)。 |
109 | * Category用于说明该属性属于哪个分类,Description自然就是该属性的含义解释。 |
110 | */ |
111 | [Category("MyOpaqueLayer"), Description("是否使用透明,默认为True")] |
112 | public bool TransparentBG |
113 | { |
114 | get |
115 | { |
116 | return _transparentBG; |
117 | } |
118 | set |
119 | { |
120 | _transparentBG = value; |
121 | this.Invalidate(); |
122 | } |
123 | } |
124 | |
125 | [Category("MyOpaqueLayer"), Description("设置透明度")] |
126 | public int Alpha |
127 | { |
128 | get |
129 | { |
130 | return _alpha; |
131 | } |
132 | set |
133 | { |
134 | _alpha = value; |
135 | this.Invalidate(); |
136 | } |
137 | } |
138 | } |
139 | } |
OpaqueCommand的方法:ShowOpaqueLayer(显示遮罩层)和HideOpaqueLayer(隐藏遮罩层)
1 | using System; |
2 | using System.Windows.Forms; |
3 | |
4 | namespace 加载中 |
5 | { |
6 | class OpaqueCommand |
7 | { |
8 | private MyOpaqueLayer.MyOpaqueLayer m_OpaqueLayer = null;//半透明蒙板层 |
9 | |
10 | /// <summary> |
11 | /// 显示遮罩层 |
12 | /// </summary> |
13 | /// <param name="control">控件</param> |
14 | /// <param name="alpha">透明度</param> |
15 | /// <param name="isShowLoadingImage">是否显示图标</param> |
16 | public void ShowOpaqueLayer(Control control, int alpha, bool isShowLoadingImage) |
17 | { |
18 | try |
19 | { |
20 | if (this.m_OpaqueLayer == null) |
21 | { |
22 | this.m_OpaqueLayer = new MyOpaqueLayer.MyOpaqueLayer(alpha, isShowLoadingImage); |
23 | control.Controls.Add(this.m_OpaqueLayer); |
24 | this.m_OpaqueLayer.Dock = DockStyle.Fill; |
25 | this.m_OpaqueLayer.BringToFront(); |
26 | } |
27 | this.m_OpaqueLayer.Enabled = true; |
28 | this.m_OpaqueLayer.Visible = true; |
29 | } |
30 | catch { } |
31 | } |
32 | |
33 | /// <summary> |
34 | /// 隐藏遮罩层 |
35 | /// </summary> |
36 | public void HideOpaqueLayer() |
37 | { |
38 | try |
39 | { |
40 | if (this.m_OpaqueLayer != null) |
41 | { |
42 | this.m_OpaqueLayer.Visible = false; |
43 | this.m_OpaqueLayer.Enabled = false; |
44 | } |
45 | } |
46 | catch(Exception ex) |
47 | { |
48 | //MessageBox.Show(ex.Message); |
49 | } |
50 | } |
51 | } |
52 | } |
自定义半透明遮罩层源码下载:
files.cnblogs.com/JuneZhang/%E8%87%AA%E5%AE%9A%E4%B9%89%E5%8D%8A%E9%80%8F%E6%98%8E%E9%81%AE%E7%BD%A9%E5%B1%82-%E6%BA%90%E7%A0%81.rar
C# Winform 实现自定义半透明loading加载遮罩层的更多相关文章
- ajax异步加载遮罩层特效
<!doctype html> <html> <head> <title>遮罩层(正在加载中)</title> <meta chars ...
- echarts 设置数据加载遮罩层
//显示加载数据的loading chart.showLoading({ text: "图表数据正在努力加载...", x ...
- vue2 自定义全局组件(Loading加载效果)
vue2 自定义全局组件(Loading加载效果) github地址: https://github.com/ccyinghua/custom-global-component 一.构建项目 vue ...
- HTML5 五彩圆环Loading加载动画实现教程
原文:HTML5 五彩圆环Loading加载动画实现教程 今天我们要来介绍一款效果很特别的HTML5 Loading加载动画,不像其他的Loading动画,这款Loading动画颜色很丰富,并且在转圈 ...
- 使用Dialog实现全局Loading加载框
Dialog实现全局Loading加载框 很多人在实现Loading加载框的时候,都是在当前的页面隐藏一个Loading布局,需要加载的时候,显示出来,加载完再隐藏 使用Dialog实现Loading ...
- vue+elementUI+axios实现的全局loading加载动画
在项目中,很多时候都需要loading加载动画来缓解用户的焦虑等待,比如说,我打开了一个页面,而这个页面有很多接口请求,但浏览器的请求并发数就那么几个,再加上如果网速不行的话,那么这时候,用户很可能就 ...
- WPF 客户端浏览器 添加Loading加载进度
在windows开发界面时,使用浏览器来请求和显示网页内容,是比较常见的. 但是在请求网页内容时,因网速或者前端功能复杂加载较慢,亦或者加载时遇到各种问题,如空白/黑屏/加载不完整/证书问题等. 因此 ...
- QT自定义控件系列(二) --- Loading加载动画控件
本系列主要使用Qt painter来实现一些基础控件.主要是对平时自行编写的一些自定义控件的总结. 为了简洁.低耦合,我们尽量不使用图片,qrc,ui等文件,而只使用c++的.h和.cpp文件. 由于 ...
- JVM自定义类加载器加载指定classPath下的所有class及jar
一.JVM中的类加载器类型 从Java虚拟机的角度讲,只有两种不同的类加载器:启动类加载器和其他类加载器. 1.启动类加载器(Boostrap ClassLoader):这个是由c++实现的,主要负责 ...
随机推荐
- MVC Filter自定义验证(拦截)
namespace QS.Web.Extensions { /// <summary> /// 验证session.权限 状态 /// </summary> [Attribut ...
- hpple 简单使用
最近项目使用到hpple,简单说一下使用方式,做做笔记 let responseData = response as! NSData let utf8Html = responseData.strin ...
- LM2596扩流
- 伪Base16的构思和实现
最近看见了一个迅雷地址,发现将其转换为普通链接的工具后,发现所谓专用地址地址就是原地址前加一个表示迅雷的前缀,后进行Base64编码.查阅Base64编码过程后,突发奇想:能否做一个Base16算法? ...
- autoplay media studio couldn't load
AutoPlay Media Studio 7 (English version) is installed on target machine. Following error occurred w ...
- 深度优化LNMP之PHP (转)
深度优化LNMP之PHP PHP缓存加速介绍 1.操作码介绍及缓存原理 当客户端请求一个php程序时,服务器的PHP引擎会解析该PHP程序,并将其编译为特定的操作码文件(Operate ...
- SQL Proc(存储过程)/tran(事物)
存储过程好比C#方法 1.事物写在过程里面,直接调用存储过程 1.1没有参数的过程 /*transaction事物,procedure存储过程*/ create proc CopyTable_1_10 ...
- jquery tab mouseover 特效
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- React组件二
<script type="text/babel"> <!-- this.props.children表示读取组件的所有子节点-->var Zu=React ...
- mysqli 取出数据库中某表的表头和内容
需求如题 取出数据库中某表的表头和内容,并显示该表的行数和列数 <?php //显示表内容的函数 function showTable($tableName){ //连接数据库 $mysqli= ...