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;

}