Форум программистов, компьютерный форум, киберфорум
Delphi: WinAPI
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
 Аватар для snake32
3502 / 1685 / 236
Регистрация: 26.02.2009
Сообщений: 8,389
Записей в блоге: 6

Hook мыши на PopupMenu

06.11.2013, 20:41. Показов 2063. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени!

Есть тыщщщи PopupMenu. Задача: посчитать кол-во нажатий каждой кнопки дабы выявить ненужные.
Искать код попапов по всему проекту и вставлять туда свой код - не вариант.
Идея была простая: поставить хук на все нажатии мышой над попапами. Я с радостью начал кодить:
Сделал локальный хук:
Delphi
1
2
3
4
5
{$IFDEF MOUSEHOOKCOUNTER}
    Hook := SetWindowsHookEx( WH_MOUSE, @MouseHookCounterProc, HInstance, GetCurrentThreadId() ) ;
    if Hook = 0 then
      ShowMessage('Не могу установить хук на мышь');
{$ENDIF}
Собственно начало процедуры хука:
Delphi
1
2
3
4
5
6
if( nCode >= 0 )and( MsgID = WM_LBUTTONUP )then
  begin
    if pdata.hwnd <> 0 then
    begin
      len := StrGetClassName( pdata.hwnd, cls );
      if cls = 'TPUtilWindow' then //'#32768' //'TPopupItem' //'TPopupMenu'
Проблема в том что я никак не могу выудить название попапы(его caption). Delphi работает через загадочный класс TPUtilWindow. С какого боку подойти к нему я не знаю. Не ужели нужно искать тыщщу мест в ручную?

Добавлено через 1 час 5 минут
Delphi
1
2
3
parent := GetParent( pdata.hwnd ); // родитля нет: parent = 0
EnumChildWindows( pdata.hwnd, @EnumChildProc, 0 ); // детей нет
menu := GetMenu( pdata.hwnd );// меню тоже НЕТ
Какие ещё апишные ф-ии можно задействлвать?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.11.2013, 20:41
Ответы с готовыми решениями:

Hook клавиатуры и мыши
Мне нужно сделать hook клавиатуры и мыши в vs 2010, но у меня проблемы с фантазией, и я не совсем понимаю как это сделать) помогите плз)

Hook клавиатуры и мыши
Я пересмотрел кучу сайтов по похожим запросам И нигде толком и понятно не написано выручайте люди.

Hook для нажатия левой кнопки мыши
Подскажите пожалуйста как отследить нажатие левой кнопки мыши вне модального окна. Я так понимаю нужно писать Hook, был бы признателен за...

6
3530 / 2270 / 279
Регистрация: 24.12.2010
Сообщений: 13,723
07.11.2013, 11:10
Никакие хуки вообще не нужны, все намного проще и смешнее.

1. При создании любой из форм (например, главной) назначаешь обработчик события Application.OnMessage
2. В обработчике OnMessage фильтруешь сообщения WM_COMMAND
3. Для каждого сообщения WM_COMMAND при нуле в старшем слове wParam получаешь уник.идентификатор MIID выбранного эл-та меню из младшего слова wParam.
4. Бежишь в цикле по глобальному списку PopupList, для каждого эл-та списка приводишь его к типу TMenu и вызываешь метод FindItem(MIID, fkCommand) - первый же найденный TMenuItem и будет искомым объектом
1
 Аватар для snake32
3502 / 1685 / 236
Регистрация: 26.02.2009
Сообщений: 8,389
Записей в блоге: 6
07.11.2013, 12:07  [ТС]
mss, спасибо огромное!
Сейчас ковыряю OnMessage( var msg:TMsg; var Handled:Boolean )
Не могли бы вы пояснить смысл Handled?
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
procedure TfmMain.PopupClickConter( var Msg: TMsg; var Handled: Boolean );
  var i:integer;
      miid:NativeUint;
      mi:TMenuItem;
