Providing Help in a Dialog Box
To provide context-sensitive help in a dialog box, you must create an array
consisting of pairs of doubleword values. The first value in each pair is the
identifier of a control in the dialog box, and the second is the context
identifier of the help topic for the control. The array should contain one pair of
identifiers for each control in the dialog box.
The dialog box procedure must process the
WM_HELP and
WM_CONTEXTMENU messages. The dialog box procedure receives WM_HELP when the user presses the F1 key and WM_CONTEXTMENU when the user clicks the right mouse button.
The
lParam parameter of WM_HELP is a pointer to a
HELPINFO structure. The
hItemHandle member of this structure identifies the control for which the user has
requested help. You must pass the handle to the
WinHelp function along with the HELP_WM_HELP command, the name of your help file, and
a pointer to the array of identifiers. The
WinHelp function searches the array for the control identifier of the specified
control and then retrieves the corresponding help context identifier. Next, the
function passes the help context identifier to Windows Help, which finds the
corresponding topic and displays it in a pop-up window. If the control has an
identifier of
1, the system searches for the next control that is a tab stop and uses its
identifier to find the help context identifier. For this reason, it is important
that you place static text before controls in a resource file.
Processing WM_CONTEXTMENU is similar to processing WM_HELP when calling the
WinHelp function, with these two exceptions:
- You pass the wParam parameter from WM_CONTEXTMENU, which is the handle of the control that sent
the message.
- You specify the HELP_CONTEXTMENU command instead of HELP_WM_HELP.
The HELP_CONTEXTMENU command causes Windows Help to display a menu before it
displays the help topic. The menu is system defined. It allows the user to
display help for the control or to display the Help Topics dialog box.
The following example shows how to implement context-sensitive help in a
dialog box.
LRESULT CALLBACK EditDlgProc(HWND hwndDlg, UINT uMsg, WPARAM wParam,
LPARAM lParam)
{
// Create an array of control identifiers and context identifiers.
static DWORD aIds[] = {
ID_SAVE, IDH_SAVE,
ID_DELETE, IDH_DELETE,
ID_COPY, IDH_COPY,
ID_PASTE, IDH_PASTE,
0,0
};
switch (uMsg) {
case WM_HELP:
WinHelp(((LPHELPINFO) lParam)->hItemHandle, "helpfile.hlp",
HELP_WM_HELP, (DWORD) (LPSTR) aIds);
break;
case WM_CONTEXTMENU:
WinHelp((HWND) wParam, "helpfile.hlp", HELP_CONTEXTMENU,
(DWORD) (LPVOID) aIds);
break;
.
. // process other messages here
.
}
return FALSE;
}
- Software for developers
-
Delphi Components
.Net Components
Software for Android Developers
- More information resources
-
MegaDetailed.Net
Unix Manual Pages
Delphi Examples
- Databases for Amazon shops developers
-
Amazon Categories Database
Browse Nodes Database