You can use Access macros to create custom shortcut menus that appear when you right-click forms,
reports,
or individual controls. You can also create custom menus that appear on the Ribbon for specific forms or
reports.
To create a menu by using macros, you perform three main steps:
1.
Create a macro group that defines the menu commands.
2.
Create another macro that creates the menu itself.
3.
Attach the menu to a control, a form, a report, or to the database as a whole.
The following sections walk you through these steps in detail.
Step 1: Create a macro group that contains the menu
commands
In this step, you create a macro group, each macro of which will be a separate command on your shortcut
menu.
What is a macro group?
a.
On the Create tab, in the Other group, click Macro. If this command is unavailable, click the arrow
beneath either the Module or the Class Module button, and then click Macro.
b.
On the Design tab, in the Show/Hide group, click Macro Names to display the Macro Name
column.
c.
For each command that you want on your custom Shortcut Menu:
In the Macro Name column, enter the text that you want to display on the shortcut menu
(for example, "Print report" or "Save").
a.
NOTE
To create an access key so that you can use the keyboard to choose the
command, type an ampersand (&) before the letter that you want to be the access key in
the command name (for example, "&Save"). This letter will be underlined on the menu.
In the Action column, select the first action you would like to take place when you click
the command on the shortcut menu.
If there are more actions that you want to take place when you select this command, add
them on the subsequent lines. For each subsequent action, leave the Macro Name cell blank.
a.
NOTE
To create a line between two menu commands, type a hyphen (-) in the
Macro Name column between the appropriate menu commands.
d.
Save and name the macro, for example, mcrShortcutMenuCommands.
The following illustration shows an example macro group for a custom menu or shortcut menu.
Step 2: Create a macro that creates the menu
This step might seem redundant, but to create the shortcut menu from the macro group that you created in
Step 1, you must create a second macro that contains the AddMenu macro action. This macro is sometimes
called the "menu macro".
a.
On the Create tab, in the Other group, click Macro. If this command is unavailable, click the arrow
beneath either the Module or the Class Module button, and then click Macro.
b.
On the first line of the macro, select AddMenu in the Action list.
c.
Under Action Arguments, in the Menu Name box, type the name of the menu (for example,
"Report Commands"). This argument is not required, but is recommended if, in Step 3, you plan to add the
menu to a Ribbon tab (such as the Add-Ins tab of a form or report). If the menu is added as a shortcut menu
in Step 3, the Menu Name argument is ignored.
d.
In the Menu Macro Name box, enter the name of the macro that you created in Step 1.
e.
Save and name the macro, for example, mcrAddShortcutMenu.
The following illustration shows an example menu macro that creates the menu we designed in Step 1.
Step 3: Attach the menu to a control, form, report, or
database
Depending on where you want the menu to appear, use one or more of the following procedures.
Add the menu to the Add-Ins tab of a form or report
Use this procedure if you want the menu to appear on the Add-Ins tab for a specific form or report,
as shown in the following illustration:
a.
In the Navigation Pane, right-click the form or report where you want the menu to appear, and then
click Design View.
b.
On the Design tab, in the Show/Hide group, click Property Sheet.
c.
Select the entire object by selecting Form or Report from the list at the top of the Property Sheet
task pane.
d.
On the Other tab on the Property Sheet, in the Shortcut Menu property box, type the name of the
macro that you created in Step 2 (in this example, mcrAddShortcutMenu).
The next time you open the form or report, the Add-Ins tab appears in the Ribbon. Click the tab to
see the menu.
For more information about Ribbon customization techniques, such as adding custom tabs or hiding
the default tabs, see the article Customize the Ribbon.
The Ribbon is a component of the Microsoft Office Fluent user interface.
Add the menu as a shortcut menu for a form, report, or
control
Use this procedure if you want the menu to appear when you right-click a specific form, report, or
control, as shown in the following illustration:
e.
In the Navigation Pane, right-click the form or report where you want the shortcut menu to appear,
and then click Design View.
f.
On the Design tab, in the Show/Hide group, click Property Sheet.
g.
Select the control or object to which you want to attach the shortcut menu.
NOTE
To select the entire object, select Form or Report from the list at the top of the
Property Sheet task pane.
h.
On the Other tab on the Property Sheet, in the Shortcut Menu Bar property box, type the name of
the macro that you created in Step 2 (in this example, mcrAddShortcutMenu).
Add the menu as a global shortcut menu
This procedure replaces all of the default shortcut menus in the current database. Custom shortcut
menus that you have attached to specific forms, reports, or controls are not affected.
i.
Click the Microsoft Office Button
and then click Access Options.
j.
In the Access Options dialog box, click Current Database.
k.
Under Ribbon and Toolbar Options, in the Shortcut Menu Bar box, type the name of the macro
that you created in Step 2 (in this example, mcrAddShortcutMenu).
NOTES
Custom shortcut menus replace the default shortcut menus for the objects they are attached to. If
you want to retain certain Access commands to use on these menus, use the RunCommand action to put
the commands into the macro groups for the menus you want them in.
A custom shortcut menu that is attached to a control supersedes any other custom shortcut menus
that are defined in the database. A custom shortcut menu that is attached to a form or report supersedes a
custom global shortcut menu.
When you specify a menu macro for a form or report or for the database, Access runs this menu
macro whenever the form, report, or database is opened. If you make changes to the menu macro or the
macro group that defines its commands while the form, report, or database is open, you must close the form,
report, or database and reopen it to see the changes.
To create a submenu, follow Step 1 to create a separate macro group that contains only the
submenu commands. Then, follow Step 1 again to define the commands for the higher-level menu. Add the
submenu as an item in the higher-level macro group by using the AddMenu macro action. The following
illustration shows the macro group for a menu that contains a submenu, and then shows the resulting
shortcut menu. The third line in the macro group creates the Export To... submenu (mcrSubMenu).
You can create multiple levels of submenus by using AddMenu actions in the macro groups for each
level of menu. Make sure to supply a value for the Menu Name argument for each AddMenu action,
otherwise the submenu will appear as a blank line in the higher-level menu.
Macro conditions are supported in the top-level menu macro only. In other words, you can use a
condition in a menu macro to determine if a particular menu or shortcut menu will be displayed, but only for
the menus on the top level. You can't use conditions to display or hide commands or submenus on the
menus. You can also use a condition to hide or show a custom shortcut menu or global shortcut menu.
Optionally, the menu macro that you create in Step 2 can be part of a macro group. For example, if
you have several shortcut menus for different objects or controls, you can create a single macro object that
contains all of the necessary menu macros. Make sure to display the Macro Name column and type a unique
name for each macro. In Step 3, use the following notation to refer to the macro:
macrogroupname.macroname. For example, mcrAddShortcutMenus.AddMenu2.