begin
  if( Msg.message = WM_COMMAND )and( Hi( Msg.wParam )=0 )then
  begin
    miid := Lo( Msg.wParam );
    for i:=0 to PopupList.Count-1 do
    begin
      mi := TMenu( PopupList[i] ).FindItem( miid, fkCommand );
      if( mi <> nil )then
      begin
        OnClicked( mi );
        break;
      end;
    end;
  end;
end;
0
3530 / 2270 / 279
Регистрация: 24.12.2010
Сообщений: 13,723
07.11.2013, 12:19
Цитата Сообщение от snake32 Посмотреть сообщение
смысл Handled?
Цитата из стандартной встроенной справки:

Handled indicates whether the event handler responded to the message. If the event handler sets Handled to true, the application assumes that the message has been completely handled and halts any subsequent processing of the message.

То есть при поступлении сообщений любому из окон осн.потока приложения событие OnMessage возбуждается самым первым до его обработки каким-либо объектом приложения.
Установкой Handled = True объект Application извещается о том, что сообщение обработано прямо в теле обработчика OnMessage и последующая его диспетчеризация и обработка не требуется.
1
Модератор
 Аватар для FIL
3492 / 2614 / 742
Регистрация: 19.09.2012
Сообщений: 7,977
07.11.2013, 13:23
snake32, ф-ции Hi и Lo возвращают байты, а не слова.
1
 Аватар для snake32
3502 / 1685 / 236
Регистрация: 26.02.2009
Сообщений: 8,389
Записей в блоге: 6
07.11.2013, 13:37  [ТС]
У меня ошибка была. Вот правильный вариант:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
procedure TfmMain.PopupClickCounter( var Msg: TMsg; var Handled: Boolean );
  var i:integer;
      miid:NativeUint;
      mi:TMenuItem;
begin
  if( Msg.message = WM_COMMAND )and( HiWORD( Msg.wParam )=0 )then
  begin
    miid := LoWORD( Msg.wParam );
 
    for i:=0 to PopupList.Count-1 do
    begin
      mi := TMenu( PopupList[i] ).FindItem( miid, fkCommand );
      if( mi <> nil )then
      begin
        OnClickedPopup( mi );
        break;
      end;
    end;
 
  end;
end;
Кстати, на x64 тоже всё работает. Думал проблемы будут из-за HiWORD/LoWORD.

Теперь что делать с обычными меню(не попап). На клик по меню заходит в первый if, но понятное дело в PopupList его нет. Где его искать? По хендлу окна Msg.hwnd?

Добавлено через 1 минуту
Цитата Сообщение от FIL Посмотреть сообщение
Hi и Lo возвращают байты, а не слова.
Да, это уже отдебажил, спасибо
0
3530 / 2270 / 279
Регистрация: 24.12.2010
Сообщений: 13,723
07.11.2013, 13:47
Цитата Сообщение от snake32 Посмотреть сообщение
По хендлу окна Msg.hwnd?
Ну можно и так.
По hwnd находишь форму. Бежишь по списку компонентов формы и ищешь среди них объекты TMenu - дальше ты уже знаешь что делать
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.11.2013, 13:47
Помогаю со студенческими работами здесь

Mouse Global Hook (Глобальный захват мыши)
Есть программка которая работает в свернутом режиме, она должна отслеживать нажатие левой кнопки мыши, по скольку клики происходят за...

NetBeans: popupMenu на левую кнопку мыши
Здравствуйте, форумчане. Java только начинаю изучать. Среда NetBeans 7.1.2. Есть кнопка jButton и меню jPopupMenu. Привязываю меню к...

Работа с PopupMenu левой и правой кнопками мыши
В моем проекте требуется задать возможность менять пользователем названия осей координат (показаны зеленым цветом) с помощью всплывающего...

Нажатие на пункт PopupMenu MenuItem по событию MenuItemClick правой или левой кнопкой мыши
Собственно никак не получается. Надо, чтобы по левой работал код пункта, а по правой только чекинг ставился... по...

hook
моя работа заключается в написании сервиса с функцией контроля действий пользователя в системе.Как с помощью hooka решить данную...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru