QueryClose Event

It is not possible to remove the "x" from the top right corner although you can disable it.
Whether you display a prompt to the user or not is up to you.
Using the QueryClose event allows you to intercept the message to close the userform before it is actually closed.
If you set the Cancel paramater to True, then the userform will not be closed.
This means the userform has been closed by the user pressing the top right x.

Private Sub UserForm_QueryClose(Cancel as integer, CloseMode as integer) 
   If CloseMode = vbQueryClose.vbFormControlMenu Then
      cmdCancel.SetFocus
      MsgBox "Cannot close the userform !!"
      Cancel = True
   End If
End Sub

This means the userform has been closed by code

If CloseMode = vbQueryClose.vbFormCode Then 
   Cancel = True
End If

Removing the Close button

'userform window
Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" _
   (ByVal lpClassName As String, ByVal lpWindowName As String) As Long

'current window state
Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" _
   (ByVal hwnd As Long, ByVal nIndex As Long) As Long

'new window style
Private Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" _
   (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long

Const GWL_STYLE = -16
Const WS_SYSMENU = &H80000

Public Sub RemoveCloseButton(oUserForm As MSForms.UserForm)
Dim hwnd As Long
Dim lStyle As Long

   hwnd = FindWindow("ThunderXFrame"), oUserForm.Caption)

   lStyle = GetWindowLong(hwnd, GWL_STYE)
   SetWindowLong hwnd, GWL_STYLE, (lStyle And Not WS_SYSMENU)
End Sub

© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext