Excel VBA 窗体之去除窗体关闭按钮 实现代码

时间:2023-03-04 12:47:28 

VBA的窗体缺少一般窗体的很多属性,不想许多语言窗体那样可以自由的设置窗体的样式,就连其默认的关闭按钮也不能设置为不显示,一般的处理方法是在窗体的关闭事件中添加代码来阻止窗体的关闭。那还不如就直接运用代码来把他去除掉(如图)。

Excel 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 窗体之去除窗体关闭按钮 实现代码的下载地址:


     

标签:Excel,VBA,窗体,之,去除,关闭,按钮,实现,代码,VBA
0
投稿

猜你喜欢

  • WPS应用技巧—分秒提取一万个文件名

    2022-07-31 20:42:46
  • WPS怎么双面打印?WPS双面打印方法

    2022-12-26 17:56:20
  • QQ云输入法可以在各种页面里面输入吗

    2023-01-09 14:39:20
  • 升级Win10更新四月版17134.48遭遇黑屏的解决方法

    2022-03-01 01:29:15
  • 在安装win10预览版9879时卡在进度18%的解决方法

    2023-07-18 10:44:17
  • 金山wps的云文档怎么删除文档

    2023-12-02 12:46:58
  • win8.1系统安装程序提示错误0×80004005解决方法

    2022-12-19 20:02:39
  • PPT演示技巧—让文字段落变得更整齐

    2022-07-04 18:32:24
  • 如何自己重装系统Win10正版系统?

    2023-08-29 12:32:33
  • 如何把pdf快速有效转换成word的图文教程

    2022-11-21 22:43:05
  • Win10 1909夜间模式怎么设置?Win10 1909夜间模式设置教程

    2022-12-02 04:58:38
  • 免费提供会员的 Apple Music,为什么在国内很难普及?

    2023-05-14 15:31:06
  • 外星人电脑如何升级Win11?外星人电脑怎么更新系统Win11?

    2022-06-04 20:14:31
  • Win10如何禁用应用商店推广功能?Win10禁用应用商店推广功能的方法

    2023-01-15 19:51:56
  • 宝德笔记本电脑重装win7系统教程

    2022-03-03 15:11:45
  • 告诉你怎么还原电脑系统

    2022-04-19 13:11:10
  • ​电脑版wps文档中的水印显示不全怎么办

    2023-07-24 11:42:45
  • WPS文字编辑器怎么编辑图片

    2023-05-18 06:23:18
  • win7系统开机黑屏提示ntoskrnl.exe文件丢失如何解决?

    2022-09-16 03:52:57
  • 51模拟器中摇一摇功能如何使用?51模拟器中摇一摇功能使用教程

    2023-10-31 14:42:33
  • asp之家 电脑教程 m.aspxhome.com