USB NS Gamepad provides a Nintendo Switch (NS) compatible gamepad. This is useful for building an arcade console or to adapt other USB devices for use with the NS.
This project adds USB HID flight sticks and gamepads to the USBHost_t36 library so they can be used with the NS.
{ 0x0F0D, 0x00c1, HORIPAD, true}, // Hori Horipad NS compatible gamepad
{ 0x0079, 0x0006, DRAGONRISE, true},// Dragon Rise Fightstick/joystick
{ 0x046D, 0xC215, EXTREME3D, true}, // Logitech Extreme 3D Pro
{ 0x044F, 0xB10A, T16000M, true} // Thrustmaster T.16000M FCS
The Teensy 3.6 acts as a computer-in-the-middle between one or more game controllers and the NS. This can be used for co-pilot mode as well as simulator control panel/button boxes (car, truck, tractor, etc).
This project also provides additional USB device types for Teensy LC and 3.x.
USB Joystick provides a generic joystick. This is known to work with the Xbox Adaptive Controller (XAC). The XAC is confused by the extra USB descriptors in the other USB Joystick types.
USB Serial + Joystick provides a generic joystick with CDC ACM USB serial.
This project has not had much testing so watch out for potholes.
If you prefer Python, see the Raspberry Pi version of NSGadget. The Pi has enough GPIOs for NS buttons and the model B has 4 USB host ports. The Pi Zero is the cheapest option but it is hard to find. See https://github.com/gdsports/NSGadget_Pi.
Install the Arduino IDE 1.8.12 and Teensyduino 1.52. I highly recommend extracting the IDE zip or tar in a separate directory from the default Arduino directory.
On a Linux system, the following instructions will install the IDE into
~/nsg/arduino-1.8.12
. Creating the portable directory ensures the sketches and
libraries are stored separately from the default Arduino sketches and
libraries.
cd
mkdir nsg
cd nsg
tar xf ~/Downloads/arduino-1.8.12-linux64.tar.xz
cd arduino-1.8.12
mkdir portable
Run the Teensyduino installer. Make sure to install in the arduino-1.8.12 directory created above.
Copy the files in this repo's hardware directory to the arduino-1.8.12/hardware directory. This will overwrite Teensyduino files.
Start the IDE with all changes.
cd ~/nsg/arduino-1.8.12
./arduino&
Teensy LC impersonates a USB NS Gamepad.
Select "NS Gamepad" from the "Tools > USB Type" menu.
Pushbuttons should be connected between the digital pins and ground.
For maximum compatibility with the NS, the USB serial and other USB endpoints are not present. The USB descriptors are as much as possible same as the Hori gamepad controller. One consequence is the Teensy auto upload does not work. But this is easy to fix. Use the IDE Upload function. After the upload fails, press the Prog button on the Teensy to start the upload.
Emulating an NS controller is not a new idea. Reverse engineering began as soon as the console started shipping.
- https://github.com/dekuNukem/Nintendo_Switch_Reverse_Engineering
- https://github.com/progmem/Switch-Fightstick
Unlike the Xbox and PS, the NS does not do controller authentication so DIY controllers are much easier to implement.
For a graphic Teensy LC pin out diagram see the following. Teensy 3.x should also work but the LC is sufficient.
Function | LC Pin | LC Pin | Function |
---|---|---|---|
GND | Vin | ||
RX1 | 0 | GND | |
TX1 | 1 | 3.3V | |
Up | 2 | 23/A9 | Y |
Right | 3 | 22/A8 | B |
Down | 4 | 21/A7 | A |
Left | 5 | 20/A6 | X |
Left throttle | 6 | 19/A5 | Right throttle |
Left trigger | 7 | 18/A4 | Right trigger |
Minus | 8 | 17/A3 | Left X axis |
Left stick | 9 | 16/A2 | Left Y axis |
Capture | 10 | 15/A1 | Right X axis |
Home | 11 | 14/A0 | Right Y axis |
Plus | 12 | 13 | Right stick |
Serial1 (RX1/TX1) pins are available for debug output.
For graphic joy-con diagrams see the following.
Note 1: The thumbsticks are clickable so they also count as buttons. See "Left Stick" and "Right Stick" above.
Note 2: The direction buttons (Up, Right, Down, Left) are reported as an 8 direction D pad so some combinations cannot be reported.
Teensy 3.6 USB NS gamepad pass through and conversion.
Select "NS Gamepad" from the "Tools > USB Type" menu.
This example contains proof of concept code for various modes of operation. All USB controllers are active so the result is a kind of co-pilot mode. The NS sees a single gamepad but two or more people can be using controllers. For example, one person is driving with one controller while the other is aiming and shooting using a different controller.
Use one hand to control left and right sticks. The hat switch at the top of the stick is mapped to the right thumbstick. A nice feature of the Thrustmaster T.16000M is it can be configured for left hand using a screwdriver. See the manual for details.
Nintendo Switch -- Teensy 3.6 -- Thrustmaster T.16000M Flight Stick
Each fight stick kit has 9 buttons and 1 joystick (8 way switch). Find them searching ebay or Amazon for "arcade buttons stick kit". The USB encoder board identifies itself as a Dragon Rise joystick. The boards are identical so the convention is the first Dragon Rise board the sketch finds is assumed to be the left side of the controller. The next board is the right side. Using blue buttons for the left side and red buttons for the right continues the blue/red joy-con theme.
Nintendo Switch -- Teensy 3.6 -- USB hub -- Dragon Rise
-- Dragon Rise
Maybe someday use to record and play macros.
Nintendo Switch -- Teensy 3.6 -- NS compatible gamepad such as Horipad