Microsoft KB Archive/191670

= How To Suppress Default Pop-up Menu When You Use Custom Menu =

Article ID: 191670

Article Last Modified on 7/13/2004

-

APPLIES TO


 * Microsoft Visual Basic 5.0 Learning Edition
 * Microsoft Visual Basic 6.0 Learning Edition
 * Microsoft Visual Basic 5.0 Professional Edition
 * Microsoft Visual Basic 6.0 Professional Edition
 * Microsoft Visual Basic 5.0 Enterprise Edition
 * Microsoft Visual Basic 6.0 Enterprise Edition

-



This article was previously published under Q191670



SUMMARY
Some Visual Basic controls, such as the TextBox control, have a default pop-up menu that automatically appears when you right-click on the control. This article demonstrates one way to disable this default pop-up menu in order that a custom pop-up menu is displayed.



MORE INFORMATION
When you right-click on the TextBox control, its default pop-up menu is displayed. Visual Basic does not have a property or any other built-in mechanism that directly disables this feature. However, setting the control's Enabled property to False prevents the menu from being displayed, although this allows the user to see that the control is disabled.

One workaround is to use the Windows LockWindowUpdate application programming interface (API) in conjunction with the Enabled property. The LockWindowUpdate function disables or re- enables drawing in a specified window. After the operation is complete, the control is re-enabled, and the LockWindowUpdate API is called a second time to resume drawing of the control.

Steps to Create Sample Project
 Start a new Standard EXE project in Visual Basic. Form1 is created by default. Add a TextBox control to Form1. Click Menu Editor from the Tools menu, and create a menu named mnuPopUp on Form1. Clear the Visible check box, and add items such as the following:

Caption: Name

File: mnuPopup

New: mnuOne

Open: MnuTwo

  Add the following code to the code window of Form1: Private Declare Function LockWindowUpdate Lib "user32" _ (ByVal hwndLock As Long) As Long

Private Sub mnuOne_Click Text1.Text = "Menu One was clicked" End Sub

Private Sub mnuTwo_Click Text1.Text = "Menu two was clicked" End Sub

Private Sub Text1_MouseDown(Button As Integer, Shift As Integer, _        X As Single, Y As Single)

If Button = vbRightButton Then ' Avoid the 'disabled' gray text by locking updates LockWindowUpdate Text1.hWnd

' A disabled TextBox will not display a context menu Text1.Enabled = False

' Give the previous line time to complete DoEvents

' Display our own context menu PopupMenu mnuPopup

' Enable the control again Text1.Enabled = True

' Unlock updates LockWindowUpdate 0& End If     End Sub

 Save and run the project. Right-click on Text1. Only the custom menu is displayed. The standard editing menu is not shown.</ol>

Alternatively, you can subclass the control to supress the default pop-up menu. Through subclassing, you can monitor for the appropriate mouse messages and handle them accordingly. See the "References" section to follow for more information on this topic.

<div class="references_section">