Skip to content

Latest commit

 

History

History
150 lines (104 loc) · 6.7 KB

readme.md

File metadata and controls

150 lines (104 loc) · 6.7 KB

You're about to make your own MTA clock!

Here's how to do it:

  1. Host a server (to translate the complex MTA API into something more RESTful).
  2. Put and run MTA API code on the server.
  3. Buy parts.
  4. Wire it up.
  5. Install some software.
  6. Set up your Arduino project.
  7. Edit your MTA Clock preferences.
  8. Compile and upload the code.
  9. Make an enclosure.
  10. Assemble.
  11. Don't miss your train!

1. Host a server.

  • Recommended: Launch a cloud linux instance, e.g. Ubuntu on AWS. (More verbose instructions here
  • Configure the instance's network (and security) settings such that it can respond to requests from wherever the subway clock will be.
  • Connect to your server over SSH.

3. Put and run MTA API code on the server.

  • Put the MTA API code on the server by cloning from git repo.
  • Use this command in terminal while controlling your server: git clone https://github.com/jonthornton/MTAPI
  • cd into the repo top-level directory: cd MTAPI/
  • Update your Ubuntu server so it can install stuff: sudo apt-get update && sudo apt-get upgrade
  • Install python on your server: sudo apt-get install python3-venv
  • Create a new python virtual environment: python3 -m venv .venv
  • Create a new tmux session (allowing the code to run unattended): tmux new -s session-name
  • Activate the virtual environment: source .venv/bin/activate
  • Install necessary python libraries: pip install -r requirements.txt
  • Launch the service and begin listening for requests: python app.py
  • Detach from the tmux session: ctrl-b, then press d key
  • Disconnect from the ec2 server: logout
  • It should be running on its own now!

4. Buy parts.

These are the parts you will need and some examples of where to find them:

Total cost estimate: ~$50-80 depending on parts availability

5. Wire it up.

Adafruit OLED Wiring Guide:

OLED pin ESP32 pin
1 (gnd) GND
2 (vin) VIN
4 (rs) 14
5 (rw) 32
6 (en) 26
11 (d4) 33
12 (d5) 27
13 (d6) 12
14 (d7) 13
  • If your ESP32 has different pins labeled, feel free to swap out pins per this pinout guide, but also update line 24 Adafruit_CharacterOLED lcd(OLED_V2, 14, 32, 26, 33, 27, 12, 13); in the mta_clock.ino accordingly: https://randomnerdtutorials.com/esp32-pinout-reference-gpios/

  • Optional: Connect, an on/off switch between ESP32 pin 25 (or any other digital pin) and GND.

6. Install some software.

6.1 Install ArduinoIDE.

6.2 Install ESP board in Arduino.

6.3 Install necessary libraries.

  • Open Library Manager from Tools > Manage Libraries...
  • Search for "Arduino_JSON" and Install
  • Download ZIP from here: https://github.com/ladyada/Adafruit_CharacterOLED
  • Add the library to Arduino from Sketch > Include Library > Add .ZIP Library...

7. Set up your Arduino project.

  • If you haven't already, download the ZIP of this Git Repo.
  • Move the folder "mta_clock" from the ZIP folder into your Sketchbook folder.
  • If you don't know where that is, it is listed at File > Preferences > Sketchbook location

8. Edit your MTA Clock preferences.

  • Open the mta_clock.ino sketch from File > Sketchbook > mta_clock
  • Go to the preferences.h tab.
  • Replace the default with your Wifi network info, server IP (found in your EC2 instances, use the IPv4 address), and other preferred settings. You can find the codes for StationID's here.
  • Save your changes.

9. Compile and upload the code.

  • Connect the ESP32 to the computer with the USB cable.
  • Ensure that the correct port is selected at Tools > Port > /dev/cu.usbserial*
  • Ensure that Tools > Upload Speed is set to 115200
  • Click the check mark to "Verify" (a.k.a. Compile) the code.
  • Click the => to upload the code to your ESP32.
  • Wait.... this will probably take a minute or two.
  • When it's done uploading, you can open the Serial monitor (set to Baud rate: 115200) with the magnifying glass button to see how it's doing.

NOTE: For some reason, the LCD might not display properly while the serial monitor window is open.

ANOTHER NOTE: The LCD won't reset when the ESP32 resets, so you might have to unplug and replug the usb cable to get it to display properly.

10. Make an enclosure.

NOTE: It did not fit my display and there isn't a great way to mount the ESP32.

  • Alternatively, you can 3D print the enclosure found in the git. To avoid supports:
    • Print main_enclosure_switch.stl or main_enclosure_noswitch.stl lcd-face down
    • Print enclosure_cover.stl on one end - the little tabs are tapered on one edge more than the other and that should face down.

11. Assemble.

If you're happy with your preferences, and everything fits properly in the enclosure, you can solder the connections and install everything in the enclosure.

12. Don't miss your train!

If you're still reading, thanks for reading me. Now, credit where credit is due! Thanks to:

Zach Kuperstein for toiling in an unfamiliar language to make this, and making the instructions as clear as possible!

Jon Thornton for making the MTA's GTFS protobuf accessible.

Bill & George at NYC Resistor for making the first generation version of this.

The MTA for making its data available to the public.