打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
VBA 窗体之去除窗体关闭按钮

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

 

附件下载:

点击链接从百度网盘下载

  

操作如下:

  • 在Excel 的VBE窗口中插入一个用户窗体,将其命名为 frmNoCloseIcon。然后再添加一个模块。在窗体和模块中添加后面所列代码。
  • 在工作薄中的任意工作表中添加一窗体按钮控件,将指定其 设置宏 为 btnShowfrmMaxMin_Click。其供示范之用.

 

具体代码:

"mdClose" 模块代码

Sub btnShowfrmMaxMin_Click()    frmNoCloseIcon.ShowEnd 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 MeEnd SubPrivate Sub btnReset_Click()    '取得窗口样式位    FIstype = GetWindowLong(FHwnd, GWL_STYLE)    '窗体样式位: 原样式和系统菜单    FIstype = FIstype Or WS_SYSMENU    '重设窗体样式位    SetWindowLong FHwnd, GWL_STYLE, FIstype    '重绘窗体标题栏    DrawMenuBar FHwndEnd 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 FHwndEnd Sub
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
VBA实用小程序04:在用户窗体标题栏添加最大化和最小化按钮
定制化窗体之放大镜
VB入门技巧N例(6)
Excel黑科技 vba中用Inputbox对话框接受输入密码时显示为*
发一个掏钱还不一定买得到, 真正完美的SHBrowseForFolder浏览文件夹方法
获取QQ群用户列表
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服