diff --git a/NEWS b/NEWS index 6b916cf..94a67b1 100644 --- a/NEWS +++ b/NEWS @@ -1,13 +1,15 @@ -xboxdrv 0.6.3 - (??/Jan/2011) +xboxdrv 0.6.3 - (09/Jan/2011) ============================= -* chatpad support, enable with --chatpad, special thanks to Jani - Virta, Andy Kirkham, dwomac and GAFBlizzard who helped make it - possible -* cleanup of modifier code +* chatpad support (still rough), special thanks to Jani Virta, Andy + Kirkham, dwomac and GAFBlizzard who helped make it possible +* added --chatpad, --chatpad-no-init and --chatpad-debug * added optional abs:/rel:/key: prefixes to --ui-axismap * fixed multiple bugs that made it impossible to assign events to specific devices +* allow input filters in --axismap and --buttonmap +* added --headset, --headset-dump FILE and --headset-play FILE, for + experimentation only xboxdrv 0.6.2 - (31/Dec/2010) diff --git a/TODO b/TODO index 7ed24e5..3a922cf 100644 --- a/TODO +++ b/TODO @@ -27,14 +27,40 @@ $ dput my-ppa xboxdrv_0.6.3_source.changes Stuff to do before 0.6.4 release: ================================= -* integrate filters into --buttonmap and --axismap: +* write documentation - --buttonmap X^toggle:autofire=B - --axismap Y1^relative +* add chatpad/headset options to ini - main purpose: allow to make shift a toggle button +* cleanup --help, some newlines missing in there -* bug: when shifting the last axis state sticks even when they key was released +* basic Dualstrike mouse emulation with absolute position: + + ./xboxdrv-dualstrike \ + --ui-clear \ + --ui-buttonmap rb=key:1-BTN_LEFT,lb=key:1-BTN_RIGHT \ + --ui-axismap x2^cal:-25000:0:25000=abs:1-ABS_X,y2^cal:-25000:0:25000=abs:1-ABS_Y + --ui-axismap x1=KEY_LEFT:KEY_RIGHT,y1=KEY_DOWN:KEY_UP -s + +* can't parse: + --ui-axismap x2=2-ABS_X,y2=2-ABS_Y + + only this works: + + --ui-axismap x2=abs:2-ABS_X,y2=abs:2-ABS_Y + + implement better guessing + +* bug: when shifting the last axis state sticks even when the key was released + +Stuff to do before 0.6.x release: +================================= + +* figure out what to do with deprecated stuff: + + --deadzone - can probably stay for convenience + --deadzone-trigger - can probably stay for convenience + --relative-axis - should go + --autofire - should go Figure out a way to load custom keymaps: @@ -42,9 +68,25 @@ Figure out a way to load custom keymaps: * http://stackoverflow.com/questions/1557689/keyboard-remapping-with-more-modifiers * http://tldp.org/HOWTO/Keyboard-and-Console-HOWTO-15.html - -Stuff to do before 0.6.x release: -================================= +* setxkbmap -device ... -I xboxdrv/xorg/ + +xkbprint -label name $DISPLAY - | gv -orientation=seascape - +http://www.charvolant.org/~doug/xkb/html/xkb.html +http://pascal.tsu.ru/en/xkb/ +http://wiki.debian.org/XStrikeForce/InputHotplugGuide +http://git.madduck.net/v/etc/xsession.git?a=blob;f=.xkb/symbols/madduck;hb=refs/heads/xkb +http://www.x.org/wiki/XKB +http://sourceforge.net/tracker/download.php?group_id=286545&atid=1214224&file_id=361450&aid=2945171 + +http://www.x.org/docs/XKB/XKBlib.pdf + +* --four-way-restrictor for the dpad? + + - keep whatever direction is pressed first, don't allow walking over diagonals? + - always keep last main direction until another main direction got pressed? + - --disable-dpad-diagonals ur,dl,dl + +* limit --four-way-restrictor to a single axis * write UIEvent::from_string() @@ -52,9 +94,9 @@ Stuff to do before 0.6.x release: * absolute mouse pointer can be created with: - ABS_X, ABS_Y, BTN_LEFT + abs:1-ABS_X, abs:1-ABS_Y, key:1-BTN_LEFT - document that somewhere + document that somewhere, device must not contain REL_X, REL_Y or BTN_A or it won't work in X11 http://www.mp3car.com/vbulletin/input-devices/108554-xbox360-chatpad-awsome-backlit-mini-keyboard-16.html#post1256444 diff --git a/doc/xboxdrv.1 b/doc/xboxdrv.1 index c954e79..80c38ba 100644 --- a/doc/xboxdrv.1 +++ b/doc/xboxdrv.1 @@ -820,7 +820,7 @@ Lets the controller act as a mouse. It is indendical to: .fi You can customize it by the usual means, just make sure -that \*(T<\fB\-\-mouse\fR\*(T> comes before you +that \*(T<\fB\-\-mouse\fR\*(T> comes before your customization options on the command line. Note that if you have your mouse buttons switched you must @@ -993,7 +993,9 @@ You can change the rumble strength via: \*(T<$ xboxdrv \-\-rumble\-gain 50%\*(T> .fi -Values larger then 100% are possible as well. +Values larger then 100% are possible as well and will +amplify small rumble commands, rumble commands already +at the maximum will stay unchanged. .SH "INPUT FILTER" Input filter allow to manipulate the events that come from the controller. They can be used @@ -1036,7 +1038,7 @@ provided as parameter that will be outputed before the event. .SS "AXIS FILTER" .TP -\*(T<\fBcal\fR\*(T>, \*(T<\fBcalibration\fR\*(T> +\*(T<\fBcal\fR\*(T>, \*(T<\fBcalibration\fR\*(T>:\fIMIN\fR:\fICENTER\fR:\fIMAX\fR See \*(T<\fB\-\-calibration\fR\*(T>. .TP \*(T<\fBsen\fR\*(T>, \*(T<\fBsensitivity\fR\*(T>:\fISENSITIVITY\fR diff --git a/doc/xboxdrv.xml b/doc/xboxdrv.xml index db9ccc3..2447aca 100644 --- a/doc/xboxdrv.xml +++ b/doc/xboxdrv.xml @@ -1019,7 +1019,7 @@ NAME = STRING ;]]></programlisting> --ui-buttonmap "start=KEY_FORWARD,back=KEY_BACK,guide=KEY_ESC,tl=void,tr=void"]]></programlisting> <para> You can customize it by the usual means, just make sure - that <option>--mouse</option> comes before you + that <option>--mouse</option> comes before your customization options on the command line. </para> <para> @@ -1239,7 +1239,11 @@ pos = (1.0f - (1.0f - pos) ** t) ** (1 / t);]]></programlisting> <programlisting>$ xboxdrv --rumble-gain 50%</programlisting> - <para>Values larger then 100% are possible as well.</para> + <para> + Values larger then 100% are possible as well and will + amplify small rumble commands, rumble commands already + at the maximum will stay unchanged. + </para> </listitem> </varlistentry> </variablelist> @@ -1323,7 +1327,7 @@ pos = (1.0f - (1.0f - pos) ** t) ** (1 / t);]]></programlisting> <title id="axisfilter.title">Axis Filter</title> <variablelist> <varlistentry> - <term><option>cal</option>, <option>calibration</option></term> + <term><option>cal</option>, <option>calibration</option>:<replaceable>MIN</replaceable>:<replaceable>CENTER</replaceable>:<replaceable>MAX</replaceable></term> <listitem> <para> See <option>--calibration</option>. diff --git a/src/command_line_options.cpp b/src/command_line_options.cpp index be480b6..50250b4 100644 --- a/src/command_line_options.cpp +++ b/src/command_line_options.cpp @@ -139,7 +139,6 @@ CommandLineParser::init_argp() .add_option(OPTION_TEST_RUMBLE, 'R', "test-rumble", "", "map rumbling to LT and RT (for testing only)") .add_option(OPTION_NO_UINPUT, 0, "no-uinput", "", "do not try to start uinput event dispatching") .add_option(OPTION_NO_EXTRA_DEVICES, 0, "no-extra-devices", "", "Do not create separate virtual keyboard and mouse devices, just use a single virtual device") - .add_option(OPTION_MIMIC_XPAD, 0, "mimic-xpad", "", "Causes xboxdrv to use the same axis and button names as the xpad kernel driver") .add_option(OPTION_DAEMON, 'D', "daemon", "", "run as daemon") .add_option(OPTION_CONFIG, 'c', "config", "FILE", "read configuration from FILE") .add_option(OPTION_CONFIG_OPTION,'o', "option", "NAME=VALUE", "Set the given configuration option") @@ -154,11 +153,17 @@ CommandLineParser::init_argp() .add_option(OPTION_DEVICE_BY_PATH, 0, "device-by-path", "BUS:DEV", "Use device BUS:DEV, do not do any scanning") .add_option(OPTION_DEVICE_BY_ID, 0, "device-by-id", "VENDOR:PRODUCT", "Use device that matches VENDOR:PRODUCT (as returned by lsusb)") .add_option(OPTION_TYPE, 0, "type", "TYPE", "Ignore autodetection and enforce controller type (xbox, xbox-mat, xbox360, xbox360-wireless, xbox360-guitar)") + .add_newline() + + .add_text("Evdev Options: ") .add_option(OPTION_EVDEV, 0, "evdev", "DEVICE", "Read events from a evdev device, instead of USB") .add_option(OPTION_EVDEV_DEBUG, 0, "evdev-debug", "", "Print out all events received from evdev") .add_option(OPTION_EVDEV_NO_GRAB, 0, "evdev-no-grab", "", "Do not grab the event device, allow other apps to receive events") .add_option(OPTION_EVDEV_ABSMAP, 0, "evdev-absmap", "MAP", "Map evdev key events to Xbox360 button events") .add_option(OPTION_EVDEV_KEYMAP, 0, "evdev-keymap", "MAP", "Map evdev abs events to Xbox360 axis events") + .add_newline() + + .add_text("Peripherals: ") .add_option(OPTION_CHATPAD, 0, "chatpad", "", "Enable Chatpad support for Xbox360 USB controller") .add_option(OPTION_CHATPAD_NO_INIT, 0, "chatpad-no-init", "", "To not send init code to the Chatpad") .add_option(OPTION_CHATPAD_DEBUG, 0, "chatpad-debug", "", "To not send init code to the Chatpad") @@ -167,6 +172,11 @@ CommandLineParser::init_argp() .add_option(OPTION_HEADSET_PLAY, 0, "headset-play", "FILE", "Play FILE on the headset") .add_newline() + .add_text("Force Feedback: ") + .add_option(OPTION_FORCE_FEEDBACK, 0, "force-feedback", "", "Enable force feedback support") + .add_option(OPTION_RUMBLE_GAIN, 0, "rumble-gain", "NUM", "Set relative rumble strength (default: 255)") + .add_newline() + .add_text("Status Options: ") .add_option(OPTION_LED, 'l', "led", "NUM", "set LED status, see --help-led (default: 0)") .add_option(OPTION_RUMBLE, 'r', "rumble", "L,R", "set the speed for both rumble motors [0-255] (default: 0,0)") @@ -182,14 +192,6 @@ CommandLineParser::init_argp() .add_option(OPTION_DPAD_ONLY, 0, "dpad-only", "", "Both sticks are ignored, only DPad sends out axis events") .add_option(OPTION_BUTTONMAP, 'b', "buttonmap", "MAP", "Remap the buttons as specified by MAP (example: B=A,X=A,Y=A)") .add_option(OPTION_AXISMAP, 'a', "axismap", "MAP", "Remap the axis as specified by MAP (example: -Y1=Y1,X1=X2)") - .add_option(OPTION_NAME, 0, "name", "DEVNAME", "Changes the descriptive name the device will have") - .add_option(OPTION_UI_NEW, 0, "ui-new", "", "Create a new uinput configuration") - .add_option(OPTION_UI_CLEAR, 0, "ui-clear", "", "Removes all existing uinput bindings") - .add_option(OPTION_UI_TOGGLE, 0, "ui-toggle", "BTN", "Set button to use for toggling between configs") - .add_option(OPTION_UI_BUTTONMAP, 0, "ui-buttonmap", "MAP", "Changes the uinput events send when hitting a button (example: X=BTN_Y,A=KEY_A)") - .add_option(OPTION_UI_AXISMAP, 0, "ui-axismap", "MAP", "Changes the uinput events send when moving a axis (example: X1=ABS_X2)") - .add_option(OPTION_MOUSE, 'm', "mouse", "", "Enable mouse emulation") - .add_option(OPTION_GUITAR, 0, "guitar", "", "Enables guitar button and axis mapping") .add_option(OPTION_SQUARE_AXIS, 0, "square-axis", "", "Cause the diagonals to be reported as (1,1) instead of (0.7, 0.7)") .add_option(OPTION_FOUR_WAY_RESTRICTOR,0, "four-way-restrictor", "", "Restrict axis movement to one axis at a time") .add_option(OPTION_DPAD_ROTATION, 0, "dpad-rotation", "DEGREE", "Rotate the dpad by the given DEGREE, must be a multiple of 45") @@ -197,14 +199,41 @@ CommandLineParser::init_argp() .add_option(OPTION_RELATIVE_AXIS, 0, "relative-axis", "MAP", "Make an axis emulate a joystick throttle (example: y2=64000)") .add_option(OPTION_AUTOFIRE, 0, "autofire", "MAP", "Cause the given buttons to act as autofire (example: A=250)") .add_option(OPTION_CALIBRARIOTION, 0, "calibration", "MAP", "Changes the calibration for the given axis (example: X2=-32768:0:32767)") - - .add_text("Force Feedback: ") - .add_option(OPTION_FORCE_FEEDBACK, 0, "force-feedback", "", "Enable force feedback support") - .add_option(OPTION_RUMBLE_GAIN, 0, "rumble-gain", "NUM", "Set relative rumble strength (default: 255)") .add_newline() + .add_text("Uinput Configuration Options: ") + .add_option(OPTION_NAME, 0, "name", "DEVNAME", "Changes the descriptive name the device will have") + .add_option(OPTION_UI_NEW, 0, "ui-new", "", "Create a new uinput configuration entry") + .add_option(OPTION_UI_CLEAR, 0, "ui-clear", "", "Removes all existing uinput bindings") + .add_option(OPTION_UI_TOGGLE, 0, "ui-toggle", "BTN", "Set button to use for toggling between configs") + .add_option(OPTION_UI_BUTTONMAP, 0, "ui-buttonmap", "MAP", "Changes the uinput events send when hitting a button (example: X=BTN_Y,A=KEY_A)") + .add_option(OPTION_UI_AXISMAP, 0, "ui-axismap", "MAP", "Changes the uinput events send when moving a axis (example: X1=ABS_X2)") + .add_newline() + + .add_text("Configuration Options: ") + .add_option(OPTION_MOUSE, 'm', "mouse", "", "Enable mouse emulation") + .add_option(OPTION_GUITAR, 0, "guitar", "", "Enables guitar button and axis mapping") + .add_option(OPTION_MIMIC_XPAD, 0, "mimic-xpad", "", "Causes xboxdrv to use the same axis and button names as the xpad kernel driver") + .add_newline() + + .add_text("Axis Filter:") + .add_pseudo(" cal, calibration MIN:CENTER:MAX", "Set the calibration values for the axis") + .add_pseudo(" sen, sensitivity:SENSITIVITY", "Set the axis sensitivity") + .add_pseudo(" dead, deadzone:VALUE, deadzone:MIN:CENTER:MAX", "Set the axis deadzone") + .add_pseudo(" rel, relative:SPEED", "Turn axis into a relative-axis") + .add_pseudo(" resp, response:VALUES:...", "Set values of the response curve") + .add_pseudo(" log:STRING", "Print axis value to stdout") + .add_newline() + + .add_text("Button Filter:") + .add_pseudo(" tog, toggle", "Turn button into a toggle button") + .add_pseudo(" inv, invert", "Invert the button value") + .add_pseudo(" auto, autofire:RATE:DELAY", "Enable automatic button press repetition") + .add_pseudo(" log:STRING", "Print button value to stdout") + .add_newline() + .add_text("See README for more documentation and examples.") - .add_text("Report bugs to Ingo Ruhnke <grumbel@gmx.de>"); + .add_text("Report bugs to Ingo Ruhnke <grumbel@gmail.com>"); } void