VBA窗体最大化最小化按钮实现

打开excel,找到开发工具 ,然后点击 Visual Basic 进入代码编辑器窗口:
在这里插入图片描述
点击插入>>用户窗体,如下图所示:
在这里插入图片描述
如果此时运行,得到的效果如下所示,是没有最大化和最小化窗口的:
在这里插入图片描述
下面我们就来添加最大化最小化功能的实现。
双击窗体,进入代码编辑界面,输入以下代码:

Option Explicit

Private Declare PtrSafe Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hWnd As Long, ByVal nIndex As Long) As Long
Private Declare PtrSafe Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
Private Declare PtrSafe Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hWnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
Private Const GWL_STYLE = (-16)
Private Const WS_THICKFRAME As Long = &H40000 '(恢复大小)
Private Const WS_MINIMIZEBOX As Long = &H20000 '(最小化)
Private Const WS_MAXIMIZEBOX As Long = &H10000 '(最大化)
Private Sub UserForm_Initialize()
   Dim hWndForm As Long
   Dim IStyle As Long
   hWndForm = FindWindow("ThunderDFrame", Me.Caption)
   IStyle = GetWindowLong(hWndForm, GWL_STYLE)
   IStyle = IStyle Or WS_THICKFRAME '还原
   IStyle = IStyle Or WS_MINIMIZEBOX '最小化
   IStyle = IStyle Or WS_MAXIMIZEBOX '最大化
   SetWindowLong hWndForm, GWL_STYLE, IStyle
End Sub

将鼠标置于Sub函数内部,按F5按键运行,得到如下效果:
在这里插入图片描述

这里需要说明的是,以上代码支持在64位操作系统运行,如果是32位系统,在导入库的时候,应使用下面一段代码:

Private Declare  Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hWnd As Long, ByVal nIndex As Long) As Long
Private Declare  Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
Private Declare  Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hWnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long

与前面一段代码相比,发现唯一的区别在于,Declare后面少了PtrSafe,其原因是:Microsoft 提供了一个 Win32API.txt 文件,其中包含 1,500 个 Declare 语句以及一个用于剪切所需 Declare 语句并将其粘贴到您的代码中的工具。不过,这些语句适用于 32 位系统,必须使用下文讨论的信息将其转换为 64 位。现有 Declare 语句在 64 位 VBA 中不会进行编译,直到使用 PtrSafe 属性将它们标记为对 64 位安全。
具体可参阅MicroSoft Office 官方资料:32 位和 64 位版本的 Office 2010 之间的兼容性

  • 9
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
VBA编程中隐藏最大化最小化窗口按钮,可以使用在表单的 Initialize 事件中使用以下代码: Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" _ (ByVal lpClassName As String, _ ByVal lpWindowName As String) As Long Private Declare Function GetSystemMenu Lib "user32" _ (ByVal hwnd As Long, _ ByVal bRevert As Long) As Long Private Declare Function RemoveMenu Lib "user32" _ (ByVal hMenu As Long, _ ByVal nPosition As Long, _ ByVal wFlags As Long) As Long Private Const MF_BYPOSITION = &H400& Private Const MF_REMOVE = &H1000& Private Sub UserForm_Initialize() Dim hwnd As Long Dim hMenu As Long hwnd = FindWindow("ThunderDFrame", Me.Caption) hMenu = GetSystemMenu(hwnd, False) Call RemoveMenu(hMenu, 6, MF_BYPOSITION) Call RemoveMenu(hMenu, 5, MF_BYPOSITION) End Sub 解释下代码的具体含义: 1. FindWindow: 它在Windows中寻找具有指定的类名和窗口名的顶层窗口。 2. GetSystemMenu:获取窗口菜单句柄。例如,这能用来得到窗口的“控制”菜单,我们可以向其中加入一些自定义的菜单项。 3. RemoveMenu: 删除具有指定位置和标志的菜单项,该函数要求我们给它提供菜单句柄、要删除的位置以及标志。 菜单项位置可以通过Windows API文档来确定,但是,Windows不总是一致的,不同的操作系统版本也许就不同。 上述代码将最大化最小化按钮在窗口的菜单中移除。有了这些代码,你可以在你自己的VBA项目中应用,也可以改写代码应用到Excel、Access 或者 PowerPoint 等其他 VBA项目中。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值