在网页中通过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 实现自定义半透明遮罩层介绍的更多相关文章

  1. C# Winform 实现自定义半透明loading加载遮罩层

    在网页中通过div+css实现半透明效果不难,今天我们看看一种在winfrom中实现的方法: 效果图如下,正常时: 显示遮罩层时: 自定义遮罩层控件的源码如下: View Row Code 1 usi ...

  2. iOS 自定义相机带拍摄区域边框及半透明遮罩层(含源码)

    开始时准备封装成ViewController的相机,但是在不改我相机控件源码的情况下,使用者很难自定义UI.于是想到将相机核心功能封装到View里,暴露出功能方法给外面调用,调用者只需将LFCamer ...

  3. jq 弹半透明遮罩层

    jquery制作点击按钮弹出遮罩半透明登陆窗口 // )[^>]*$|^#([\w-]+)$/,M=/^.[^:#\[\.,]*$/,ka=/\S/,$= /^(\s|\u00A0)+|(\s| ...

  4. 解决css3遮罩层挡住下面元素事件的方法

    比如大家常看到的鼠标移入图片中,会有一个挡住图片的黑色半透明遮罩层,上面还有文字介绍,这时候就会遇到该层遮挡住下面图片的跳转链接事件,这时候怎么办呢?有个简单的css3属性可以快速解决该问题:poin ...

  5. 【特效】手机端仿美团下拉菜单带遮罩层html+css+jquery

    写了一个手机端的下拉菜单,类似美团,用相对单位rem写的. 效果截图: 代码很简单,原理有点类似嵌套的选项卡,其中的难点在于弹出下拉菜单后,出现黑色半透明遮罩层,而且下层列表页面禁止滚动了.关键就是给 ...

  6. jQuery实现遮罩层

    1.1 背景半透明遮罩层样式 需要一个黑色(当然也可以其他)背景,且须设置为绝对定位,以下是项目中用到的css样式: /* 半透明的遮罩层 */ #overlay { background: #000 ...

  7. 移动端优化 && 清除移动端网站点击a标签时闪现的边框或遮罩层(CSS) && 移动端点击 && 文字不可选择

      在移动端网站,当你点击加了a标签的文字或图片时,该元素的周围会闪现一个蓝色的边框,在微信上的网站就是如此:而有的浏览器会闪现一个半透明遮罩层,比如移动端的Chrome浏览器,其实这些特效无非就是为 ...

  8. Winform应用程序实现通用遮罩层

    在WEB上,我们在需要进行大数据或复杂逻辑处理时,由于耗时较长,一般我们会在处理过程中的页面上显示一个半透明的遮罩层,上面放个图标或提示:正在处理中...等字样,这样用户体验就比较好了,然而如果在Wi ...

  9. Android自定义遮罩层设计

    在做网页设计时,前端设计人员会经常用到基于JS开发的遮罩层,并且背景半透明.这样的效果怎么样在Android上实现呢?这个实现并不困难,先来上效果图: <ignore_js_op> 201 ...

随机推荐

  1. NServiceBus入门:多个endpoint(Introduction to NServiceBus: Multiple endpoints)

    原文地址:https://docs.particular.net/tutorials/intro-to-nservicebus/3-multiple-endpoints/ 侵删. 目前为止,我们只是在 ...

  2. Android显示GIF动画 GifView

    android中显示gif动画原生态一般支持的不是很好,故找了一个开源的项目,现简单介绍如下: GifView 是一个为了解决android中现在没有直接显示gif的view,只能通过mediapla ...

  3. Linux /sbin/service脚本一个基本无影响的bug

    CentOS提供了一个启动服务的功能:service [service name] (start|stop|restart|...),此功能的执行脚本为/sbin/service. 今天看了下此脚本, ...

  4. iOS:quartz2D绘图小项目(涂鸦画板)

    介绍:学了quartz2D的绘图知识后,我根据它的一些功能制作了一个小项目:涂鸦画板. 功能:绘制各种图形,还可以选取相册上的照片做涂鸦,然后保存到相册中.其中,还包括功能有:颜色的选取.线宽的选取. ...

  5. Dos网络查看命令

    net use //ip/ipc$ " " /user:" " 建立IPC空链接 net use //ip/ipc$ "密码" /user: ...

  6. 在Spring Boot项目中使用Spock框架

    转载:https://www.jianshu.com/p/f1e354d382cd Spock框架是基于Groovy语言的测试框架,Groovy与Java具备良好的互操作性,因此可以在Spring B ...

  7. 算法笔记_113:算法集训之代码填空题集一(Java)

     目录 1 报数游戏 2 不连续处断开 3 猜数字游戏 4 串的反转 5 串中找数字 6 递归连续数 7 复制网站内容 8 股票的风险 9 基因牛的繁殖 10 括号的匹配   1 报数游戏 有n个孩子 ...

  8. 算法笔记_051:荷兰国旗问题(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 现有n个红白蓝三种不同颜色的小球,乱序排列在一起,请通过两两交换任意两个球,使得从左至右的球依次为红球.白球.蓝球.这个问题之所以叫荷兰国旗,是因为 ...

  9. 【SSH进阶之路】Struts基本原理 + 实现简单登录(二)

    上面博文,主要简单的介绍了一下SSH的基本概念,比較宏观,作为刚開始学习的人可以有一个总体上的认识,个人觉得对学习有非常好的辅助功能.它不不过一个"瞭望塔".更是检验是否真正掌握全 ...

  10. 【Linux】VMware上安装Linux操作系统

    Vmware上安装Linux系统 1. 文件菜单选择新建虚拟机 2. 选择经典类型安装,下一步. 3. 选择稍后安装操作系统,下一步. 4. 选择Linux系统,版本选择CentOS 64位. 给虚拟 ...