Xbindkeys не запускает некоторые клавиши при изменении раскладки клавиатуры
Я использую xbindkeys для сопоставления некоторых кнопок мыши с ключами.
Однако, когда я меняю раскладку клавиатуры, xbindkeys не имитирует некоторые назначенные клавиши на новой раскладке. Когда я переключаюсь на предыдущий макет, он работает нормально.
Комбинации, которые перестают работать:
# Present desktops
"xte 'key Super_L'"
b:10 + release
# Zoom
"xte 'keydown Super_L' 'keydown Alt_L' 'key 8' 'keyup Super_L' 'keyup Alt_L'"
b:13 + release
Все эти ключи находятся в одном месте на двух разных макетах.
Я проверил с xbindkeys -n -v
и он все еще распознает кнопки мыши, но xbindkeys
не вызывает связанные ключи.
С en
расположение:
Button release !
e.xbutton.button=10
e.xbutton.state=16
"xte 'key Super_L'"
Release + m:0x0 + b:10 (mouse)
got screen 0 for window d3
Start program with fork+exec call
После перехода на es
расположение:
Button press !
e.xbutton.button=10
e.xbutton.state=16
Button release !
e.xbutton.button=10
e.xbutton.state=8208
1 ответ
Решение
Это ошибка в xbindkeys. Вам нужно скачать последний источник (1.8.6) и применить патч (fix_layout.patch). Ошибка обсуждалась здесь.
fix_layout.patch
From d4a943caa3d700a5edb18d5ab528e8cf7f6d54c9 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Alberto=20S=E1nchez=20Molero?= <alsamolero@gmail.com>
Date: Mon, 10 Feb 2014 21:11:05 +0100
Subject: Fix keyboard layout problems - Ignore 13th and 14th bits of button
state
Author: Alberto Sanchez Molero <alsamolero@gmail.com>
---
xbindkeys.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/xbindkeys.c b/xbindkeys.c
index b0adef9..5b1b86b 100644
--- a/xbindkeys.c
+++ b/xbindkeys.c
@@ -377,7 +377,7 @@ event_loop (Display * d)
printf ("e.xbutton.state=%d\n", e.xbutton.state);
}
- e.xbutton.state &= ~(numlock_mask | capslock_mask | scrolllock_mask
+ e.xbutton.state &= 0x1FFF & ~(numlock_mask | capslock_mask | scrolllock_mask
| Button1Mask | Button2Mask | Button3Mask
| Button4Mask | Button5Mask);
@@ -409,7 +409,7 @@ event_loop (Display * d)
printf ("e.xbutton.state=%d\n", e.xbutton.state);
}
- e.xbutton.state &= ~(numlock_mask | capslock_mask | scrolllock_mask
+ e.xbutton.state &= 0x1FFF & ~(numlock_mask | capslock_mask | scrolllock_mask
| Button1Mask | Button2Mask | Button3Mask
| Button4Mask | Button5Mask);
--
cgit v1.0