Evgenii Legotckoi
Evgenii Legotckoi24 февраля 2016 г. 23:56

XGrabKey

Синтаксис

XGrabKey(display, keycode, modifiers, grab_window, owner_events, pointer_mode, keyboard_mode)
      Display *    display;
      int          keycode;
      unsigned int modifiers;
      Window       grab_window;
      Bool         owner_events;
      int          pointer_mode, keyboard_mode;

Аргументы

display         // Указывает соединение с X Сервером
keycode         // Указывает код клавиши (KeyCode) или любой код (AnyKey)
modifiers       // Указывает установку конкретных масок модификаторов 
                // или использование любых модификаторов (AnyModifier). 
                // Маска является поразрядным ИЛИ для проверки битов маски.
grab_window     // Указывает захватываемое окно
owner_events    // Указывает значение Boolean, которое указывает на события клавиатуры, 
                // будут ли представлены как обычно.
pointer_mode    // Описывает дальнейший способ обработки событий указателя мыши.
                // Вы можете передавать GrabModeSync или GrabModeAsync.
keyboard_mode   // Описывает дальнейший способ обработки событий клавиатуры. 
                // Вы можете передавать GrabModeSync or GrabModeAsync.

Описание

Функция XGrabKey() устанавливает пассивный захват клавиатуры. В дальнейшем клавиатура может захватываться активно (с помощью XGrabKeyboard() ), время последнего захвата клавиатуры устанавливается в момент, когда нажата клавиша (тогда передаётся событие KeyPress ), а вызывается событие KeyPress , если выполнены все условия (то есть являются true):

  • Клавиатура не захвачена, а указанная клавиша (которая может быть сама по себе модификатором) является логически нажатой, когда также нажаты другие целевые клавиши модификаторы, и при этом не нажаты иные модификаторы, которые не заложены в .
  • Захватываемое окно является предком или является окном фокусировки захватываемого сочетания клавиш, или окно фокусировки является потомком окна фокусировки и содержит указатель на предка
  • Пассивный захват той же комбинации клавиш не существует у какого-либо предка захватываемого окна.

Интерпретация следующих аргументов для XGrabKeyboard() . Активный захват завершается автоматически, когда логическое состояние клавиатуры описывается отпускание клавиши (независимо от логического состояния клавиш модификаторов).

Примечание. Логическое состояние устройства (как видно по клиентским приложениям) может запаздывать по сравнению с физическим состоянием, если обработка события устройства заморозилась. То есть может происходить подлагивание приложения или даже заморозка сервера X11. В частности это может наблюдаться при запуске режима захвата в качестве GrabModeSync , если не реализована корректная обработка событий нажатия клавиш.

Значение модификатора AnyModifier для аргумента modifiers является эквивалентом разрешения обработки всех возможных сочетаний клавиш модификаторов (включая комбинации без модификаторов).

Стоит отметить, что в X11 модификаторами являются не только клавиши Ctrl, Alt, Shift, Win(Meta), как в ОС Windows , но и клавиши ScrollLock, CapsLock, NumLock. Поэтому при регистрации сочетаний горячих клавиш необходимо учитывать и сочетания с данными клавишами. То есть, фактически вместо одного сочетания Сtrl+Alt+R, необходимо зарегистрировать ещё 7 сочетаний с клавишами ScrollLock, CapsLock и NumLock, чтобы сочетание корректно работало, если, конечно, Вам специально не требуется иной логики поведения приложения в сочетании с данным модификаторами.

Значение AnyKey для аргумента keycode эквивалентно решению обработки всех возможных клавиш (кодов клавиш). Однако, указание keycode должно быть в пределах между min_keycode и max_keycode. Иначе будет получена ошибка BadValues.

Если какое-то клиентское приложение уже использует определённое сочетание клавиш с помощью XGrabKey() на определённом целевом окне, то будет возвращена ошибка BadAccess . При использовании модификатора AnyModifier или AnyKey запрос на некоторые клавиши будет ошибочен и в результате BadAccess захват не будет выполняться из-за конфликта с комбинацией клавиш, захваченной другим приложением.

