Solved

Menu Editor Question

Posted on 2004-10-18
6
405 Views
Last Modified: 2010-07-27
I am trying to build a popup menu, using menu editor, I have:

                  Caption          Name            Index
Qnty:             Qnty            mnu1             0
......1               1               mnu1            1
......2               2               mnu1            2
......3               3               mnu1            3


I am getting error when I want to save above setting.  The error is:  "Menu control elements must be contiguous and with the same submenu".  This is follow up work from question at:

http://www.experts-exchange.com/Programming/Programming_Languages/Visual_Basic/Q_21164566.html

Also, I don't want this menu to show up on the top of the form; rather to pop up on a right-click on a control (see above link for codes I have).

Thanks,  
0
Comment
Question by:Mike Eghtebas
  • 3
  • 2
6 Comments
 
LVL 17

Accepted Solution

by:
zzzzzooc earned 400 total points
ID: 12340732
You can't index a menu and it's sub-menus. You have to give the menu one name without an index, then use the same names for the sub-menus and index those.

Example:
-------------------------------------------------------
                 Caption          Name            Index
Qnty:             Qnty            mnu1            
......1               1               mnu1_            0
......2               2               mnu1_            1
......3               3               mnu1_            2
0
 

Assisted Solution

by:Sergio_A
Sergio_A earned 100 total points
ID: 12341550
Well... first of all, you only can display a popup menu over a MDIForm or a simple Form.
This is the method you must Use:

Private Sub Form_MouseDown(Button As Integer, Shift As Integer, X As Single, Y As Single)
    Call Me.PopupMenu(menuname, flags, x, y, boldcommand)
End Sub

a simple trick you can use is putting this method - replacing "Me" with the name of the current Form - in a mouseDown command of the control where you can show the submenu. Then, you can set the X,Y arguments of the method with the desired coordinates (eg. the Control left and top values)

The problem with your code refering the menu is that you can't put the same name to the submenu-subitems as the main menu. Change this code to this:

                  Caption          Name            Index
Qnty:             Qnty            mnu0            
......1               1               mnu1            1
......2               2               mnu1            2
......3               3               mnu1            3


if Qnty is the only menu with the "mnu0" name, dosn't have to have index. It's same as an control array.

Let me know your results.... Cya
0
 
LVL 34

Author Comment

by:Mike Eghtebas
ID: 12347113
Hi Sergio,

I appreciate your good answer.  The solution from zzzzzooc was first correct answer nevertheless.  For additional info you have included in:

PopupMenu(menuname, flags, x, y, boldcommand)

I split the points (100 out of 500) for you.  My understanding from this code is:

flags:?    <-- menue title?
x, y: Are these parameters to open the menu at a desired location?
boldcommand: Does this constant make menu captions appear bold?
0
Free Tool: IP Lookup

Get more info about an IP address or domain name, such as organization, abuse contacts and geolocation.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

 

Expert Comment

by:Sergio_A
ID: 12358180
Well, those flags are optional, so you can put only the things you are interested in, and yes, X,Y are the params to open the menu in the desired location. Your code should look like this:

frmMe.PopupMenu("mnu0",,cmdAdd.left,cmdAdd.top)

I think this could work for You...
Greetings!!
0
 

Expert Comment

by:Sergio_A
ID: 12358206
I forgot to tell you that frmMe can be replaced by only "ME" or the name of your form.
0
 
LVL 34

Author Comment

by:Mike Eghtebas
ID: 12361567
Thank you Sergio,

Mike
0

Featured Post

Announcing the Most Valuable Experts of 2016

MVEs are more concerned with the satisfaction of those they help than with the considerable points they can earn. They are the types of people you feel privileged to call colleagues. Join us in honoring this amazing group of Experts.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

There are many ways to remove duplicate entries in an SQL or Access database. Most make you temporarily insert an ID field, make a temp table and copy data back and forth, and/or are slow. Here is an easy way in VB6 using ADO to remove duplicate row…
Have you ever wanted to restrict the users input in a textbox to numbers, and while doing that make sure that they can't 'cheat' by pasting in non-numeric text? Of course you can do that with code you write yourself but it's tedious and error-prone …
Get people started with the process of using Access VBA to control Excel using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Excel. Using automation, an Access application can laun…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

828 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question