Excel VBA 窗体之去除窗体关闭按钮 实现代码
发布时间:2023-03-04 12:47:28
VBA的窗体缺少一般窗体的很多属性,不想许多语言窗体那样可以自由的设置窗体的样式,就连其默认的关闭按钮也不能设置为不显示,一般的处理方法是在窗体的关闭事件中添加代码来阻止窗体的关闭。那还不如就直接运用代码来把他去除掉(如图)。
附件下载:
操作如下:
◾在Excel的VBE窗口中插入一个用户窗体,将其命名为frmNoCloseIcon。然后再添加一个模块。在窗体和模块中添加后面所列代码。
◾在工作薄中的任意工作表中添加一窗体按钮控件,将指定其设置宏为btnShowfrmMaxMin_Click。其供示范之用。
具体代码:
"mdClose"模块代码
Sub btnShowfrmMaxMin_Click()
frmNoCloseIcon.Show
End Sub
"frmNoCloseIcon" 窗体代码
'****************************************
'---此模块演示了去除窗体关闭按钮---
'****************************************
Option Explicit
'以下声明API函数
#If Win64 Then '64位
Private Declare PtrSafe Function FindWindow _
Lib "user32" _
Alias "FindWindowA" ( _
ByVal lpClassName As String, _
ByVal lpWindowName As String) _
As LongPtr
Private Declare PtrSafe Function GetWindowLong _
Lib "user32" _
Alias "GetWindowLongPtrA" ( _
ByVal hwnd As LongPtr, _
ByVal nIndex As Long) _
As LongPtr
Private Declare PtrSafe Function SetWindowLong _
Lib "user32" _
Alias "SetWindowLongPtrA" ( _
ByVal hwnd As LongPtr, _
ByVal nIndex As Long, _
ByVal dwNewLong As LongPtr) _
As LongPtr
Private Declare PtrSafe Function DrawMenuBar _
Lib "user32"( _
ByVal hwnd As LongPtr) _
As Long
#Else '32位
'查找窗口
Private Declare Function FindWindow _
Lib "User32" _
Alias "FindWindowA" ( _
ByVal lpClassName As String, _
ByVal lpWindowName As String) _
As Long
'取得窗口样式位
Private Declare Function GetWindowLong _
Lib "User32" _
Alias "GetWindowLongA" ( _
ByVal Hwnd As Long, _
ByVal nIndex As Long) _
As Long
'设置窗口样式位
Private Declare Function SetWindowLong _
Lib "User32" _
Alias "SetWindowLongA" ( _
ByVal Hwnd As Long, _
ByVal nIndex As Long, _
ByVal dwNewLong As Long) _
As Long
'重绘窗体标题栏
Private Declare Function DrawMenuBar _
Lib "User32" ( _
ByVal Hwnd As Long) _
As Long
#End If
#If Win64 Then '64位
Private FHwnd As LongPtr
Private FIstype As LongPtr
#Else
Private FHwnd As Long
Private FIstype As Long
#End If
'以下定义常数
Private Const GWL_STYLE = (-16) '窗口样式
Private Const WS_SYSMENU = &H80000 '系统菜单
Private Sub btnClose_Click()
Unload Me
End Sub
Private Sub btnReset_Click()
'取得窗口样式位
FIstype = GetWindowLong(FHwnd, GWL_STYLE)
'窗体样式位: 原样式和系统菜单
FIstype = FIstype Or WS_SYSMENU
'重设窗体样式位
SetWindowLong FHwnd, GWL_STYLE, FIstype
'重绘窗体标题栏
DrawMenuBar FHwnd
End Sub
'**************************************
'---------------主程序-----------------
'**************************************
Private Sub UserForm_Initialize()
'查找窗口句柄
FHwnd = FindWindow("ThunderDFrame", Me.Caption)
'取得窗口样式位
FIstype = GetWindowLong(FHwnd, GWL_STYLE)
'窗体样式位: 原样式和无系统菜单
FIstype = FIstype And Not WS_SYSMENU
'重设窗体样式位
SetWindowLong FHwnd, GWL_STYLE, FIstype
'重绘窗体标题栏
DrawMenuBar FHwnd
End Sub
Excel VBA 窗体之去除窗体关闭按钮 实现代码的下载地址:


