特殊:Badtitle/NS100:ManyButtonsMouseHowto:修订间差异

来自Ubuntu中文
跳到导航跳到搜索
Wikibot留言 | 贡献
无编辑摘要
Wikibot留言 | 贡献
无编辑摘要
 
(未显示同一用户的6个中间版本)
第7行: 第7行:
== Beyond the Basics ==
== Beyond the Basics ==
If you have installed the GNOME environment (default for Ubuntu) you ''already'' have the software needed to get the "6th" and "7th" mouse buttons working (forward/backward on most mice)!
If you have installed the GNOME environment (default for Ubuntu) you ''already'' have the software needed to get the "6th" and "7th" mouse buttons working (forward/backward on most mice)!
Open `/etc/X11/xorg.conf` or `/etc/X11/XF86Config-4` for editing. Within the `InputDevice` section for your `Configured Mouse`, change <code><nowiki>Option "Buttons" "5"</nowiki></code> to <code><nowiki>Option "Buttons" "7"</nowiki></code> (see "xorg.conf (X11 configuration file)" section below for an example). You may also have to change the `ZAxisMapping` option from `"4 5"` to `"6 7"`. Be prepared to experiment to discover what works best on your system.
== Limitations ==
Note that xorg X Input system is not able to bind a combination of more than one mouse button to a certain action. For example, it is not possible to bind left-clicking while simultaneously scrolling up to a specific action. Only binding of one action to each button is allowed, except when combining them with keyboard modifier keys (Ctrl, Alt, Super,...)
== Remapping buttons ==
Some pointing devices have a strange button mapping, so need some tweaking to match X's perception of things. Such tweaking can be performed at runtime with xinput - find your device in <code><nowiki>xinput list</nowiki></code> and run <code><nowiki>xinput set-button-map <device name> 1 2 3 6 7</nowiki></code>, replacing those numbers with your required button mapping. You might be able to find it by searching for other people with the same hardware, or you might need to play around and see what works.
== Mapping More Buttons ==
== Mapping More Buttons ==
The key to being able to program mouse buttons beyond the seven already discussed is to install imwheel (from the [[UbuntuHelp:Universe|Universe]] repository). Imwheel will enable you to define application-specific actions to your additional mouse buttons.
The key to being able to program mouse buttons beyond the seven already discussed is to install imwheel (from the [[UbuntuHelp:Universe|Universe]] repository). Imwheel will enable you to define application-specific actions to your additional mouse buttons.
<ol><li>Download and install imwheel using Synaptic, Adept, or apt-get
<ol><li>Download and install imwheel using Synaptic, Adept, or apt-get
</li><li>Modify your `/etc/X11/xorg.conf` (or `XF86Config-4`) file to indicate the number of buttons on your mouse
</li><li>Modify your `/etc/X11/imwheel/imwheelrc` or `~/.imwheelrc` file to tell imwheel what to do with a mouse click when it happens in a particular application. See the Wikis referenced below for details on what you can do with your imwheelrc or .imwheelrc file.</li></ol>
</li><li>Modify your `/etc/X11/imwheel/imwheelrc` or `~/.imwheelrc` file to tell imwheel what to do with a mouse click when it happens in a particular application. See the Wikis referenced below for details on what you can do with your imwheelrc or .imwheelrc file.</li></ol>


