Join GitHub today
GitHub is home to over 28 million developers working together to host and review code, manage projects, and build software together.Sign up
This project is the result of hard work from Miroof. https://github.com/miroof/node-virtual-gamepads
Install from the experimental menu of the setup script (may only work well with a rpi2)
Once the nodejs application is launched, you just have to plug your gamepad controller by connecting your device on the same local network and by reaching the address http://node_server_adress (i.e. your Raspberry Pi's IP address) on your choice of web browser (Chrome Mobile is recommended).
Use it as a Smartphone Application (Chrome for Android)
Note that you need to configure the virtual gamepad from emulationstation while in the web browser first BEFORE you create the application on your smartphone otherwise the input configuration in emulationstation will not work.
With the add to homescreen chrome feature, you can easily use virtual gamepads application without launching the browser each time you want to play.
With only 3 clicks, virtual gamepads web application becomes a standalone application.
Then a shortcut is added on your homescreen and the application will be launched outside the browser.
Enjoy Haptic Feedbacks
Because it's difficult to spot the right place in a touch screen without looking at it, the touch zone of each button was increased. LT button was moved at the center of the screen to let as much space as possible for the joystick and avoid touch mistakes.
To know if we pressed a button with success, the web application provides an haptic feedback which can be easily deactivated by turning off the vibrations of the phone.
You will need to configure your controller with EmulationStation and RetroArch just like you would any other controller.
You can also install manually using these steps:
### Install Node.js sudo apt-get update && sudo apt-get upgrade wget http://node-arm.herokuapp.com/node_archive_armhf.deb sudo dpkg -i node_archive_armhf.deb rm node_archive_armhf.deb ### Update Node.js and NPM sudo npm cache clean -f sudo npm install -g n sudo n stable sudo npm install -g npm ### Install Virtual Gamepad (Must Be Run As Root!) su git clone https://github.com/miroof/node-virtual-gamepads cd node-virtual-gamepads npm install ### Enable Virtual Gamepad on Boot sudo npm install pm2 -g sudo pm2 start main.js sudo pm2 startup sudo pm2 save
EmulationStation Controller Config:
input_device = "Virtual gamepad" input_driver = "udev" input_r_btn = "5" input_save_state_btn = "5" input_start_btn = "7" input_exit_emulator_btn = "7" input_l_btn = "4" input_load_state_btn = "4" input_up_axis = "-1" input_a_btn = "0" input_b_btn = "1" input_reset_btn = "1" input_down_axis = "+1" input_right_axis = "+0" input_state_slot_increase_axis = "+0" input_x_btn = "2" input_menu_toggle_btn = "2" input_select_btn = "6" input_enable_hotkey_btn = "6" input_y_btn = "3" input_left_axis = "-0" input_state_slot_decrease_axis = "-0"