Desktop client for the Yoke Gamepad App
NOTE: The following instructions are for Yoke Classic, a stable version no longer in development, and available in Google Play and F-Droid
If you want a version with customizable layouts, try Yoke WebView. Yoke WebView is for the moment only available on GitHub.
The Linux client can be installed with ```bash
pip3 install git+https://github.com/rmst/[email protected] --upgrade
On Linux to enable Yoke to create gamepad devices we need to add a udev rulebash yoke-enable-uinput # you can find that script in the "bin" directory ``
(This can be undone viayoke-disable-uinput`)
On Windows Yoke needs the vJoy driver. The installer can be downloaded here.
Now you can run the client with
bash yokeYour computer should then show up in the Yoke app immediately if you are on the same network.
To test Yoke on Linux you can install, e.g. jstest-gtk:
bash sudo apt install jstest-gtk jstest-gtk # to run
To use Yoke effectively with SDL-based games (e.g. all games using Unreal Engine or Unity3D), you can install the SDL gamepad tool. (If the package is not found, download the tool from the website.)
bash sudo apt install gamepadtool gamepadtool # to run
yokeprocess creates one virtual device. To run multiple processes on the same machine make sure to give them different
--idnumbers (any integer greater than 0).
The communication between the Linux client and the Android app are unencrypted UDP messages. You should therefore use it in networks you trust. However, if you are not in a trusted environment you can always create one via USB or Bluetooth. Just enable USB or Bluetooth tethering on your Android device and connect your Linux computer. This will create a mini-network for just your Phone and Computer and Yoke will work as usual.
Changing the controller mapping and behaviour of certain axes is very simple. Have a look at
bin/yokewhich is the Python script that is used for the
If you want to modify more low level stuff that's also pretty easy. The Yoke linux client basically consists of a single Python file