'''NOTE:''' You can use modifications to the `~/.imwheelrc` to limit imwheel behavior to specific users on your system.
'''NOTE:''' You can use modifications to the `~/.imwheelrc` to limit imwheel behavior to specific users on your system.
1.#4 Finally, if desired, tell X11 to run imwheel whenever X11 is started (modifying `/etc/X11/Xsession.d/60imwheel_start-imwheel` and changing `IMWHEEL_START=0` to `=1` in `/etc/X11/imwheel/startup.conf`). Alternately, you can start imwheel manually.
1.#4 Finally, if desired, tell X11 to run imwheel whenever X11 is started (modifying `/etc/X11/Xsession.d/60imwheel_start-imwheel` and changing `IMWHEEL_START=0` to `=1` in `/etc/X11/imwheel/startup.conf`). Alternately, you can start imwheel manually.
'''NOTE:''' See [[UbuntuHelp:IntellimouseMousemanBackForwardButtons| Set Up an Intellimouse or Mouseman's Back/Forward Buttons]] for an outstanding explanation of how to set up imwheel properly.
=== Before You Proceed ===
=== Before You Proceed ===
Before any further editing to `xorg.conf` or `.imwheelrc`, it might be helpful to check your mouse button mappings.
Before any further editing to `xorg.conf` or `.imwheelrc`, it might be helpful to check your mouse button mappings.
第26行: 第27行:
</nowiki></pre>
</nowiki></pre>
== Examples ==
== Examples ==
Frequently, the best way to learn is to look at what works for other people. Here are some examples of working `xorg.conf` and `imwheelrc` files. Compare these to your own to help you troubleshoot and test out new configurations.
Frequently, the best way to learn is to look at what works for other people. Here are some examples of working `imwheelrc` files. Compare these to your own to help you troubleshoot and test out new configurations.
=== xorg.conf (X11 configuration file) ===
==== Example 1 ====
This is what the relevant portion of my `xorg.conf` file looks like:
<pre><nowiki>
Section "InputDevice"
        Identifier      "Configured Mouse"
        Driver          "mouse"
        Option          "CorePointer"
        Option          "Device"                "/dev/input/mice"
        Option          "Protocol"              "ExplorerPS/2"
        Option          "Emulate3Buttons"      "false"
        Option          "Buttons"              "7"
        Option          "ZAxisMapping"          "6 7"
EndSection
</nowiki></pre>
'''NOTE:''' Using xmodmap to remap mouse buttons can result in the error "xmodmap:  commandline:1:  bad number of buttons, must have 11 instead of 7". If you want to remap the buttons on your mouse, make the following (or similar) modification to your `xorg.conf` file:
<pre><nowiki>
        Option          "Buttons"              "5"
        Option          "ZAxisMapping"          "4 5"
        Option          "ButtonMapping"        "1 2 3 6 7"
</nowiki></pre>
==== Example 2 ====
Here is another example from a Logitech 510 mouse:
<pre><nowiki>
Section "InputDevice"
        Identifier  "Configured Mouse"
        Driver      "mouse"
        Option      "Buttons" "7"
        Option      "CorePointer"
        Option      "Device" "/dev/input/mice"
        Option      "Protocol" "ExplorerPS/2"
        Option      "ZAxisMapping" "4 5"
        Option      "ButtonMapping" "1 2 3 6 7"
        Option      "Resolution" "800"
EndSection
</nowiki></pre>
==== Example 3 ====
Finally, here is the `xorg.conf` from a Wireless Intelli``Mouse Explorer 2.0. This is how I got my mouse working after 20 minutes of fiddling.
<pre><nowiki>
Section "InputDevice"
        Identifier  "Configured Mouse"
        Driver      "mouse"
        Option      "CorePointer"
        Option      "Device"                "/dev/input/mice"
        Option      "Protocol"              "ExplorerPS/2"
        Option      "Emulate3Buttons"      "false"
        Option      "Buttons"              "7"
        Option      "ZAxisMapping"          "6 7"
        Option      "ButtonMapping"        "1 2 3 4 5 6 7"
EndSection
</nowiki></pre>
==== Example 4 ====
Here is how to setup a '''7 button Dell mouse''' (1 scroll wheel and 2 thumb buttons).
imwheel -c and xev gives that the thumb buttons are 8 & 9 and not 6 & 7 as would be expected from a 7 button mouse.
Create `57xmodmap` in `/etc/X11/Xsession.d/` and add this (the ButtonMapping option doesn't work for unknown reason):
<pre><nowiki>
#/bin/bash
xmodmap -e "pointer = 1 2 3 4 5 8 9 6 7"
</nowiki></pre>
Then change the `xorg.conf` to:
<pre><nowiki>
Section "InputDevice"
        Identifier      "Configured Mouse"
        Driver          "mouse"
        Option          "CorePointer"
        Option          "Device"                "/dev/input/mice"
        Option          "Protocol"              "Auto"
        Option          "Buttons"              "9"
        Option          "ZAxisMapping"          "4 5"
EndSection
</nowiki></pre>
=== imwheelrc ===
=== imwheelrc ===
Here is an example of what a portion of my `.imwheelrc` looks like:
Here is an example of what a portion of my `.imwheelrc` looks like:
第109行: 第39行:
== Useful links ==
== Useful links ==
* [http://www.google.com/search?q=configure+x11+mouse+buttons&btnG=Search&hl=en&lr= Google Search "configure x11 mouse buttons"]
* [http://www.google.com/search?q=configure+x11+mouse+buttons&btnG=Search&hl=en&lr= Google Search "configure x11 mouse buttons"]
* [[UbuntuHelp:IntellimouseMousemanBackForwardButtons| Set Up an Intellimouse or Mouseman's Back/Forward Buttons]]
* http://subwiki.honeypot.net/cgi-bin/view/Computing/ExtraMouseButtons
* [http://forums.macosxhints.com/showpost.php?p=46998&postcount=57 Configure a three-button mouse to work with X11.app]
* [http://www.lirc.org/html/configure.html Configuring LIRC (Linux Infrared Remote Control)]
* [http://www.lirc.org/html/configure.html Configuring LIRC (Linux Infrared Remote Control)]
* http://www.linuxnetmag.com/en/issue5/m5mouse1.html
* [http://fedoraforum.org/forum/showthread.php?t=27470 Fedora Forum: Configuring mouse side buttons in FC3]
* [http://fedoraforum.org/forum/showthread.php?t=27470 Fedora Forum: Configuring mouse side buttons in FC3]
* [http://fedoraforum.org/forum/showthread.php?s=5745dd389c241334b0dc76f0f7b86a16&t=25659 Fedora Forum: Configuring mouse buttons]
* [http://fedoraforum.org/forum/showthread.php?s=5745dd389c241334b0dc76f0f7b86a16&t=25659 Fedora Forum: Configuring mouse buttons]
* [http://docs.hp.com/en/B2355-90122/ch06s04.html HP: Customizing the Mouse and Keyboard]
* [http://docs.hp.com/en/B2355-90122/ch06s04.html HP: Customizing the Mouse and Keyboard]
[[category:CategoryDocumentation]]
----
[[category:CategoryHardware]] [[category:CategoryX]]


[[category:UbuntuHelp]]
[[category:UbuntuHelp]]

2010年5月19日 (三) 23:22的最新版本

{{#ifexist: :ManyButtonsMouseHowto/zh | | {{#ifexist: ManyButtonsMouseHowto/zh | | {{#ifeq: {{#titleparts:ManyButtonsMouseHowto|1|-1|}} | zh | | }} }} }} {{#ifeq: {{#titleparts:ManyButtonsMouseHowto|1|-1|}} | zh | | }}

  1. title Configuring a Multi-Button Mouse

This page describes how to configure Ubuntu to fully utilize a mouse with multiple buttons, wheels, and other controls.

Before You Begin

It's important to note that Ubuntu considers a standard two button, scroll/click-wheel mouse to have five buttons. Each main button (left and right) count as one, the downward click on the wheel counts as another, and the up/down scrolling also count as one each (2+1+2=5).

Beyond the Basics

If you have installed the GNOME environment (default for Ubuntu) you already have the software needed to get the "6th" and "7th" mouse buttons working (forward/backward on most mice)!

Limitations

Note that xorg X Input system is not able to bind a combination of more than one mouse button to a certain action. For example, it is not possible to bind left-clicking while simultaneously scrolling up to a specific action. Only binding of one action to each button is allowed, except when combining them with keyboard modifier keys (Ctrl, Alt, Super,...)

Remapping buttons

Some pointing devices have a strange button mapping, so need some tweaking to match X's perception of things. Such tweaking can be performed at runtime with xinput - find your device in xinput list and run xinput set-button-map <device name> 1 2 3 6 7, replacing those numbers with your required button mapping. You might be able to find it by searching for other people with the same hardware, or you might need to play around and see what works.

Mapping More Buttons

The key to being able to program mouse buttons beyond the seven already discussed is to install imwheel (from the Universe repository). Imwheel will enable you to define application-specific actions to your additional mouse buttons.

  1. Download and install imwheel using Synaptic, Adept, or apt-get
  2. Modify your `/etc/X11/imwheel/imwheelrc` or `~/.imwheelrc` file to tell imwheel what to do with a mouse click when it happens in a particular application. See the Wikis referenced below for details on what you can do with your imwheelrc or .imwheelrc file.

NOTE: You can use modifications to the `~/.imwheelrc` to limit imwheel behavior to specific users on your system. 1.#4 Finally, if desired, tell X11 to run imwheel whenever X11 is started (modifying `/etc/X11/Xsession.d/60imwheel_start-imwheel` and changing `IMWHEEL_START=0` to `=1` in `/etc/X11/imwheel/startup.conf`). Alternately, you can start imwheel manually.

Before You Proceed

Before any further editing to `xorg.conf` or `.imwheelrc`, it might be helpful to check your mouse button mappings. Run `imwheel -c` from a terminal window for imwheel's graphical UI. Pressing the Grab``Wheel``Action button and then one of your mouse's buttons should cause imwheel to show the button's default mapping. In practice, this seemed somewhat inconsistent, but results may differ depending on your particular mouse.

The information you glean from this test could prove helpful if your mouse doesn't have traditional button mappings. If, for example, your side mouse buttons map to the standard left and right (1 and 2) positions, and you wanted these side buttons to control Firefox's Back and Forward buttons, you would use the following `.imwheelrc` entry for Firefox.

"^Firefox-bin$"
None,Left,Alt_L|Left
None,Right,Alt_L|Right

Examples

Frequently, the best way to learn is to look at what works for other people. Here are some examples of working `imwheelrc` files. Compare these to your own to help you troubleshoot and test out new configurations.

imwheelrc

Here is an example of what a portion of my `.imwheelrc` looks like:

"^Firefox-bin$"
# Flip between browser tabs
None, Left, Control_L|Page_Up
None, Right, Control_L|Page_Down

If you'd like to customize your mouse buttons for additional applications, just add more entries like this to the `imwheelrc` file.

Useful links