VBA to remove "Title Bar" (Minimise/Maximise/Spreadsheet Name/Close

surkdidat

Well-known Member
Joined
Oct 1, 2011
Messages
597
Office Version
  1. 365
Can someone help me with this please?!

I need code in my spreadsheet to stop users having access to the "title bar".

I have VBA written so there is a "close button" on my spreadsheet so the user closes the sheet (and saves automatically)

EDIT: I do not need the code to do anything else, as the window is set for a specific size, and resizes dependant on what the user needs to input. The scrollbar, tabs, row and column heading, formula bar are already hidden.
 
Last edited:

Excel Facts

Excel Joke
Why can't spreadsheets drive cars? They crash too often!
.
To minimize confusion, what are you defining as the "title bar" ?
 
Upvote 0
If you copy/paste the following code into the UserForm's code window, the user form will be displayed without a titlebar or surrounding borders (make sure you leave yourself a way to dismiss the UserForm while testing this)...
Code:
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

Dim hWndForm As Long

Private Sub UserForm_Initialize()
   Dim Style As Long, Menu As Long
   hWndForm = FindWindow("ThunderDFrame", Me.Caption)
   Style = GetWindowLong(hWndForm, &HFFF0)
   Style = Style And Not &HC00000
   SetWindowLong hWndForm, &HFFF0, Style
   DrawMenuBar hWndForm
End Sub
 
Last edited:
Upvote 0
Thank you for this. Apologies been offline for a week, will try later!

If you copy/paste the following code into the UserForm's code window, the user form will be displayed without a titlebar or surrounding borders (make sure you leave yourself a way to dismiss the UserForm while testing this)...
Code:
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

Dim hWndForm As Long

Private Sub UserForm_Initialize()
   Dim Style As Long, Menu As Long
   hWndForm = FindWindow("ThunderDFrame", Me.Caption)
   Style = GetWindowLong(hWndForm, &HFFF0)
   Style = Style And Not &HC00000
   SetWindowLong hWndForm, &HFFF0, Style
   DrawMenuBar hWndForm
End Sub
 
Upvote 0
Apologies - to clarify, do both bits of code go into UserForm? What does the "user32" relate to? Is this the worksheet name?
Have tried as worksheet name, but it does not remove title bar?
Wll "Alt+F11"still allow me back in to editor with this code please?
 
Upvote 0
Apologies - to clarify, do both bits of code go into UserForm? What does the "user32" relate to? Is this the worksheet name?
Have tried as worksheet name, but it does not remove title bar?
Wll "Alt+F11"still allow me back in to editor with this code please?
Just copy/paste the code exactly as I wrote it... don't change any part of it. And all of the code goes in the UserForm's code window. The first four Declare statements create a link to some of the underlying Windows API (Application Programming Interface) functions which are needed to affect the display of Windows components.
 
Upvote 0
I have added this code into UserForm. I have saved and closed, and reopened. Still bring up Spreadsheet Go into editor, and run code. Just brings up grey box?

Just copy/paste the code exactly as I wrote it... don't change any part of it. And all of the code goes in the UserForm's code window. The first four Declare statements create a link to some of the underlying Windows API (Application Programming Interface) functions which are needed to affect the display of Windows components.
 
Upvote 0
I have added this code into UserForm. I have saved and closed, and reopened. Still bring up Spreadsheet Go into editor, and run code. Just brings up grey box?

Do you have a userform in your workbook Project ? If so, what's the name of the UserForm ?

From the description you have given us so far, I think, you are referring to the title bar of the excel application not to that of a UserForm in which case the code that Rick kindly suggested won't work .
 
Upvote 0
.
Paste in a Routine Module :

Code:
Option Explicit


Sub hide_menu()


With Worksheets("Sheet1")


    With ActiveWindow
        .DisplayHorizontalScrollBar = False
        .DisplayVerticalScrollBar = False
    End With
    With Application
        .DisplayFullScreen = True
        .DisplayFormulaBar = False
        .DisplayStatusBar = False
    End With
    With Application
    
        .CommandBars("Full Screen").Visible = False
        .CommandBars("Worksheet Menu Bar").Enabled = False
        .CommandBars("Standard").Visible = False
        .CommandBars("Formatting").Visible = False
    End With
End With
End Sub


Sub unhide_menu()


With Worksheets("Sheet1")


    With ActiveWindow
        .DisplayHorizontalScrollBar = True
        .DisplayVerticalScrollBar = True
    End With
    With Application
        .DisplayFullScreen = False
        .DisplayFormulaBar = True
        .DisplayStatusBar = True
    End With
    With Application
        .CommandBars("Full Screen").Visible = True
        .CommandBars("Worksheet Menu Bar").Enabled = True
        .CommandBars("Standard").Visible = True
        .CommandBars("Formatting").Visible = True
    End With
End With
End Sub



Paste in ThisWorkbook module :

Code:
Private Sub Workbook_BeforeClose(Cancel As Boolean)
    Call unhide_menu
End Sub


Private Sub Workbook_Open()
    Call hide_menu
End Sub
 
Upvote 0

Forum statistics

Threads
1,225,750
Messages
6,186,805
Members
453,373
Latest member
Ereha

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top