「全てのマウスボタンを動作させる」の版間の差分

提供: ArchWiki
ナビゲーションに移動 検索に移動
(文字列「カスタム .service ファイルを書く」を「ユニットファイル」に置換)
 
(4人の利用者による、間の21版が非表示)
1行目: 1行目:
 
[[Category:マウス]]
 
[[Category:マウス]]
 
[[Category:X サーバー]]
 
[[Category:X サーバー]]
[[en:All Mouse Buttons Working]]
+
[[en:Mouse buttons]]
[[ru:All Mouse Buttons Working]]
+
[[ru:Mouse buttons]]
 
[[zh-hant:All Mouse Buttons Working]]
 
[[zh-hant:All Mouse Buttons Working]]
 
{{Related articles start}}
 
{{Related articles start}}
8行目: 8行目:
 
{{Related|マウスのポーリングレート}}
 
{{Related|マウスのポーリングレート}}
 
{{Related articles end}}
 
{{Related articles end}}
この記事では4つ以上のマウスボタンが付いているマウスを使っているユーザーに全てのボタンを使用する方法説明します。そうしたマウスは Logitech ([[Logitech_Marble_Mouse|Logitech Marble® Mouse]]) や Microsoft などが製作しています。
+
この記事では 3 つ以上のマウスボタンが付いているマウスを設定する方法について説明します。
   
  +
== Xでマウス入力をテストする前提条件 ==
== 要件 ==
 
   
  +
このページでは、[[Wayland]]ではなく、[[Xorg]] ([[Xorg|X Window System]]) を使っていることを前提にしています。
Xorg では {{ic|evdev}} ドライバーを使います。EVentDEVice は USB 入力デバイス用の先進的なドライバーで、Xorg 標準の {{ic|mouse}} ドライバーよりも強力です。また、{{ic|mouse}} ドライバーよりも"ダイレクト"に制御することができ、遅延が抑えられます。
 
   
  +
まず、X があなたのマウスから何を見るかを確認したいと思うでしょう。X のイベントは [[xev]] ユーティリティで表示することができます。実行することでウィンドウがポップアップします。
{{Note|{{Ic|evdev}} はカーネルモジュールであり Xorg インプットドライバーでもあります。全ての Arch カーネルには {{Ic|evdev}} モジュールが付属しています。}}
 
   
  +
$ xev -event button | grep button
Xorg 11R7.0 以降では {{ic|/etc/X11/xorg.conf}} に変更を加えるだけで後の設定は必要ありません。
 
   
  +
そのウィンドウの xevents (移動、サイズ変更、クリックなど) は、''xev'' を起動したコンソールに報告されます。"ボタン" を含む行をフィルタリングしているため、マウスのクリックとリリースのイベントが、関連するボタン番号とともに表示されます。ほとんどのマウスの場合、これは左ボタンの場合は '1'、中央のボタンは '2'、右ボタンの場合は '3' になります。他のボタンは異なります (たとえば、Logicool MX Master 3 の場合、スクロールホイールは 4 と 5、サムホイールは 6 と 7、親指の先のボタンは 9、親指の内側のボタンは 8)
== マウスの名前を確認 ==
 
  +
  +
出力例:
  +
  +
state 0x0, button 1, same_screen YES
  +
state 0x100, button 1, same_screen YES
  +
state 0x0, button 9, same_screen YES
  +
state 0x0, button 9, same_screen YES
  +
  +
これは、マウスの左クリックとリリースに続いて親指の先でクリックとリリースに相当します。
  +
  +
''xev'' を使用すると、マウスボタンの番号を確認し、X にマウスクリックが通知されていることを確認できます。
  +
  +
== マウスとキーボードの機能の再バインド ==
  +
  +
このセクションでは、さまざまなツールを使用してマウスとキーボードの機能を再配置する方法について詳しく説明します。
  +
  +
=== マウスボタンをキーボード機能にバインドする ===
  +
  +
==== xte ====
  +
  +
{{Pkg|xautomation}} の ''xte'' は、キーボードのボタンをマウスにバインドする場合に便利です。
  +
  +
これは、{{ic|Shift_R}} をマウス ボタン 3 ("右クリック") にバインドする {{ic|~/.xbindkeysrc}} の例です:
  +
  +
{{hc|~/.xbindkeysrc|
  +
"xte 'mouseclick 3'"
  +
Shift_R
  +
}}
  +
  +
=== キーボードをマウスボタンにバインド ===
  +
  +
==== xvkbd と xbindkeys ====
  +
  +
マウスボタンをキーボードにバインドしたいとします。問題はキーの押下をエミュレートする方法がわからないということです。そこで {{AUR|xvkbd}} が役に立ちます。{{Pkg|xbindkeys}} と一緒に使うことができます:
  +
  +
$ xbindkeys --defaults >> ~/.xbindkeysrc
  +
$ xbindkeys
  +
  +
xbindkeys を再起動するには以下を実行:
  +
  +
$ pkill -f xbindkeys
  +
$ xbindkeys
  +
  +
{{Ic|~/.xbindkeysrc}} の設定例:
  +
  +
"xvkbd -text "\[F8]""
  +
m:0x0 + b:8
  +
"xvkbd -text "\[Shift]\[Left]""
  +
m:0x0 + b:9
  +
"xvkbd -text "\[Shift]\[Right]""
  +
m:0x0 + b:10
  +
"xvkbd -text 2"
  +
m:0x0 + b:11
  +
"xvkbd -text 3"
  +
m:0x0 + b:12
  +
  +
