На главную

On-line справка по Win32 API

Написать письмо
БЕСПЛАТНАЯ ежедневная online лотерея! Выигрывай каждый день БЕСПЛАТНО!
Список всех статей A-B-C-D-E-F-G-H-I-J-K-L-M-N-O-P-Q-R-S-T-U-V-W-X-Y-Z | Скачать Вниз

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;

}



Пригласи друзей и счет твоего мобильника всегда будет положительным!
Предыдущая статья
 
Сайт Народ.Ру Интернет
Следующая статья
Пригласи друзей и счет твоего мобильника всегда будет положительным!

Обеспечение Помощи в Диалоговом Ящике



Чтобы обеспечивать контекстно-зависимую помощь в диалоговом ящике, Вы должны создать массив, состоящий из пар величин двойного слова. Первая величина в каждой паре - идентификатор управления в диалоговом ящике, и второй - контекстным идентификатором темы помощи для управления. Массив должен содержать один пара идентификаторов для каждого управления в диалоговом ящике.

Диалоговая процедура ящика должна обработать WM_HELP и сообщения WM_CONTEXTMENU. Диалоговая процедура ящика получает WM_HELP когда потребитель нажимает ключ F1 и WM_CONTEXTMENU когда потребитель щелкает кнопку мыши права.
Параметр lParam WM_HELP является указателем в структуру HELPINFO. Член hItemHandle этой структуры идентифицирует управление для которого потребитель попросил помощь. Вы должны передать ручку в функцию WinHelp вместе с командой HELP_WM_HELP, имя вашей помощи файла, и указателем в массив идентификаторов. Функция WinHelp ищет массив для управляющего идентификатора определенного управления затем извлекает контекстный идентификатор соответствующей помощи. Затем, функция передает контекстный идентификатор помощи в Помощь Окна, который находит соответствующую тему и отображает это в управляющем окне. Если управление имеет идентификатор - 1, система ищет следующее управление, которое - таб. останавливает и использует свой идентификатор, чтобы находить контекстный идентификатор помощи. По этой причине, важно, чтобы Вы устанавливали статический текст перед элементами управления в файле ресурса.

Обработка WM_CONTEXTMENU подобная обработке WM_HELP при разговоре функции WinHelp, с этими двумя исключениями:

Вы передаете параметр wParam из WM_CONTEXTMENU, который - ручка управления, которое посылало сообщение.
Вы определяете команду HELP_CONTEXTMENU вместо HELP_WM_HELP.



Команда HELP_CONTEXTMENU заставляет Подсказку Windows, чтобы отображать меню прежде, чем оно отобразит тему подсказки. Меню является системой определенной. Это позволяет пользователя, чтобы отображать подсказку для управления или, чтобы отображать Темы Подсказки диалогового блока.
Следующий пример показывает как, чтобы осуществлять контекстно-зависимую подсказку в диалоговом блоке.

LRESULT CALLBACK EditDlgProc(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
{

// Создайте массив управляющих идентификаторов и контекстных идентификаторов.

статический DWORD помогает[] = { ID_SAVE, IDH_SAVE, ID_DELETE, IDH_DELETE, ID_COPY, IDH_COPY, ID_PASTE, IDH_PASTE,
0,0
};

ключ (uMsg) { случай WM_HELP:
WinHelp СРЕДСТВ(((LPHELPINFO) lParam)->hItemHandle, "helpfile.hlp", HELP_WM_HELP, (DWORD) (LPSTR));

прерывание;

случай WM_CONTEXTMENU:
WinHelp СРЕДСТВ((HWND) wParam, "helpfile.hlp", HELP_CONTEXTMENU, (DWORD) (LPVOID));
прерывание;
.
. // процесс другие сообщения здесь
.
}

обратная ЛОЖЬ;

}



Вверх Version 1.3, Oct 26 2010 © 2007, 2010, mrhx Вверх
 mrhx software  Русский перевод OpenGL  Русский перевод Win32 API
 
Используются технологии uCoz