RC Viewer, RC Gamepad, Play video games with the RC Transmitter as Game ControllerI like RC (radio controlled) vehicles and thought it would be great to play racing games with the RC Transmitter. I checked the internet and as always, someone else had already that idea. One solution is using the Andurino and another is using Flightsim. I decided to use my own solution. I am using a Teensy 3, some wires and a 6 channel RC Transmitter/Receiver. It is also a great solution for handicapped people to play racing games. I released two programs:
The RC Gamepad can be used as gamepad and it can emulate a Xbox 360 Controller and a PlayStation 3 Controller (see description for limitations). Hardware
Source codesRC Viewer: rcviewer-20220821.zip, License: MIT RC Gamepad: rcgamepad-20221004.zip, License: GPLv2 Videos
External content blocked. Watch on YouTube RC Gamepad/Controller mappingMode informationVarious blink modes when transmitter is not powered on startup and for mode 1 - 'gaming mode', mode 2 - 'menu mode', mode 3 - 'alternate buttons mode'. How it works, circuit diagramThe RC Receiver gives continuous pulses as output. The impulse length is between a minimum and a maximum length. The length of the pulse is corresponding with the angle of the servo or the speed of the motor. Every channel has its own pulse output. I read the output of the RC Receiver with the Teensy using the digital input pins and interrupts on state change. The RC Receiver can work with 4,8V-12V and is powered by the 5V of the Teensy USB connection. Output from the Teensy as Serial USB device (program RC Viewer) and minicomChannel exampleChannel 1, controlled by the steering wheel of the RC Transmitter.
Pulse diagramThese values are from my receiver. You can get the values of your hardware with RC Viewer. RC Viewer1. The program RC ViewerThe program prints the impulse lengths from a RC receiver to a serial terminal. The serial output can come directly from the Teensy as USB Serial device or with the Teensy serial pins. You can use for example the program 'minicom' to see the output. License: MIT, see LICENSE.txt Download: rcviewer-20220821.zip 2. Hardware
3. Program detailsMain program: rcviewer.cpp 3.1. Serial outputSetup in the section: Terminal connection
Teensy as USB Serial device: #define serial Serial Output refresh rate in milli seconds: #define TERMINAL_REFRESH_MS 200 3.2. Output device nodes
Teensy as USB Serial device : /dev/ttyACM0 3.3. Examples with minicomminicom -b 115200 -D /dev/ttyACM0 -o minicom -b 115200 -D /dev/ttyUSB0 -o Leaving minicom: Press CTRL-A, then 'q'. 3.4. RC receiverSetup in the section: Remote control Define number of transmitter channels: #define RC_NUM_CHANNELS 6 Setup the used Teensy pins wired with the RC receiver. rc_interrupt_pin[RC_NUM_CHANNELS] = {18, 19, 20, 21, 22, 23}; 3.5. Setup channelInit channel 1, usual the steering wheel: RC_InitChannel (1, Isr1); Init channel 2, usual accelerate/break: RC_InitChannel (2, Isr2); Print channel 1 data: RC_PrintChannel (1); 4. How to compile4.1. Install compilerDownload and install the Arduino IDE Download Teensyduino and install to the Arduino IDE directory 4.2. Setup the MakefileOpen the Makefile of RC Viewer and set • the ARDUINO_HOME variable to your Arduino IDE installation directory. • the M_ARDUINO_VERSION variable to your Arduino IDE version. • the M_TEENSYDUINO_VERSION variable to your Teensyduino version. • the M_TEENSY_VERSION variable if you use another 3.x Teensy than the 3.2. 4.3. CompileRun 'make' to compile the program. You find the compiled program (rcviewer.hex) in the 'bin' directory. 5. How to flash5.1. ToolUse the program 'teensy_loader_cli' to flash the Teensy. 5.2. Command to flashPress the white button on the Teensy to switch to the flash mode. Run: teensy_loader_cli -mmcu=mk20dx256 -v -w bin/rcviewer.hex You can also use the 'flash' script: ./flash RC Gamepad - Game Controller1. The program RC GamepadRC Gamepad allows you to play video games with a RC (radio controlled) transmitter and receiver. RC Gamepad can work as simple USB Gamepad, emulate a Xbox 360 Controller or a PlayStation 3 Controller. The emulated console controllers will NOT work on their consoles, because the required security mechanism is not implemented. The USB descriptors are not shipped with this source code. You can get the USB descriptors with the tool 'getdescriptors' when you own the original controller. See '9. Console controllers' for more information. License: GPLv2, see LICENSE.txt Download: rcgamepad-20221004.zip 2. Hardware
3. Program detailsMain program: rcgamepad.cpp 3.1. Controller type
Set the CONTROLLER_TYPE variable. Possible values are CONTROLLER_GAMEPAD CONTROLLER_XBOX360 CONTROLLER_PS3 Example: #define CONTROLLER_TYPE CONTROLLER_GAMEPAD See '9. Console controllers' for details. 3.2. Debug outputDebugging is optional. Use an USB to RS232 device to connect to a serial terminal. Set the DEBUG_TYPE variable. Possible values are DEBUG_NONE, DEBUG_USB_CONFIGURE, DEBUG_USB_IN_REPORT, DEBUG_USB_OUT_REPORT, DEBUG_USB_DATA, DEBUG_USB_VERBOSE The DEBUG_TYPE variable is a bitmask. Use the logical or for multiple options.
Examples: #define DEBUG_TYPE DEBUG_NONE #define DEBUG_TYPE (DEBUG_USB_CONFIGURE | DEBUG_USB_OUT_REPORT) #define DEBUG_TYPE DEBUG_USB_VERBOSE 3.3. Print RC valuesYou can print the RC values to a serial terminal. Enable #define PRINT_RC_VALUES If PRINT_RC_VALUES is enabled, then the screen will be shown automatically. If PRINT_RC_VALUES is not enabled, then the screen can be enabled on demand by pressing the key 'v'. Note: If you also enable USB debugging, then the serial terminal screen will be mixed with different data. 3.4. Channel numbers on RC ReceiverIf your transmitter and receiver is using different channel numbers, then change the numbers: #define CHANNEL1 1 #define CHANNEL2 2 #define CHANNEL3 3 #define CHANNEL4 4 #define CHANNEL5 5 #define CHANNEL6 6 3.5. Calibration or notRC Gamepad has a calibration for the steering wheel and accelerate/brake trigger implemented. See 'Calibration' for information how to calibrate. The calibration result will be stored on the EEPROM of the Teensy. As alternative to the calibration, it is possible to use hardcoded values. You get the correct values for the channels with 'Print RC values'. Calibration is enabled by default. To use hardcoded values remove or comment out #define USE_CALIBRATE Here are some hardcoded values from my RC Transmitter/Receiver: // Steering wheel #define CHANNEL1_MIN 936 #define CHANNEL1_RELAXED 1479 #define CHANNEL1_MAX 1999 // Accelerate/Break #define CHANNEL2_MIN 1013 #define CHANNEL2_RELAXED 1475 #define CHANNEL2_MAX 1987 // Tristate channel #define CHANNEL4_MODE1 1000 #define CHANNEL4_MODE2 2000 // Twostate channels #define CHANNEL3_TIPPING 1200 #define CHANNEL5_TIPPING 1800 #define CHANNEL6_TIPPING 990 3.6. Button press timeButtons are handled in a special way. See 'RC Buttons'. Set the variable BUTTON_PRESS_TIME press time. The time is in milli seconds. #define BUTTON_PRESS_TIME 400 3.7. Buttons special featureButtons are handled in a special way. See 'RC Buttons'. The special feature hold buttons pressed until the accelerate trigger get below start position and also when a maximum press time has been reached. #define FEATURE_KEEP_PRESSED 3.8. Terminal connectionYou can use a serial terminal to print debug information and the values of the RC Transmitter. #define SERIAL_PORT Serial1 // RS232 serial pins RX1 and TX1. #define TERMINAL_REFRESH_MS 500 // Refresh rate for the terminal output. 500ms. 3.9. RC ReceiverSetup in the section: Remote control
Define number of transmitter channels: #define RC_NUM_CHANNELS 6
Setup the used Teensy pins wired with the RC Receiver. rc_interrupt_pin[RC_NUM_CHANNELS] = {18, 19, 20, 21, 22, 23}; 4. Serial terminal
You can use the hardware serial of your Teensy to connect to a serial terminal.
I am using a USB Serial Cable COM-FOUR PL2303HX USB to TTL RS232 COM. Connect
RDX to TX1, TDX to RX1 and GND to GND. Output device node: /dev/ttyUSB0 As serial terminal use for example minicom. minicom -b 115200 -D /dev/ttyUSB0 -o
Leaving minicom: Press CTRL-A, then 'q'. 5. How to compile5.1. Install compilerDownload and install the Arduino IDE
Download Teensyduino and install to the Arduino IDE directory 5.2. Setup the MakefileOpen the Makefile of RC Gamepad and set
• the ARDUINO_HOME variable to your Arduino IDE installation directory. 5.3. CompileRun 'make' to compile the program. You find the compiled program (rcgamepad.hex) in the 'bin' directory. 6. How to flash6.1. Tool
Use the program 'teensy_loader_cli' to flash the Teensy.
6.2. Command to flashPress the white button on the Teensy to switch to the flash mode. Run: teensy_loader_cli -mmcu=mk20dx256 -v -w bin/rcgamepad.hex You can also use the 'flash' script: ./flash 7. CalibrationYou can calibrate the steering wheel and the accelerate/brake trigger.
1) Power on the RC Transmitter. Instead of the calibration, you can also use hardcoded values. In the program rcgamepad.cpp write '//' before '#define USE_CALIBRATE' to disable calibration. Write your values of the steering wheel and accelerate/brake trigger to the defines below. You get the correct values when you use the serial connection to a terminal and '#define PRINT_RC_VALUES' in the program. You can also flash the Teensy with the program 'RC Viewer' for the Teensy 3.2 and view the values. 7.1. Troubleshooting - No calibration modeWhen entering the calibration modes does not work, then turn the steering wheel to the maximum of the other side. Maybe it is inverted. If this is also not working, check that USE_CALIBRATE is defined and recompile the program and flash the Teensy. 8. RC Buttons - emulate buttonsThe RC Transmitter buttons are acting as switches. For example, when you press the button for channel 6, the button changes the state (pulse duration > 1000µs) and keeps it. When you press again, it changes the state (pulse duration < 1000µs) and keeps it. This behavior is useful for RC vehicles, but for gaming you need buttons that are acting as buttons. The Two-State Button function emulates a 400ms button press when the transmitter button state switches. 9. Console controllersRC Gamepad is not shipped with the original USB descriptors of the Xbox 360 and the PlayStation 3 Controller. When you have the original controller, then its possible to retrieve the USB descriptors with the program 'getdescriptors'. The program creates .h files. Those files have to be in the 'descriptors' directory. You find a precompiled version of the program in the 'descriptors' directory. Just run it with the connected original controller. The source code of 'getdesciptors' is also available. You find it in the directory 'getdescriptors_src'. Use 'make' to compile the program. The emulated console controllers will not work on their consoles out of the box, because the required security mechanism is not implemented. But you can use the emulated controllers on Linux, Windows, OSX and much more. 10. Gamepad USB Vendor and Product IDRC Gamepad is a non commercial program. I do not own an USB Vendor ID, so I am using the Teensy Vendor ID for demonstration purpose for the implemented gamepad. In descriptors/gamepad.h: #define GAMEPAD_VENDOR 0x16C0 // Teensy Vendor ID #define GAMEPAD_PRODUCT 0xFFF0 // No special number 11. TestingOn Linux: jstest /dev/input/js0 12. TroublesWhen you play a game and you have a strange behavior, then disable the RC values terminal output. Write '//' in front of '#define PRINT_RC_VALUES'. If this does not help, then disable the debug output. Set '#define DEBUG_TYPE DEBUG_NONE'. 13. Debug outputFor debugging, you can connect the Teensy with an USB Serial Cable an view the output for example with the program minicom. Wire details are shown at the 'Teensy - RC Viewer/RC Gamepad' circuit diagram and in the 'Teensy - USB/UART' area. 14. Mode informationVarious blink modes when transmitter is not powered on startup and for mode 1 - 'gaming mode', mode 2 - 'menu mode', mode 3 - 'alternate buttons mode'. Using handicappedTodo Photos© 2025 by
Elmar Hanlhofer |