猜你喜欢
- Win7系统电脑怎么防止U盘中毒?有用户反映U盘在使用的时候经常中病毒,并且会传染到其他电脑上,那么如何防止U盘中病毒呢?下面请看具体操作方
- 找不到msvcr100.dll怎么办?我们在打开计算机程序时,系统提醒没法启动此程序,由于计算机中丢失MSVCR100.dll,试着重新安装
- 联想笔记本win7旗舰版忘记开机密码怎么办?遇到联想笔记本win7旗舰版忘记开机密码的问题,然后进不去系统,这种情况怎么办呢?下面小编就教下
- office2015怎么安装?小编带来了office2015安装步骤,之前微软已经发布了Office2015下载,不过很多朋友不知道怎么安装
- 腾讯新闻如何绑定分享平台?很多小伙伴都使用腾讯新闻查看资讯。最近有用户问小编,想要使用腾讯新闻绑定分享平台,但是不知道怎么操作。下面就是腾讯
- 如果我们在使用win10操作系统电脑的时候,需要重置自己的系统但是在在操作的过程中出现了win10系统重置卡在28%不动没反应的情况的话,小
- Win10玩红色警戒3总是卡顿怎么办?红色警戒3在Win10系统上运行时一直非常卡该如何解决?下面给家介绍Win10系统运行红色警戒3游戏的
- 最近有Win10系统用户反映,打开OneNote的时候,发现OneNote打不开并且出现提示“0x80070005”,用户不知道这是怎么回事
- WPS是我们办公时候经常使用的一款文字编辑软件,很多朋友可能需要在wps文字中插入一个超级链接链接链接到网页或者邮件或者程序,那么,wps超
- Word能够说是我们日常工作必不可少的办公软件之一,而我们在使用该软件的时候难免会遇到不熟悉的操作,例如有的用户不清楚如何为页眉添加双划线,
- 如何屏蔽iMessage广告?21世纪营销无处不在,稍不注意,就被营销了!iMessage做为苹果设备之间的一款利用网络传输的即时聊天工具也
- 相信有些小伙伴在使用电脑的时候或多或多都经历过系统还原或者重装的情况,因此也有一部分没经历的小伙伴好奇,win10系统还原之后会不会丢失数据
- 凭借引擎反应更快、内存占用更少及内置多项实用功能等亮点,火狐浏览器成功获得了不少国内PC用户的青睐。值得一提的是,用户还可以在火狐浏览器中对
- 最近有win7系统用户反映,电脑在360安全浏览器上想保存一张图片在电脑上,却弹出提示“您没有权限在此位置中保存文件,请与管理员联系以获得相
- 很多联想win10系统的用户不知道如何关闭防火墙。暂时关闭防火墙对计算机几乎没有影响。如果有第三方杀毒软件,你不用担心。你可以大胆地关掉它。
- Excel中经常需要引用一些自定义的公式,自定义的公式具体该如何引用呢?接下来是小编为大家带来的excel引用自定义公式的方法,供大家参考。
- win10系统如何设置待机时间?在win10系统中,可以通过设置待机时间来减少电量的损耗,但是很多用户都不清楚具体要怎么设置,一起来看下吧。
- 说明鼠标双击行或列边缘,自动调整行高或列宽到最适合的高度或宽度。演示
- win10双系统开机引导文件损坏了该如何修复呢?今天小编整理了相关的修复教程,过程很简单,接下来跟小编一起看看吧。Win10双系统修复开机引
- 怎么才能让ipad连接电脑,那可真是让人头疼了,那么在这里,就让我们来看看ipad连接电脑的方法吧在现下,苹果设备已经成了人人都喜欢的产品之