请问高手,如何在VBA代码中最小化当前窗体

请问高手,如何在VBA代码中最小化当前窗体?一般最小化是自己去点击,我希望用代码去实现。下面这些代码只是能让窗体出现最小化、最大化按钮,但如何写代码执行某窗体最小化我却不... 请问高手,如何在VBA代码中最小化当前窗体?一般最小化是自己去点击,我希望用代码去实现。
下面这些代码只是能让窗体出现最小化、最大化按钮,但如何写代码执行某窗体最小化我却不知道
'这以下的代码放在窗体代码的顶部
'注意下面还有放在底部的代码
Option Explicit
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
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 '(最大化)
'这以上的代码放在窗体代码的顶部

'这以下的代码放在窗体代码的底部
'窗体UserForm的初始化
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
'这以上的代码放在窗体代码的底部
展开
 我来答
qiuduhan
2012-06-09 · TA获得超过112个赞
知道小有建树答主
回答量:118
采纳率:100%
帮助的人:89.2万
展开全部
DoCmd.Minimize 最小化当前窗口
可以不用调用API函数,最小化,最大化等窗体的所有操作都可以用DOCMD的对象的各种方法来实现的。而且语句都很简单。
更多追问追答
追问
但我照此写成代码,则运行错误。我的代码如下:

Private Sub CommandButton1_Click()
DoCmd.Minimize
End Sub
我是在VBA程序编辑器中。
您能写一个完整的VBA运行代码吗?是一段可运行的。我提高奖分
追答
我运行了没有错了  把你的错误描述抄下来看看。
docmd对象时access对象。如果是excel,你用录制宏来记录一下最小化操作的代码,自己看一下吧。
ActiveWindow.WindowState = xlMinimized
这个是excel最小化的代码,它实际上是用的属性来设置的。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式