Linux mouse and joystick driver for the Texas Instruments eZ430-Chronos watch
After you downloaded and extracted the files just type make
in the directory containing the extracted files. You need to have a C compiler like gcc installed on your system.
This driver will only work on Linux as it is using the kernel's uinput framework.
- As root:
modprobe uinput
- Plug your RF Access Point included with your watch into your system.
- On your Chronos watch select "ACC" (for key presses and movement data) or "PPt" (key presses only) and initiate transfer with the lower right button. You should see a blinking wireless symbol now.
- Change to the program directory and type
./chronos-input
for mouse mode or./chronos-input -m j
for joystick mode
I'm assuming you are using the default firmware of the device.
Make sure you have write permissions the uinput device (usually /dev/uinput
) and read and write permissions to the access point device (usually /dev/ttyACM0
).
For a list of all program options type ./chronos-input -h
Both the mouse and the joystick driver behave like real devices, have their own device entries (/dev/input/[mouse?|js?]
) and thus can be configured and used with your existing applications.
When using the driver in mouse mode the keys / axis are set as follows:
* = Left click
Up = Right click
# = middle click
Rotating the clock to the left / right = mouse cursor movement on x axis
Rotating the clock forwards / backwards = mouse cursor movement on y axis
When using the driver in joystick mode the keys / axis are as follows:
* = Button 1
Up = Button 2
# = Button 3
y-axis = Axis 1
x-axis = Axis 2
z-axis = Axis 3
For practical use it is recommended to calibrate your watch/joystick using a tool like jscal, otherwise you may never get the maximum peak.
Calibration only works for applications using the kernel's joystick interface. For SDL applications you may want to set SDL_JOYSTICK_DEVICE=/dev/input/js0
on your command line to use the joystick interface. See https://wiki.archlinux.org/index.php/Joystick#Joystick_Input_Systems for more details.
If your application can only use evdev (or is using SDL2) you may use ./chronos-input -m j -s 4.5
(or something like ./chronos-input -m j -s x5 -s y2.25
for adjusting axes individually) to increase responsiveness.
- Using PPt mode for presentations may not do what you expect: The buttons will generate left / middle / right clicks like in ACC mode, but most presentation programs need other keys to change slides. Use the Chronos Control Center if you want to define custom keyboard keys for these buttons.
- If the battery power is low (<2.9V) the clock may randomly crash when transfering data. There is nothing I can do about that, so please change your batteries in that case.
- On some systems no data is transferred. As a workaround start the Chronos Control Center to correctly initialize the RF Access Point. If you have any idea what might be missing in my code please drop me a note.
You are stuck somewhere? Something in the documentation isn't as clear as it should be? Or is it simply not working?
Drop me a note (ignaz.forster@gmx.de) or open an issue in the issue tracker.