1.0.0 • Published 9 years ago

tessel-nes v1.0.0

Weekly downloads
2
License
Public Domain
Repository
github
Last release
9 years ago

Tessel NES Controller Library

A simple Tessel library for interacting with the original Nintendo controller

Connection Information

The original NES controller has a 7 pin connector but only 5 are actually used. The following image shows what the connections are when looking at the connector.

The colors listed above are the most common but they aren't universal due to the huge number of knockoff controllers made. The best way to be sure is to use the continuity feature on your multimeter to see which wire goes to which hole on the connector after you cut it off. The connector image above shows which hole corresponds to which connection. Once you've identified the wires you can connect them to any port, including GPIO, on the Tessel as follows:

Controller ConnectionTessel Port Connection
GroundGround
Power3.3V
LatchG1
DataMISO
PulseSCK

Installation

npm install tessel-nes

Example

var tessel = require('tessel');
var nesController = require('tessel-nes').use(tessel.port['GPIO']);

nesController.on('ready', function(){
  // Query the button states every half second.
  setInterval(function(){
    nesController.query(function(err, buttons){
      console.log(buttons);
    });
  }, 500);
});

Events

NESController.on('ready', callback(err, controller)) - Emitted when the controller object is first initialized

NESController.on('up', callback()) - Emitted when up button is pressed*

NESController.on('down', callback()) - Emitted when down button is pressed*

NESController.on('left', callback()) - Emitted when left button is pressed*

NESController.on('right', callback()) - Emitted when right button is pressed*

NESController.on('a', callback()) - Emitted when A button is pressed*

NESController.on('b', callback()) - Emitted when B button is pressed*

NESController.on('select', callback()) - Emitted when select button is pressed*

NESController.on('start', callback()) - Emitted when start button is pressed*

*Button events will only fire after startListening() has been called

Methods

NESController.query(callback(err, buttonStates)) - Query the controller button states

NESController.startListening() - Controller will start polling for button presses and fire events when detected

NESController.stopListening() - Stop polling for button events.

Further Examples

Licensing

Public Domain. No restrictions.