KubuntuLaptopButtons

Differences between revisions 12 and 13
Revision 12 as of 2006-07-05 21:12:50
Size: 5296
Editor: clj46-234
Comment:
Revision 13 as of 2006-08-04 19:48:13
Size: 5570
Editor: host-84-9-234-221
Comment:
Deletions are marked like this. Additions are marked like this.
Line 47: Line 47:
|| 118 || XF``86Music || KMilo run Amarok ||
Line 48: Line 49:
|| || XF``86Calculator || KMilo, run speedcrunch if installed else KCalc ||
|| || XF``86Terminal || KMilo run Konsole ||
|| no reliable standard || XF``86Calculator || KMilo, run speedcrunch if installed else KCalc ||
|| no reliable standard || XF``86Terminal || KMilo run Konsole ||
Line 53: Line 54:
|| || XF``86AudioPause || Amarok || || 162 (same as play) || XF``86AudioPause || Amarok ||
Line 69: Line 70:
|| || XF``86Go || Konqueror || || no reliable standard || XF``86Go || Konqueror ||
Line 72: Line 73:
|| || XF``86PowerOff || KubuntuPowerManagement ||
|| || XF``86Standby || KubuntuPowerManagement ||
|| 222 (but also HAL?) || XF``86PowerOff || KubuntuPowerManagement ||
|| 223|| XF``86Standby || KubuntuPowerManagement ||
Line 75: Line 76:
|| || XF``86ContrastAdjust || KubuntuPowerManagement ||
|| || XF``86BrightnessAdjust || KubuntuPowerManagement ||
|| nothing || XF``86ContrastAdjust || KubuntuPowerManagement ||
|| nothing || XF``86BrightnessAdjust || KubuntuPowerManagement ||
Line 79: Line 80:
|| 204 || XF``86Eject || run ''eject'' ||
|| || XF``86LaunchA || none, user can set with KH``otKeys ||
|| 204 (mac only) || XF``86Eject || run ''eject'' ||
|| 245 || XF86Launch0 || Help Key, launch KHelpCentre ||
|| 159 (Thinkpad key)
|| XF``86LaunchA || none, user can set with KH``otKeys ||
Line 83: Line 85:
|| || XF``86LightBulb || KMilo on screen display ||
|| 132 (Thinkpad Light) || XF``86LightBulb || KMilo on screen display ||

Summary

Use the Ubuntu laptop buttons infrastructure in KDE.

Rationale

Many laptops and also desktops have extra feature buttons which handle power management, display controls and other features. These should work as well in Kubuntu as they do in Ubuntu.

Use cases

Masie has a laptop with suspend and brightness buttons, when pressing these buttons nothing happens and she doesn't know how to make them work.

Bob notices that all his laptop buttons work in Ubuntu but none of them work in Kubuntu which would otherwise be his preferred environment.

Daniel follows the complex kmilo thinkpad instructions to get his thinkpad buttons working, he has to enable nvram writing to get this to work but wonders if it is a security risk.

Scope

Specific laptops are the problem of acpi-support and hotkey-setup, this spec is for making sure KDE does the right thing with the output of hotkey-setup.

Design

KDE has KMilo, a kde daemon module for handling laptop keys. KMilo has plugins for different types of laptop and each plugin for KMilo works in different ways and has different abilities. With the abstraction provided by hotkey-setup we no longer need different parts of KMilo for each laptop. We will create a new KMilo plugin for hotkey-support.

Implementation

Our KMilo hotkey-setup plugin will run xmodmap on startup to map the xevents from hotkey-setup to X keys. We will setup global bindings in KMix, Konqueror, Amarok and KubuntuPowerManagement to handle volume up/down, play/pause, suspend/hibernate, screen brightness and web browser control. The KMilo plugin will also have global bindings for volume and screen brightness and will show its on screen display to give feedback to the user, it will get its values by querying KMix and KubuntuPowerManagement with DCOP.

The KMilo plugin will also have global keybindings to listen for the e-mail and web browser buttons, these will run the default application which the user can set in the normal KDE way. Other application buttons will run the default Kubuntu application.

The existing KMilo plugins will be moved to a new unsupported package.

Unspecified buttons such as the "IBM Thinkpad" button will be mapped to X keys which can be set to almost any action using khotkeys, a standard part of KDE.

Keycode

Keysym

Handler

229

XF86Search

KMilo run kfmexec for KDE's default search page

235

XF86MyComputer

KMilo run kfmexec $HOME

236

XF86Mail

KMilo, run default e-mail application

237

XF86AudioMedia

KMilo run Amarok

118

XF86Music

KMilo run Amarok

178

XF86WWW

KMilo run default web browser

no reliable standard

XF86Calculator

KMilo, run speedcrunch if installed else KCalc

no reliable standard

XF86Terminal

KMilo run Konsole

Keycode

Keysym

Handler

162

XF86AudioPlay

Amarok

162 (same as play)

XF86AudioPause

Amarok

164

XF86AudioStop

Amarok

144

XF86AudioPrev

Amarok

153

XF86AudioNext

Amarok

Keycode

Keysym

Handler

160

XF86AudioMute

KMix to change, KMilo for on screen display

174

XF86AudioLowerVolume

KMix to change, KMilo for on screen display

176

XF86AudioRaiseVolume

KMix to change, KMilo for on screen display

Keycode

Keysym

Handler

230

XF86Favorites

Konqueror

231

XF86Refresh

Konqueror

232

XF86Stop

Konqueror

233

XF86Forward

Konqueror

234

XF86Back

Konqueror

no reliable standard

XF86Go

Konqueror

Keycode

Keysym

Handler

222 (but also HAL?)

XF86PowerOff

KubuntuPowerManagement

223

XF86Standby

KubuntuPowerManagement

223

XF86Sleep

KubuntuPowerManagement

nothing

XF86ContrastAdjust

KubuntuPowerManagement

nothing

XF86BrightnessAdjust

KubuntuPowerManagement

Keycode

Keysym

Handler

204 (mac only)

XF86Eject

run eject

245

XF86Launch0

Help Key, launch KHelpCentre

159 (Thinkpad key)

XF86LaunchA

none, user can set with KHotKeys

XF86LaunchB

none, user can set with KHotKeys

XF86LaunchC

none, user can set with KHotKeys

132 (Thinkpad Light)

XF86LightBulb

KMilo on screen display

Comments

AchimBohnet

  • Lots of applications have Favorites, Stop, Forward, Back etc functionality. The special keys should not be globally assigned to just one app. Instead we should modify the keybindings of the apps where assignment of XF86<action> makes sense. I assume, that at least some of the XF86<*> keysyms can be assgined as a second Keybinding to a KDE STDAccel and are then automaticaly available in all apps that make use of them.

  • Full screen mode: check that globally bound keys work also in full screen mode. I once used a tool (not kmilo) where e.g. Mute, etc. didn't work in full screen mode.

KubuntuLaptopButtons (last edited 2008-08-06 16:27:41 by localhost)