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++实现的,主要负责 ...
随机推荐
- ThinkPad E40无线网卡驱动安装 FOR CENTOS6.3
1.看一下咱们用的本本的无线是咋子无线网卡,如下: [root@liaohg Downloads]# lspci | grep Wireless 03:00.0 Network controller: ...
- 学习笔记_第一个strut程序_之中文乱码,过滤器解决方案及过程总结
1. 第一次碰到加过滤器的过程,就是在学习struct1的时候,中文乱码 几个需要注意的关键字 2.什么叫package 所谓package就是打包的意思,就是说以下程序都是处于这个包内,所以一开始 ...
- JavaScript高级程序设计(四): 关键字With的使用
一.关键字with 1.含义 with 语句可以方便地用来引用某个特定对象中已有的属性,但是不能用来给对象添加属性.要给对象创建新的属性,必须明确地引用该对象. 简单的说,with为一个或一 ...
- IOS中的NSTimer定时器详解
/* 在IOS中有多种定时器,这里我对NSTimer定时器做了一个简单的介绍.如果你是小白,你可能会从这篇文章中学习到一些知识,如果你是大牛,请别吝啬你的评论,指出我的不足,你的质疑是对我最大的帮助. ...
- linux 列出安装包内的文件
rpm系列: 1. 文件类型 rpm -qpl xxx.rpm2. 已安装文件 rpm -ql packagename debain系列: dpkg -c xxxx.deb
- [002] The Perks of Being a Wallflower - 读后记
The Perks of Being a Wallflower 今天(2015年10月30日 18:26:17)读完"The Perks of Being a Wallflower" ...
- python-MySQLdb-练习
看完视频,自己练习一遍. 还是遇到问题,不过最终还是解决了.贴上完成的代码. CREATE TABLE `NewTable` ( `acctid` int(11) NOT NULL AUTO_INCR ...
- IE6 png 透明 (三种解决方法)
FF和IE7已经直接支持透明的png图了,下面这个主要是解决IE6下透明PNG图片有灰底的 ====================================================== ...
- DOM 文档对象模型
document 对象(作为对象),是 DOM 的核心作用:对内容,属性,样式等操作属性:title:设置/返回当前文档的标题url:返回当前文档的 urlinnerHTML:获取指定对象内的内容bg ...
- Yii 权限分级式访问控制实现(非RBAC法)
以下由我们在信易网络公司开发项目的时候终结出的一些经验 主要参考资料:yii官网http://www.yiiframework.com/wiki/60/yii framework 提供了2套权限访问系 ...