マウスボタンの番号を確認したいときは xev を使ってください。xvkbd -text では必ず大文字を入力して、括弧開き ([) を \ でエスケープしてください。
  +
  +
以下は xbindkeys で X のセレクションの貼り付け (中クリックのペースト) を有効にする例です。xsel と xvkbd のインストールが必要で、マウスのボタン 13 が押されたときにコマンドを実行します ({{ic|~/.xbindkeysrc}}):
  +
  +
"xvkbd -no-jump-pointer -text "\D1$(xsel)" 2>/dev/null"
  +
b:13
  +
  +
以下は Meta+M のキーバインドの例です:
  +
"xvkbd -text "\{+Super_L}m\{-Super_L}""
  +
b:10
  +
  +
==== evrouter ====
  +
  +
プログラム (特にゲーム) によっては別の方法で入力を読み込むため、もう一つのプログラムが必要になります: {{AUR|evrouter}}。
  +
  +
{{ic|evrouter}} コマンドで入力デバイスを読み込むには、{{ic|input}} グループのユーザー (あるいは root) でコマンドを実行しなければなりません。ユーザーをグループに追加するには:
  +
  +
# gpasswd -a ''user'' input
  +
  +
{{ic|--dump}} オプションを使うことで変更するボタンの名前を表示することができます:
  +
  +
{{Tip|USB デバイスであれば udev は通常 {{ic|/dev/input/by-id/}} にシンボリックリンクを作成するので、それを使って特定のデバイスを指定できます。}}
  +
  +
{{hc|$ evrouter --dump /dev/input/event*|device 0: /dev/input/event0: AT Translated Set 2 keyboard
  +
device 1: /dev/input/event1: Microsoft Microsoft Trackball Explorer®
  +
device 2: /dev/input/event2: Sleep Button
  +
device 3: /dev/input/event3: Power Button
  +
device 4: /dev/input/event4: Power Button
  +
device 5: /dev/input/event5: PC Speaker
  +
Display name: :0.0
  +
}}
  +
  +
それから変更したいボタンを押してください:
  +
  +
Window "(null)": # Window title
  +
# Window "(null)": # Resource name
  +
# Window "(null)": # Class name
  +
"Microsoft Trackball Explorer®" "/dev/input/event1" none key/275 "fill this in!"
  +
  +
Window "(null)": # Window title
  +
# Window "(null)": # Resource name
  +
# Window "(null)": # Class name
  +
"Microsoft Trackball Explorer®" "/dev/input/event1" none key/276 "fill this in!"
  +
  +
文末が "fill this in!" になっている行を設定ファイル (デフォルトでは {{ic|~/.evrouterrc}}) にコピーできます。例えば、evrouter に組み込まれている X11 のキーイベントエミュレータを使用して:
  +
  +
{{hc|~/.evrouterrc|"Microsoft Trackball Explorer®" "/dev/input/event*" any key/275 "XKey/1"
  +
"Microsoft Trackball Explorer®" "/dev/input/event*" any key/276 "XKey/2"}}
  +
  +
起動時に udev が別のデバイス番号を付与した場合を想定して 'event1' は 'event*' に変更してあります。また、'none' を 'any' に変更することで、ボタンが押されたときに修飾キーが押されていても、ルールが適用されるようにしています。フィールドの詳しい説味は {{man|1|evrouter|url=}} を見てください。
  +
  +
{{Tip|ルールは特定のウィンドウだけに適用させることもできます。詳しくは {{man|1|evrouter|url=}} を参照。}}
  +
  +
設定ファイルの作成後、デーモンとして実行:
  +
  +
$ evrouter /dev/input/event*
  +
  +
デーモンを停止するには:
  +
  +
$ evrouter -q
  +
$ rm -f /tmp/.evrouter*
  +
  +
{{Note|{{ic|/tmp/.evrouter:0.0}} ファイルが存在すると {{ic|evrouter}} は起動に失敗します。手動で削除してください。}}
  +
  +
== ユーザーツール ==
  +
  +
このセクションでは、マウス設定、特にボタンの設定に役立つハードウェア固有のツールの概要を説明します。一般的なリマップツールについては、[[入力リマップユーティリティ]] を参照してください。
  +
  +
* [https://github.com/libratbag/piper Piper] ({{Pkg|piper}}) は、ゲーミングマウスを設定するためのグラフィカルユーザーインターフェイスであり、Wayland と連携して動作します。マウスを操作するには、そのマウスが [https://github.com/libratbag/libratbag/tree/master/data/devices サポートされるデバイスのリスト] に含まれている必要があります。
  +
* Logitech MX マウスの {{AUR|lomoco}} は、適切な解像度の設定、スマートスクロールの有効化または無効化 (起動時のサポートも) などに役立ちます。{{ic|/etc/udev/lomoco_mouse.conf}} を開き、[[udev]] によってマウスがロードされたときに自動的に適用されるオプションを設定します。{{Note|lomoco パッケージが古い可能性があります。新しい Logitech マウス用のハックがあります: [http://piie.net/temp/g5_hiddev.c]}}
  +
* {{AUR|logiops}} は、Logicool マウスを設定するためのツール (Logicool Options for Linux) です。ボタンをアクションに再マップしたり、ジェスチャー、スマート シフトなどをサポートしたりできます。
  +
  +
== evdev Xorg.conf のセットアップ ==
  +
  +
このセクションでは、{{ic|evdev}} を使用して 3 つ以上のボタンを備えたマウスをセットアップする方法について説明します。これを実現する方法は他にもありますが、ここで説明するメモやツールの一部は、他のニーズを持つ人にとって役立つかもしれません。一部のパーツは、他のドライバーを使用して追加のマウス ボタンを機能させるのに役立つ場合があります。
  +
  +
Xorg の evdev ドライバーを使用します。EVentDEVice は、標準の Xorg {{ic|mouse}} ドライバーよりもはるかに優れた能力を提供する USB 入力デバイス用の高度なドライバーです。また、{{ic|mouse}} ドライバーよりも ''直接的'' であるため、待ち時間が短くなり、変換の問題も少なくなります。
  +
  +
* {{ic|evdev}} はカーネルモジュールと Xorg 入力ドライバーの両方であることに注意してください。すべての Arch カーネルには、{{ic|evdev}} モジュールが付属しています。
  +
  +
Xorg 11R7.0 以降では、{{ic|/etc/X11/xorg.conf}} に次の変更を加えるだけで済みます。
  +
  +
=== マウスの名前を確認 ===
   
 
{{Note|正確な情報を得るために、Xorg やマウスのドライバーをロードする前にコマンドを実行する必要がある場合もあります。}}
 
{{Note|正確な情報を得るために、Xorg やマウスのドライバーをロードする前にコマンドを実行する必要がある場合もあります。}}
40行目: 179行目:
 
デバイスの名前をコピーしたら、{{ic|/etc/X11/xorg.conf}} を開いて下さい。
 
デバイスの名前をコピーしたら、{{ic|/etc/X11/xorg.conf}} を開いて下さい。
   
== Xorg の設定 ==
+
=== Xorg の設定 ===
   
 
X がマウスを使う方法を設定するため {{ic|xorg.conf}} にエントリを記述します。エントリは以下のようになります:
 
X がマウスを使う方法を設定するため {{ic|xorg.conf}} にエントリを記述します。エントリは以下のようになります:
78行目: 217行目:
 
$ ls /dev/input/by-id/
 
$ ls /dev/input/by-id/
   
== 設定後 ==
+
=== evdev Xorg.conf 設定後 ===
   
=== Google Chrome ===
+
==== Google Chrome ====
   
 
動作します。横スクロールは何も設定しなくても動作します。スクロールホイールを左右に押して下さい。親指ボタンで次/前のページに移動します。
 
動作します。横スクロールは何も設定しなくても動作します。スクロールホイールを左右に押して下さい。親指ボタンで次/前のページに移動します。
   
=== Opera ===
+
==== Opera ====
   
 
動作します。ボタンのマッピングは {{Ic|Preferences > Advanced > Shortcuts > Mouse set-up}} で簡単に変えられます。例えば、''button 8'' を ''back'' にバインドするには:
 
動作します。ボタンのマッピングは {{Ic|Preferences > Advanced > Shortcuts > Mouse set-up}} で簡単に変えられます。例えば、''button 8'' を ''back'' にバインドするには:
92行目: 231行目:
 
# アクションカラムに、次を入力: ''Back''
 
# アクションカラムに、次を入力: ''Back''
   
=== Firefox ===
+
==== Firefox ====
   
==== 横スクロール ====
+
===== 横スクロール =====
   
  +
左と右のスクロールの代わりに、戻ると進むを有効にするには、{{ic|about:config}} で以下の設定を変更します:
=====Firefox 20 以上=====
 
左と右のスクロールの代わりに、戻ると進むを有効にするには、{{ic|about:config}} で以下の設定を変更します (バージョン 32 で確認済み):
 
   
 
mousewheel.default.action.override_x 2
 
mousewheel.default.action.override_x 2
 
mousewheel.default.delta_multiplier_x -100
 
mousewheel.default.delta_multiplier_x -100
   
=====古いバージョ=====
+
==== 親指ボタ - 進むと戻る ====
   
  +
{{Note |以下は、xev がすべてのマウスボタンを正しく検出する (アプリごとに機能をマッピングできる) か、それともデフォルトの動作を変更するかによって、冗長になる可能性があります。}}
デフォルトでは、FX/MX マウスの左右スクロールは戻ると進むに翻訳されます。スクロールのままにしたい場合、{{ic|about:config}} を開いて以下の値を変更してください:
 
   
  +
キーストロークを適当なマウスボタンにマッピングして {{AUR|xvkbd}} と {{Pkg|xbindkeys}} をインストールする必要があります。
mousewheel.horizscroll.withnokey.action 0
 
mousewheel.horizscroll.withnokey.numlines -3
 
 
もしくは (Logitech G5 で確認):
 
 
mousewheel.horizscroll.withnokey.action 2
 
mousewheel.horizscroll.withnokey.numlines 2
 
 
{{Note|numlines で正数を使うと、右と左が切り替わります。左を押すとウィンドウは右にスクロールします。}}
 
 
=== 親指ボタン - 進むと戻る ===
 
 
{{Note | The following maybe redundant depending on whether xev detects all your mouse buttons correctly (functions can be mapped on a per-app basis) or you want to change the default behaviour.}}
 
 
キーストロークを適当なマウスボタンにマッピングして {{Pkg|xvkbd}} と {{Pkg|xbindkeys}} をインストールする必要があります。
 
   
 
戻る/進むを使用する最近のアプリケーションでは、デフォルトで XF86Back が戻るに、XF86Forward が進むにマッピングされています。ほとんどの MX マウスでは親指ボタンは 8 や 9 と認識されます。使用しているボタンで番号が異なっている場合、xev を使ってボタンの番号を確認して例で使われている番号を置き換えて下さい (b:8 & b:9)。
 
戻る/進むを使用する最近のアプリケーションでは、デフォルトで XF86Back が戻るに、XF86Forward が進むにマッピングされています。ほとんどの MX マウスでは親指ボタンは 8 や 9 と認識されます。使用しているボタンで番号が異なっている場合、xev を使ってボタンの番号を確認して例で使われている番号を置き換えて下さい (b:8 & b:9)。
137行目: 261行目:
 
詳しい情報は [[en2:Logitech MX1000|Logitech MX1000]] にあります。
 
詳しい情報は [[en2:Logitech MX1000|Logitech MX1000]] にあります。
   
=== xmodmap の調整 ===
+
==== xmodmap の調整 ====
   
  +
{{Note |evdev では以下のどれも必要ありませんが、evdev 以外のユーザーのためにここにあります。マウスで問題が発生しない限り、このセクション全体を無視してください。}}
{{Note | None of the below is necessary with evdev, but it's here for non-evdev users. Unless something does not work on your mouse, ignore this whole section!}}
 
   
 
{{ic|.xinitrc}} を使って X をロードしている場合、以下を {{ic|.xinitrc}} に追加してください (ボタンの数字は必要に応じて変更してください):
 
{{ic|.xinitrc}} を使って X をロードしている場合、以下を {{ic|.xinitrc}} に追加してください (ボタンの数字は必要に応じて変更してください):
155行目: 279行目:
 
Xorg に含まれている 'xev' というプログラムを使ってボタンを確認することもできます。xev を実行すると、デスクトップに小さなボックスが表示されるので、カーソルを合わせてボタンをクリックすることで、ボタンのマッピングがわかります。
 
Xorg に含まれている 'xev' というプログラムを使ってボタンを確認することもできます。xev を実行すると、デスクトップに小さなボックスが表示されるので、カーソルを合わせてボタンをクリックすることで、ボタンのマッピングがわかります。
   
=== xinput の調整 ===
+
==== xinput の調整 ====
   
 
デバッグ時は {{ic|xinput}} を使うことでユーザー空間で即座にボタンマップを変更できます。Logitech M505/B605 マウスの場合の実行例:
 
デバッグ時は {{ic|xinput}} を使うことでユーザー空間で即座にボタンマップを変更できます。Logitech M505/B605 マウスの場合の実行例:
161行目: 285行目:
 
$ xinput set-button-map "$(xinput | awk -F'[=]' '/Logitech M505\/B605/ {print $2}' | awk '{print $1}')" 1 2 3 4 5 8 9
 
$ xinput set-button-map "$(xinput | awk -F'[=]' '/Logitech M505\/B605/ {print $2}' | awk '{print $1}')" 1 2 3 4 5 8 9
   
  +
==デバイスごとの設定ファイル==
== 他の方法 ==
 
   
  +
=== Logitech G600===
以下の方法は evdev ドライバーの代わりに X.org の標準のマウス入力ドライバー (xf86-input-mouse) を使います。7つまでボタンがあるマウスで動作します。下記の変更を適用するには {{ic|/etc/X11/xorg.conf}} の InputDevice セクションを編集してください。設定後、X を再起動すれば適用されます。
 
  +
xorg-server 1.18.0-3 では G600 のサイドボタンはキーボードデバイスとして認識されず、おかしな挙動が発生することがあります (マウスボタンをクリックするとマウスカーソルが画面の端に飛ばされる)。強制的にキーボードボタンとして認識させるために、以下のセクションを {{ic|/etc/X11/xorg.conf}} に追加してください:
   
  +
Section "InputClass"
=== IMPS/2 ===
 
  +
Identifier "G600 misconfiguration fix"
  +
MatchProduct "G600"
  +
# Match just the keyboard section of the G600
  +
MatchIsKeyboard "true"
  +
# evdev assumes it's a mouse when it sees the absolute axis. Stop that from happening.
  +
Option "IgnoreAbsoluteAxes" "on"
  +
EndSection
   
  +
=== Mad Catz ===
IntelliMouse Explorer 3.0 でテスト済みです。全てのマウスで動作するという保証はありません。
 
   
  +
[[Mad Catz]] を見てください。
Driver "mouse"
 
Option "Protocol" "IMPS/2"
 
Option "Device" "/dev/input/mice"
 
Option "ZAxisMapping" "4 5 6 7"
 
   
=== ExplorerPS/2 ===
+
=== Logitech M560/M545/M546 ===
  +
これらのマウスは Windows 8 用に設計されており、通常通りの挙動を示しません: マウスとキーボードのペアとして認識され、ボタンによっては通常のマウスボタンのイベントが発火せず、キーボードとマウスボタンのコンビネーションと認識されます。そのため Linux で"快適"なマウスとして使うのは厳しくなっています。
   
  +
ドライバーを使うことで通常のマウスのように使うことができます:
Logitech MX400 と MX518 でテスト済みです。7つまでボタンがある MX シリーズのマウスで動作します。
 
   
  +
[https://github.com/kreijack/logitech-m560 M560 のカーネルモジュール] (カーネル v4.2 でマージされています), [https://github.com/CzBiX/logitech-m560/tree/m545 M545/M546 のカーネルモジュール]
Driver "mouse"
 
Option "Protocol" "ExplorerPS/2"
 
Option "Device" "/dev/input/mice"
 
Option "Buttons" "7"
 
Option "ZAxisMapping" "4 5"
 
Option "ButtonMapping" "1 2 3 6 7"
 
   
  +
また、xbindkeys でボタンをマッピングすることを推奨します。
上記の設定は USB で接続する Microsoft InteliMouse Explorer 3.0 でも使えます。
 
 
=== Auto ===
 
 
Logitech MX400 でテスト済みです。7つまでボタンがある大抵のマウスで動作します。
 
 
Driver "mouse"
 
Option "Protocol" "auto"
 
Option "Device" "/dev/input/mice"
 
Option "Buttons" "7"
 
Option "ZAxisMapping" "4 5"
 
Option "ButtonMapping" "1 2 3 6 7"
 
 
以下の設定は Logitech MX1000 で動作することを確認しています。
 
 
Driver "mouse"
 
Option "Protocol" "auto"
 
Option "Device" "/dev/input/mice"
 
Option "Emulate3Buttons" "no"
 
Option "Buttons" "12"
 
Option "ZAxisMapping" "4 5 7 6 8 9"
 
 
=== easystroke ===
 
 
[http://sourceforge.net/projects/easystroke/ easystroke] は X11 用のジェスチャー認識アプリケーションです。ただしマウスボタンの管理に使うこともできます。btnx と比べて多目的に使えることが主な利点です。一方で、ユーザーベースなので、ユーザーごとに設定をする必要があります。
 
 
easystroke で特別なマウスボタンを管理するには、以下を実行 (Back/Forward マウスボタンの例):
 
easystroke -g
 
Preferences タブ > Additional buttons > Add から特殊なボタンを追加してください。
 
{{Note|easystroke がマウスボタンを自動的に検出しない場合、手動で指定できます。ボタンの識別子 (番号) は xev で確認してください。}}
 
 
''Action tab > Add action'' から、新しいアクションに名前を付けて、Type で "Key" を選択、Details から "Alt+Left" で Back ボタンを、"Alt+Right" で Forward ボタンを設定して、Stroke クリックで適当なマウスボタンをクリックしてください (警告が表示されたら確認してください)。それでマウスボタンの設定は完了です。
 
 
== キーボードをマウスボタンにバインド ==
 
 
=== xvkbd と xbindkeys ===
 
 
マウスボタンをキーボードにバインドしたいとします。問題はキーの押下をエミュレートする方法がわからないということです。そこで {{Pkg|xvkbd}} が役に立ちます。{{Pkg|xbindkeys}} と一緒に使うことができます:
 
 
$ xbindkeys --defaults >> ~/.xbindkeysrc
 
$ xbindkeys
 
 
xbindkeys を再起動するには以下を実行:
 
 
$ pkill -f xbindkeys
 
$ xbindkeys
 
 
{{Ic|~/.xbindkeysrc}} の設定例:
 
 
"xvkbd -text "\[F8]""
 
m:0x0 + b:8
 
"xvkbd -text "\[Shift]\[Left]""
 
m:0x0 + b:9
 
"xvkbd -text "\[Shift]\[Right]""
 
m:0x0 + b:10
 
"xvkbd -text 2"
 
m:0x0 + b:11
 
"xvkbd -text 3"
 
m:0x0 + b:12
 
 
マウスボタンの番号を確認したいときは xev を使ってください。xvkbd -text では必ず大文字を入力して、括弧開き ([) を \ でエスケープしてください。
 
 
以下は xbindkeys で X のセレクションの貼り付け (中クリックのペースト) を有効にする例です。xsel と xvkbd のインストールが必要で、マウスのボタン 13 が押されたときにコマンドを実行します ({{ic|~/.xbindkeysrc}}):
 
 
"xvkbd -no-jump-pointer -text "\D1$(xsel)" 2>/dev/null"
 
b:13
 
 
以下は Meta+M のキーバインドの例です:
 
"xvkbd -text "\{+Super_L}m\{-Super_L}""
 
b:10
 
 
=== evrouter ===
 
 
プログラム (特にゲーム) によっては別の方法で入力を読み込むため、もう一つのプログラムが必要になります: {{AUR|evrouter}}。
 
 
{{ic|evrouter}} コマンドで入力デバイスを読み込むには、{{ic|input}} グループのユーザー (あるいは root) でコマンドを実行しなければなりません。ユーザーをグループに追加するには:
 
 
# gpasswd -a ''user'' input
 
 
{{ic|--dump}} オプションを使うことで変更するボタンの名前を表示することができます:
 
 
{{Tip|USB デバイスであれば udev は通常 {{ic|/dev/input/by-id/}} にシンボリックリンクを作成するので、それを使って特定のデバイスを指定できます。}}
 
 
{{hc|$ evrouter --dump /dev/input/event*|device 0: /dev/input/event0: AT Translated Set 2 keyboard
 
device 1: /dev/input/event1: Microsoft Microsoft Trackball Explorer®
 
device 2: /dev/input/event2: Sleep Button
 
device 3: /dev/input/event3: Power Button
 
device 4: /dev/input/event4: Power Button
 
device 5: /dev/input/event5: PC Speaker
 
Display name: :0.0
 
}}
 
 
それから変更したいボタンを押してください:
 
 
Window "(null)": # Window title
 
# Window "(null)": # Resource name
 
# Window "(null)": # Class name
 
"Microsoft Trackball Explorer®" "/dev/input/event1" none key/275 "fill this in!"
 
 
Window "(null)": # Window title
 
# Window "(null)": # Resource name
 
# Window "(null)": # Class name
 
"Microsoft Trackball Explorer®" "/dev/input/event1" none key/276 "fill this in!"
 
 
文末が "fill this in!" になっている行を設定ファイル (デフォルトでは {{ic|~/.evrouterrc}}) にコピーできます。例えば、evrouter に組み込まれている X11 のキーイベントエミュレータを使用して:
 
 
{{hc|~/.evrouterrc|"Microsoft Trackball Explorer®" "/dev/input/event*" any key/275 "XKey/1"
 
"Microsoft Trackball Explorer®" "/dev/input/event*" any key/276 "XKey/2"}}
 
 
起動時に udev が別のデバイス番号を付与した場合を想定して 'event1' は 'event*' に変更してあります。また、'none' を 'any' に変更することで、ボタンが押されたときに修飾キーが押されていても、ルールが適用されるようにしています。フィールドの詳しい説味は {{ic|man 1 evrouter}} を見てください。
 
 
{{Tip|ルールは特定のウィンドウだけに適用させることもできます。詳しくは {{ic|man 1 evrouter}} を参照。}}
 
 
設定ファイルの作成後、デーモンとして実行:
 
 
$ evrouter /dev/input/event*
 
 
デーモンを停止するには:
 
 
$ evrouter -q
 
$ rm -f /tmp/.evrouter*
 
 
{{Note|{{ic|/tmp/.evrouter:0.0}} ファイルが存在すると {{ic|evrouter}} は起動に失敗します。手動で削除してください。}}
 
   
 
=== Logitech G5 マウスの + と - のバインド ===
 
=== Logitech G5 マウスの + と - のバインド ===
327行目: 330行目:
 
systemd ユニットを使うことで起動時に g5hack ツールを実行できます。詳しくは [[Systemd#ユニットファイル]]を見てください。
 
systemd ユニットを使うことで起動時に g5hack ツールを実行できます。詳しくは [[Systemd#ユニットファイル]]を見てください。
   
  +
== Arch がゲスト仮想マシンの場合 ==
== ユーザーツール ==
 
   
  +
2 つまたは 3 つを超えるマウス ボタンをサポートしたい場合、その機能はハイパーバイザーソフトウェアによって異なります。
{{AUR|imwheel}} でマウスの回転やボタンのマッピングを設定することができます。システム全体で設定したり、あるいは個別のプロセスごとに設定できます。
 
   
  +
=== VMware ワークステーション ===
全てのアプリケーションで前に戻る・先に進むのボタンを有効にして Chromium でスクロール速度を上げる {{ic|~/.imwheelrc}} の例:
 
"^chromium$"
 
None, Up, Button4, 3
 
None, Down, Button5, 3<br/>
 
".*"
 
None, Thumb1, Alt_L|Left
 
None, Thumb2, Alt_L|Right
 
   
  +
Arch ベースのゲスト VM の場合、その ''.vmx'' 設定ファイルに以下の行を追加します:
また、[[公式リポジトリ]]にある Logitech MX 用のツールである {{Pkg|lomoco}} は解像度を設定したり、スマートスクロールを有効化・無効化したりできます。
 
  +
mouse.vusb.enable = "TRUE"
 
  +
mouse.vusb.useBasicMouse = "FALSE"
{{ic|/etc/udev/lomoco_mouse.conf}} を開いて、マウスが [[udev]] によってロードされたときに自動的に適用したいオプションを設定してください。
 
{{Note|The lomoco package may be out of date. There is a hack for newer Logitech mice: [http://piie.net/temp/g5_hiddev.c]}}
 
 
==デバイスごとの設定ファイル==
 
 
=== Logitech G600===
 
xorg-server 1.18.0-3 では G600 のサイドボタンはキーボードデバイスとして認識されず、おかしな挙動が発生することがあります (マウスボタンをクリックするとマウスカーソルが画面の端に飛ばされる)。強制的にキーボードボタンとして認識させるために、以下のセクションを {{ic|/etc/X11/xorg.conf}} に追加してください:
 
 
Section "InputClass"
 
Identifier "G600 misconfiguration fix"
 
MatchProduct "G600"
 
# Match just the keyboard section of the G600
 
MatchIsKeyboard "true"
 
# evdev assumes it's a mouse when it sees the absolute axis. Stop that from happening.
 
Option "IgnoreAbsoluteAxes" "on"
 
EndSection
 
 
=== Mad Catz ===
 
 
[[Mad Catz]] を見てください。
 
 
=== Logitech M560/M545/M546 ===
 
これらのマウスは Windows 8 用に設計されており、通常通りの挙動を示しません: マウスとキーボードのペアとして認識され、ボタンによっては通常のマウスボタンのイベントが発火せず、キーボードとマウスボタンのコンビネーションと認識されます。そのため Linux で"快適"なマウスとして使うのは厳しくなっています。
 
 
ドライバーを使うことで通常のマウスのように使うことができます:
 
 
[https://github.com/kreijack/logitech-m560 M560 のカーネルモジュール] (カーネル v4.2 でマージされています), [https://github.com/CzBiX/logitech-m560/tree/m545 M545/M546 のカーネルモジュール]
 
 
また、xbindkeys でボタンをマッピングすることを推奨します。
 

2024年2月4日 (日) 23:14時点における最新版

関連記事

この記事では 3 つ以上のマウスボタンが付いているマウスを設定する方法について説明します。

Xでマウス入力をテストする前提条件

このページでは、Waylandではなく、Xorg (X Window System) を使っていることを前提にしています。

まず、X があなたのマウスから何を見るかを確認したいと思うでしょう。X のイベントは xev ユーティリティで表示することができます。実行することでウィンドウがポップアップします。

$ xev -event button | grep button

そのウィンドウの xevents (移動、サイズ変更、クリックなど) は、xev を起動したコンソールに報告されます。"ボタン" を含む行をフィルタリングしているため、マウスのクリックとリリースのイベントが、関連するボタン番号とともに表示されます。ほとんどのマウスの場合、これは左ボタンの場合は '1'、中央のボタンは '2'、右ボタンの場合は '3' になります。他のボタンは異なります (たとえば、Logicool MX Master 3 の場合、スクロールホイールは 4 と 5、サムホイールは 6 と 7、親指の先のボタンは 9、親指の内側のボタンは 8)

出力例:

state 0x0, button 1, same_screen YES
state 0x100, button 1, same_screen YES
state 0x0, button 9, same_screen YES
state 0x0, button 9, same_screen YES

これは、マウスの左クリックとリリースに続いて親指の先でクリックとリリースに相当します。

xev を使用すると、マウスボタンの番号を確認し、X にマウスクリックが通知されていることを確認できます。

マウスとキーボードの機能の再バインド

このセクションでは、さまざまなツールを使用してマウスとキーボードの機能を再配置する方法について詳しく説明します。

マウスボタンをキーボード機能にバインドする

xte

xautomationxte は、キーボードのボタンをマウスにバインドする場合に便利です。

これは、Shift_R をマウス ボタン 3 ("右クリック") にバインドする ~/.xbindkeysrc の例です:

~/.xbindkeysrc
"xte 'mouseclick 3'"
  Shift_R

キーボードをマウスボタンにバインド

xvkbd と xbindkeys

マウスボタンをキーボードにバインドしたいとします。問題はキーの押下をエミュレートする方法がわからないということです。そこで xvkbdAUR が役に立ちます。xbindkeys と一緒に使うことができます:

$ xbindkeys --defaults >> ~/.xbindkeysrc
$ xbindkeys

xbindkeys を再起動するには以下を実行:

$ pkill -f xbindkeys
$ xbindkeys 

~/.xbindkeysrc の設定例:

"xvkbd  -text "\[F8]""
       m:0x0 + b:8
"xvkbd  -text "\[Shift]\[Left]""
       m:0x0 + b:9
"xvkbd  -text "\[Shift]\[Right]""
       m:0x0 + b:10
"xvkbd  -text 2"
       m:0x0 + b:11
"xvkbd  -text 3"
       m:0x0 + b:12

マウスボタンの番号を確認したいときは xev を使ってください。xvkbd -text では必ず大文字を入力して、括弧開き ([) を \ でエスケープしてください。

以下は xbindkeys で X のセレクションの貼り付け (中クリックのペースト) を有効にする例です。xsel と xvkbd のインストールが必要で、マウスのボタン 13 が押されたときにコマンドを実行します (~/.xbindkeysrc):

"xvkbd -no-jump-pointer -text "\D1$(xsel)" 2>/dev/null"
b:13

以下は Meta+M のキーバインドの例です:

"xvkbd  -text "\{+Super_L}m\{-Super_L}""
b:10

evrouter

プログラム (特にゲーム) によっては別の方法で入力を読み込むため、もう一つのプログラムが必要になります: evrouterAUR

evrouter コマンドで入力デバイスを読み込むには、input グループのユーザー (あるいは root) でコマンドを実行しなければなりません。ユーザーをグループに追加するには:

# gpasswd -a user input

--dump オプションを使うことで変更するボタンの名前を表示することができます:

ヒント: USB デバイスであれば udev は通常 /dev/input/by-id/ にシンボリックリンクを作成するので、それを使って特定のデバイスを指定できます。
$ evrouter --dump /dev/input/event*
device  0: /dev/input/event0: AT Translated Set 2 keyboard
device  1: /dev/input/event1: Microsoft Microsoft Trackball Explorer®
device  2: /dev/input/event2: Sleep Button
device  3: /dev/input/event3: Power Button
device  4: /dev/input/event4: Power Button
device  5: /dev/input/event5: PC Speaker
Display name: :0.0

それから変更したいボタンを押してください:

Window "(null)": # Window title
# Window "(null)": # Resource name
# Window "(null)": # Class name
"Microsoft Trackball Explorer®" "/dev/input/event1" none key/275 "fill this in!"

Window "(null)": # Window title
# Window "(null)": # Resource name
# Window "(null)": # Class name
"Microsoft Trackball Explorer®" "/dev/input/event1" none key/276 "fill this in!"

文末が "fill this in!" になっている行を設定ファイル (デフォルトでは ~/.evrouterrc) にコピーできます。例えば、evrouter に組み込まれている X11 のキーイベントエミュレータを使用して:

~/.evrouterrc
"Microsoft Trackball Explorer®" "/dev/input/event*" any key/275 "XKey/1"
"Microsoft Trackball Explorer®" "/dev/input/event*" any key/276 "XKey/2"

起動時に udev が別のデバイス番号を付与した場合を想定して 'event1' は 'event*' に変更してあります。また、'none' を 'any' に変更することで、ボタンが押されたときに修飾キーが押されていても、ルールが適用されるようにしています。フィールドの詳しい説味は evrouter(1) を見てください。

ヒント: ルールは特定のウィンドウだけに適用させることもできます。詳しくは evrouter(1) を参照。

設定ファイルの作成後、デーモンとして実行:

$ evrouter /dev/input/event*

デーモンを停止するには:

$ evrouter -q
$ rm -f /tmp/.evrouter*
ノート: /tmp/.evrouter:0.0 ファイルが存在すると evrouter は起動に失敗します。手動で削除してください。

ユーザーツール

このセクションでは、マウス設定、特にボタンの設定に役立つハードウェア固有のツールの概要を説明します。一般的なリマップツールについては、入力リマップユーティリティ を参照してください。

  • Piper (piper) は、ゲーミングマウスを設定するためのグラフィカルユーザーインターフェイスであり、Wayland と連携して動作します。マウスを操作するには、そのマウスが サポートされるデバイスのリスト に含まれている必要があります。
  • Logitech MX マウスの lomocoAUR は、適切な解像度の設定、スマートスクロールの有効化または無効化 (起動時のサポートも) などに役立ちます。/etc/udev/lomoco_mouse.conf を開き、udev によってマウスがロードされたときに自動的に適用されるオプションを設定します。
    ノート: lomoco パッケージが古い可能性があります。新しい Logitech マウス用のハックがあります: [1]
  • logiopsAUR は、Logicool マウスを設定するためのツール (Logicool Options for Linux) です。ボタンをアクションに再マップしたり、ジェスチャー、スマート シフトなどをサポートしたりできます。

evdev Xorg.conf のセットアップ

このセクションでは、evdev を使用して 3 つ以上のボタンを備えたマウスをセットアップする方法について説明します。これを実現する方法は他にもありますが、ここで説明するメモやツールの一部は、他のニーズを持つ人にとって役立つかもしれません。一部のパーツは、他のドライバーを使用して追加のマウス ボタンを機能させるのに役立つ場合があります。

Xorg の evdev ドライバーを使用します。EVentDEVice は、標準の Xorg mouse ドライバーよりもはるかに優れた能力を提供する USB 入力デバイス用の高度なドライバーです。また、mouse ドライバーよりも 直接的 であるため、待ち時間が短くなり、変換の問題も少なくなります。

  • evdev はカーネルモジュールと Xorg 入力ドライバーの両方であることに注意してください。すべての Arch カーネルには、evdev モジュールが付属しています。

Xorg 11R7.0 以降では、/etc/X11/xorg.conf に次の変更を加えるだけで済みます。

マウスの名前を確認

ノート: 正確な情報を得るために、Xorg やマウスのドライバーをロードする前にコマンドを実行する必要がある場合もあります。

まず最初にマウスの名前を確認します。次のコマンドを実行してください:

$ egrep "Name|Handlers" /proc/bus/input/devices | egrep -B1 'Handlers.*mouse'

以下のような出力がされます:

N: Name="Logitech USB Gaming Mouse"
H: Handlers=mouse0 event0 ts0 

もしくはマウスが複数ある場合:

N: Name="Kensington Kensington Expert Mouse Wireless"
H: Handlers=event0 mouse0 
--
N: Name="Logitech USB Receiver"
H: Handlers=kbd event2 mouse1

Handlers=mouse0 というのがマウスであり、デバイスの名前は Logitech USB Gaming Mouse です。名前はマウスによって異なります。

デバイスの名前をコピーしたら、/etc/X11/xorg.conf を開いて下さい。

Xorg の設定

X がマウスを使う方法を設定するため xorg.conf にエントリを記述します。エントリは以下のようになります:

Section "InputDevice"
  Identifier      "Evdev Mouse"
  Driver          "evdev"
  Option          "Name" "Logitech USB Gaming Mouse"
  Option          "evBits"  "+1-2"
  Option          "keyBits" "~272-287"
  Option          "relBits" "~0-2 ~6 ~8"
  Option          "Pass"    "3"
  Option          "CorePointer"
EndSection

Name オプションは先にコピーした名前に置き換えて下さい。マウスを複数使う場合や Xorg をロードしたときにエラーが発生する場合は CorePointer オプションは外して下さい。他のオプションはどれも evdev の基本的なマウス設定で、ほとんどのマウスで機能します。

次に、マウスを使うように X を設定します。xorg.confServerLayout を見て下さい。

ServerLayout セクションを修正してデバイスとして "Evdev Mouse" を使うようにしてください。設定したら、以下のようになります:

Section "ServerLayout"
  Identifier     "Default Layout"
  Screen 0       "Monitor0" 0 0
  InputDevice    "Keyboard0" "CoreKeyboard"
  InputDevice    "Evdev Mouse" "CorePointer"
EndSection

レイアウトで変更する必要があるのは (マウスを示す) InputDevice 行だけです。

Logitech G5 マウスを使っていてマウスが動作しない場合、InputDevice セクションに以下を記述してみてください ([#] は egrep 'Name|Handlers' /proc/bus/input/devices で確認できる数字に置き換えて下さい)。必要ない場合は、記述しないでください。

Option "Device" "/dev/input/event[#]"

上記の方法で、再起動後にマウスが動作しなくなる場合、/dev/input/by-id にシンボリックリンクを作成してみてください。例:

Option      "Device" "/dev/input/by-id/usb-Logitech_USB_Receiver-event-mouse"

適当な ID は、次を実行することで確認できます:

$ ls /dev/input/by-id/

evdev Xorg.conf 設定後

Google Chrome

動作します。横スクロールは何も設定しなくても動作します。スクロールホイールを左右に押して下さい。親指ボタンで次/前のページに移動します。

Opera

動作します。ボタンのマッピングは Preferences > Advanced > Shortcuts > Mouse set-up で簡単に変えられます。例えば、button 8back にバインドするには:

  1. マウスの設定から Application ドロップダウンを開く
  2. インプットカラムに、次を入力: Button 8
  3. アクションカラムに、次を入力: Back

Firefox

横スクロール

左と右のスクロールの代わりに、戻ると進むを有効にするには、about:config で以下の設定を変更します:

mousewheel.default.action.override_x         2
mousewheel.default.delta_multiplier_x       -100

親指ボタン - 進むと戻る

ノート: 以下は、xev がすべてのマウスボタンを正しく検出する (アプリごとに機能をマッピングできる) か、それともデフォルトの動作を変更するかによって、冗長になる可能性があります。

キーストロークを適当なマウスボタンにマッピングして xvkbdAURxbindkeys をインストールする必要があります。

戻る/進むを使用する最近のアプリケーションでは、デフォルトで XF86Back が戻るに、XF86Forward が進むにマッピングされています。ほとんどの MX マウスでは親指ボタンは 8 や 9 と認識されます。使用しているボタンで番号が異なっている場合、xev を使ってボタンの番号を確認して例で使われている番号を置き換えて下さい (b:8 & b:9)。

MX マウスを使っている場合、以下の内容で ~/.xbindkeysrc ファイルを作成します:

# Mouse Buttons
"xvkbd -xsendevent -text "\[XF86Back]""
m:0x0 + b:8 
"xvkbd -xsendevent -text "\[XF86Forward]""
m:0x0 + b:9

次にテストです。以下のコマンドを実行してください。問題ないようでしたら xbindkeys を .xinitrc など (X が起動するたびに読み込まれるファイル) に追加してください。また、Epiphany や Konqueror では特別な設定をしたり Imwheel を使用しなくとも機能します。

xbindkeys

詳しい情報は Logitech MX1000 にあります。

xmodmap の調整

ノート: evdev では以下のどれも必要ありませんが、evdev 以外のユーザーのためにここにあります。マウスで問題が発生しない限り、このセクション全体を無視してください。

.xinitrc を使って X をロードしている場合、以下を .xinitrc に追加してください (ボタンの数字は必要に応じて変更してください):

xmodmap -e "pointer = 1 2 3 6 7 8 9 10 11 12 4 5" &

ボタン 4 と 5 は一番最後に置いて下さい。そうしないとスクロールホイールが動作しません。

.xinitrc ではなく GDM/XDM/KDM を使っている場合、~/.Xmodmap ファイルを作成して以下を追加します (ボタンの数字は必要に応じて変更してください):

pointer = 1 2 3 6 7 8 9 10 11 12 4 5
  • GDM/XDM/KDM は ~/.Xmodmap ファイルが存在すると読み込みますが、startx は読み込みません。~/.xinitrc に次のコマンドを追加して読み込ませることもできます: xmodmap ~/.Xmodmap。何か変更が必要になったときに *DM と startx のどちらを使っている場合でも ~/.Xmodmap を編集すれば良くなります。

望み通りの動作をさせるために数字を多少弄る必要があるかもしれません。マウスによってはボタン 6 と 7 がスクロールホイールだったりします。その場合は 6 と 7 を最後の数字にしてください。上手く行くまで弄り続けて下さい。

Xorg に含まれている 'xev' というプログラムを使ってボタンを確認することもできます。xev を実行すると、デスクトップに小さなボックスが表示されるので、カーソルを合わせてボタンをクリックすることで、ボタンのマッピングがわかります。

xinput の調整

デバッグ時は xinput を使うことでユーザー空間で即座にボタンマップを変更できます。Logitech M505/B605 マウスの場合の実行例:

$ xinput set-button-map "$(xinput | awk -F'[=]' '/Logitech M505\/B605/ {print $2}' | awk '{print $1}')" 1 2 3 4 5 8 9

デバイスごとの設定ファイル

Logitech G600

xorg-server 1.18.0-3 では G600 のサイドボタンはキーボードデバイスとして認識されず、おかしな挙動が発生することがあります (マウスボタンをクリックするとマウスカーソルが画面の端に飛ばされる)。強制的にキーボードボタンとして認識させるために、以下のセクションを /etc/X11/xorg.conf に追加してください:

Section "InputClass"
    Identifier "G600 misconfiguration fix"
    MatchProduct "G600"
    # Match just the keyboard section of the G600
    MatchIsKeyboard "true"
    # evdev assumes it's a mouse when it sees the absolute axis. Stop that from happening. 
    Option "IgnoreAbsoluteAxes" "on"  
EndSection

Mad Catz

Mad Catz を見てください。

Logitech M560/M545/M546

これらのマウスは Windows 8 用に設計されており、通常通りの挙動を示しません: マウスとキーボードのペアとして認識され、ボタンによっては通常のマウスボタンのイベントが発火せず、キーボードとマウスボタンのコンビネーションと認識されます。そのため Linux で"快適"なマウスとして使うのは厳しくなっています。

ドライバーを使うことで通常のマウスのように使うことができます:

M560 のカーネルモジュール (カーネル v4.2 でマージされています), M545/M546 のカーネルモジュール

また、xbindkeys でボタンをマッピングすることを推奨します。

Logitech G5 マウスの + と - のバインド

G5/7 マウスに付いているボタン +- をバインドしたい場合 (通常は DPI を変更します)、lomoco の作者によって作成された g5hack [2] を使う必要があります。

$ wget http://piie.net/temp/g5_hiddev.c
$ gcc -o g5hack g5_hiddev.c
$ ./g5hack /dev/usb/hiddev0 3

上記のコマンドで DPI が2000に変更され、1番目の LED が点灯して DPI の動的な変更が無効化され evrouter で使えるようになります。コマンドを頻繁に実行する場合は /usr/bin ディレクトリにコピーすると良いでしょう:

# cp g5hack /usr/bin/

+- ボタンをバインドしたい場合、ファイル内の末尾付近の行 ('"-" button does not function anymore' というコメントが上にある行) を使用したいモードのところにコピーしてください。

product 0xc049 と認識される最新の G5 マウスではオリジナルのソースは使えません。#define MOUSE_G5 0xc041#define MOUSE_G5 0xc049 に変更してコンパイルしてください。

systemd ユニットを使うことで起動時に g5hack ツールを実行できます。詳しくは Systemd#ユニットファイルを見てください。

Arch がゲスト仮想マシンの場合

2 つまたは 3 つを超えるマウス ボタンをサポートしたい場合、その機能はハイパーバイザーソフトウェアによって異なります。

VMware ワークステーション

Arch ベースのゲスト VM の場合、その .vmx 設定ファイルに以下の行を追加します:

mouse.vusb.enable = "TRUE"
mouse.vusb.useBasicMouse = "FALSE"