В частности, из-за такого поведения XGrabKey() можно некоторое время недоумевать о том, почему не срабатывает захват клавиши PrintScreen под тем же самым дистрибутивом Ubuntu. А причина в том, что данная клавиша уже захвачена приложением для создания скриншотов, которое идёт в поставке Ubuntu по умолчанию и уже захватывает данную клавишу.

XGrabKey() может генерировать следующие ошибки BadAccess , BadValue и BadWindow .

Диагностика

BadAccess - клиентское приложение попыталось освободить запись цветовой карты, которые уже освобождена.

BadAccess - клиентское приложение попыталось сохранить запись цветовой карты, которая в режиме read-only.

BadValue - некоторые числовые значения выходят за пределы диапазона запроса.  Если определенный диапазон не указан для аргумента, полный спектр определяется типом принимаемого аргумента.Любой аргумент определяется как набор альтернатив который может вызывать данную ошибку.

BadWindow - Значение для аргумента Окна (Window) не имеет имени определённого Окна (Window). Неверный идентификатор окна.

см. также XUngrabKey()

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

Комментарии

Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь
ДЛ

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат:60баллов,
  • Очки рейтинга-1
СЦ

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат:50баллов,
  • Очки рейтинга-4
AT

C++ - Тест 001. Первая программа и типы данных

  • Результат:73баллов,
  • Очки рейтинга1
Последние комментарии
J
JonnyJo30 марта 2023 г. 21:57
Qt/C++ - Урок 021. Рисование мышью в Qt Евгений, здравствуйте! Только начал изучение Qt и возник вопрос по 21ому уроку. После написания кода, выдаёт следующие ошибки В чём может быть проблема?
АН
Алексей Николаев26 марта 2023 г. 19:10
Qt/C++ - Урок 042. PopUp уведомление в стиле Gnome с помощью Qt Добрый день, взял за основу ваш PopUp notification , и немного доработал его под свои нужды. Добавил в отдельном eventloop'e всплывающую очередь уведомлений с анимацией и таймеро…
АН
Алексей Николаев26 марта 2023 г. 19:04
Qt/C++ - Урок 042. PopUp уведомление в стиле Gnome с помощью Qt Включите прозрачность в композит менеджере fly-admin-theme : fly-admin-theme ->Эффекты и всё заработает.
Evgenii Legotckoi
Evgenii Legotckoi24 марта 2023 г. 20:09
Django - Урок 062. Как написать блочный шаблонный тег tabbar наподобие тега blocktranslate Почитайте эту статью про "хлебные крошки"
Сейчас обсуждают на форуме
BlinCT
BlinCT1 апреля 2023 г. 15:16
Нужен совет по работе с ListView и несколькими моделями Спасибо, сейчас займусь этим.
NSProject
NSProject31 марта 2023 г. 12:55
Проверка комментария принадлежит он пользователю или нет DRF (Django Rest Framework) Здравствуйте! Сегодня я столкнулся с такой проблеммой. Существует модель комметариев. Где их соответственно достаточное количество. Все они выводятся при помощи запроса ajax (axios). Так ка…
P
Pisych30 марта 2023 г. 12:50
Как подсчитать количество по условию? Да! Вот так работает! Огромное Вам спасибо! ........
Evgenii Legotckoi
Evgenii Legotckoi29 марта 2023 г. 14:11
Замена поля ManyToMany Картинки точно нужно хранить в медиа директории на сервере, а для обращения использовать ImageField. Который будет хранить только путь к изображению на сервере. Хранить изображения в базе данных…
ВА
Виталий Анисимов30 января 2023 г. 2:17
Как добавить виртуальную клавиатура с Т9 в своей проект на QML. Добрый день. Прошу помочь, пишу небольше приложение в Qt. Добвил в свой проект виртуальную клавиатуру от Qt. Но как добавить в него возможность изменения Т9 никак не могу понять.

Следите за нами в социальных сетях