ON_COMMAND_RANGE

Используйте этот макрос для сопоставления сопредельное диапазон идентификаторов команд с одной функции обработчика сообщений.

ON_COMMAND_RANGE(id1, id2, memberFxn )

Параметры

  • id1
    Идентификатор команды в начале непрерывного диапазона идентификаторов команд.

  • id2
    Идентификатор команды в конце непрерывного диапазона идентификаторов команд.

  • memberFxn
    Имя функции обработчика сообщений, к которой сопоставлены команды.

Заметки

Диапазон идентификаторов начинается с id1 и заканчивающемся элементом с id2.

Используйте ON_COMMAND_RANGE для сопоставления диапазона идентификаторов команд одному функцию-член.Используйте ON_COMMAND для сопоставления одной команды к функции-члену.Только одна запись сообщение-сопоставления может соответствовать заданному идентификатору командыТо есть нельзя сопоставить команду на более чем один обработчик.Дополнительные сведения о диапазонах сообщения сопоставления см. в разделе Обработчики для диапазонов Сообщение-Сопоставления.

Нет автоматическая поддержка диапазонов сопоставления сообщений, поэтому следует самостоятельно установить.

Пример

// The code fragment below shows how to use ON_COMMAND_RANGE macro
// to map a contiguous range of command IDs to a single message 
// handler function (i.e. OnRangeCmds() in the sample below). In 
// addition, it also shows how to use CheckMenuRadioItem() to check a 
// selected menu item and makes it a radio item.
BEGIN_MESSAGE_MAP(CChildFrame, CMDIChildWnd)
   ON_COMMAND_RANGE(ID_COMMAND_RANGECMD1, ID_COMMAND_RANGECMD3, &CChildFrame::OnRangeCmds)
END_MESSAGE_MAP()

void CChildFrame::OnRangeCmds(UINT nID)
{
   CMenu* mmenu = AfxGetMainWnd()->GetMenu();
   CMenu* submenu = mmenu->GetSubMenu(5);
   submenu->CheckMenuRadioItem(ID_COMMAND_RANGECMD1, ID_COMMAND_RANGECMD3, 
      nID, MF_BYCOMMAND);
}

Требования

Header: afxmsg_.h

См. также

Ссылки

ON_UPDATE_COMMAND_UI_RANGE

ON_CONTROL_RANGE

ON_COMMAND

Основные понятия

Макросы и глобальные MFC