在网页中通过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加载遮罩层的更多相关文章

  1. ajax异步加载遮罩层特效

    <!doctype html> <html> <head> <title>遮罩层(正在加载中)</title> <meta chars ...

  2. echarts 设置数据加载遮罩层

    //显示加载数据的loading        chart.showLoading({            text: "图表数据正在努力加载...",            x ...

  3. vue2 自定义全局组件(Loading加载效果)

    vue2 自定义全局组件(Loading加载效果) github地址: https://github.com/ccyinghua/custom-global-component 一.构建项目 vue ...

  4. HTML5 五彩圆环Loading加载动画实现教程

    原文:HTML5 五彩圆环Loading加载动画实现教程 今天我们要来介绍一款效果很特别的HTML5 Loading加载动画,不像其他的Loading动画,这款Loading动画颜色很丰富,并且在转圈 ...

  5. 使用Dialog实现全局Loading加载框

    Dialog实现全局Loading加载框 很多人在实现Loading加载框的时候,都是在当前的页面隐藏一个Loading布局,需要加载的时候,显示出来,加载完再隐藏 使用Dialog实现Loading ...

  6. vue+elementUI+axios实现的全局loading加载动画

    在项目中,很多时候都需要loading加载动画来缓解用户的焦虑等待,比如说,我打开了一个页面,而这个页面有很多接口请求,但浏览器的请求并发数就那么几个,再加上如果网速不行的话,那么这时候,用户很可能就 ...

  7. WPF 客户端浏览器 添加Loading加载进度

    在windows开发界面时,使用浏览器来请求和显示网页内容,是比较常见的. 但是在请求网页内容时,因网速或者前端功能复杂加载较慢,亦或者加载时遇到各种问题,如空白/黑屏/加载不完整/证书问题等. 因此 ...

  8. QT自定义控件系列(二) --- Loading加载动画控件

    本系列主要使用Qt painter来实现一些基础控件.主要是对平时自行编写的一些自定义控件的总结. 为了简洁.低耦合,我们尽量不使用图片,qrc,ui等文件,而只使用c++的.h和.cpp文件. 由于 ...

  9. JVM自定义类加载器加载指定classPath下的所有class及jar

    一.JVM中的类加载器类型 从Java虚拟机的角度讲,只有两种不同的类加载器:启动类加载器和其他类加载器. 1.启动类加载器(Boostrap ClassLoader):这个是由c++实现的,主要负责 ...

随机推荐

  1. Opencv读取视频一闪而过情况分析

    在参加一个软件比赛需要用opencv对视频的处理,也碰到了一些问题. 最常见的就是视频一闪而过了,在网上查了好久都没解决, 最后重装在配置环境变量时发现的. 现在我来终结一下估计是比较全的了. 先说明 ...

  2. C#常用正则验证

    #region Protected Property protected Regex rLetters { get { return new Regex("[a-zA-Z]{1,}" ...

  3. 解决Android Studio启动速度慢的问题。避免每次启动Android Studio都要fetching Android sdk compoment information。

    Android Studio每次启动都要去fetching sdk,由于Android sdk 官网在大陆连不上,所以每次启动时界面都会停在那里很久. 解决办法就是设置取消每次fetching sdk ...

  4. oracle进制转换

    h2 { margin-top: 0.46cm; margin-bottom: 0.46cm; direction: ltr; line-height: 173%; text-align: justi ...

  5. H5之canvas简单入门

    <canvas></canvas>是html5出现的新标签,像所有的dom对象一样它有自己本身的属性.方法和事件,其中就有绘图的方法,js能够调用它来进行绘图 <canv ...

  6. eclipse中定位引用的源码

    如图,在eclipse中,我想看BaseContoller是怎么实现的,将鼠标放上去,按住Ctrl单击左键就行了

  7. (转 部分修改) IOS 手势密码(简单版)

    // // Created by wangtouwang on 15/4/7. // Copyright (c) 2015年 wangtouwang. All rights reserved. // ...

  8. 如何在Ubuntu上创建及管理LXC容器?

    将LXC安装到Ubuntu上 $ sudo apt-get install lxc 安装完毕之后,运行lxc-checkconifg工具,检查当前Linux内核支持LXC的情况.要是一切都已被启用,内 ...

  9. 移动web问题小结

    Meta标签: <meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalab ...

  10. Linq表连接大全(INNER JOIN、LEFT OUTER JOIN、RIGHT OUTER JOIN、FULL OUTER JOIN、CROSS JOIN)

    我们知道在SQL中一共有五种JOIN操作:INNER JOIN.LEFT OUTER JOIN.RIGHT OUTER JOIN.FULL OUTER JOIN.CROSS JOIN 1>先创建 ...