您的位置:首页 > 其它

屏蔽关闭和最大化按钮,只保留最小化按钮

2006-01-04 20:01 295 查看
'屏蔽关闭和最大化按钮,只保留最小化按钮

Option Explicit
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_BYCOMMAND = &H0&
Private Const SC_CLOSE = &HF060&

'--------------------------------------

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 Const GWL_STYLE = (-16)
Private Const WS_MAXIMIZEBOX = &H10000
'Private Const WS_MINIMIZEBOX = &H20000

Private Sub Form_Load()
Dim MyMenu As Long
MyMenu = GetSystemMenu(Me.hwnd, 0) '得到系统菜单的句柄,Me.hwnd表示当前窗体的句柄
RemoveMenu MyMenu, SC_CLOSE, MF_BYCOMMAND '屏蔽关闭按钮

'下面代码屏蔽最大化按钮
Dim mdiWnd As Long
mdiWnd = GetWindowLong(Me.hwnd, GWL_STYLE)

mdiWnd = mdiWnd And Not (WS_MAXIMIZEBOX)

mdiWnd = SetWindowLong(Me.hwnd, GWL_STYLE, mdiWnd)
End Sub
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: