Watchy by SQFMI
Getting Started
Contents
Jump to…
- Watchy Kit w/ Case Assembly
- Watchy Kit with Case
- Arduino Setup
- WiFi Configuration
- PlatformIO Configuration
Watchy Kit w/ Case Assembly
Before You Start: thoroughly review the instructions and inspect for any missing or damaged parts.
- Carefully Remove The Components: The display is made of glass and will crack if bent!
- Test Your PCB: Verify the board is functional!
- Do Not Apply The Included Tape: Watchy can be assembled and secured using the included enclosure without tape. Only use the tape if you plan to use Watchy without the enclosure and have triple-checked the screen alignment.
Assembly Instructions
- Connect the screen to the FPC connector: Ensure the shiny gold pins on the ribbon cable face up. The ribbon cable should pass through the PCB slot as shown in the image.
- Connect the battery.
- Connect the USB to start charging the battery.
- Press SW1: to bring up the menu/confirm.
- Press SW3 & SW4: to navigate up/down.
- Press SW2: to exit/cancel.
Watchy Buttons
Wait one minute to verify if the clock updates the time correctly.
Tips
- Ensure the screen is perfectly aligned before taping it down! It should not extend above or below the strap holes on the PCB.
- Tuck in the battery cable. Everything should fit snugly and be aligned with the bottom case before securing the top case.
- Do NOT force the case to close. It could damage the screen & buttons! The case should close easily with the top and bottom snaps latching.
- Do NOT overtighten the screws in the aluminum case. Overtightening can crack the screen! Ensure everything fits properly and slowly adjust the screws to secure the case.
- Still having issues? Check out our step-by-step guide on assembling the case in our FAQ.
Assembly Videos
Watchy Original Assembly
- Apply tape to the back of the E-Paper display and battery. The front of the display is white, and the back is metallic/silver.
- Pull lightly to unlock the FFC connector, insert the display cable through the strap hole. Ensure the cable is fully inserted, then push the lock back in to secure the cable.
- Fold back and align the display to the top of the PCB, peel off the tape, and firmly secure the display.
- Insert the battery plug, ensuring correct polarity (red is closer to the USB connector).
- Peel off the tape and firmly secure the battery to the PCB.
- Insert the watch strap through the PCB strap holes, then tighten the strap from both ends.
- Wrap the strap around your arm and adjust for comfort.
Assembly Video
Arduino Setup
Watchy comes pre-loaded with firmware that showcases all basic features. You can also experiment with different watch faces and examples in Arduino.
- Download and install the latest Arduino IDE.
- Start Arduino and open File > Preferences.
- Under Additional Board Manager URLs add:
- Open Tools > Board > Boards Manager and install the latest version of the esp32 platform.
- Under Sketch > Include Library > Manage Libraries, search for Watchy and install the latest version.
- Ensure all dependencies are updated to the latest versions, i.e., GxEPD2, WiFiManager, rtc_pcf8563, etc.
Upload
- Plug in the USB on Watchy and select the serial port that appears.
- If nothing appears or if you’re having trouble uploading, ensure you have the USB-Serial drivers installed. Also, make sure you’re using a USB data cable, not a charge-only cable. Try different USB ports if necessary.
- Select Tools > Board > ESP32 Arduino > Watchy.
- Select Tools > Board Revision > Watchy v2.0.
- Select Tools > Partition Scheme > Huge App.
- Leave everything else as default.
- Choose an example and click upload.
- Experiment with modifying the examples or create your own app!
WiFi Configuration
- Click ‘Setup WiFi’ from the main menu on the watch.
- Connect to ‘Watchy AP’ WiFi from another device such as a phone or computer/laptop.
- Open
192.168.4.1
in the browser. On an iPhone, this page opens automatically when connecting to WiFi. - Click ‘Configure WiFi’.
- Enter SSID and password. (Note: SSID can be prefilled by listed networks at the top of this screen).
- Hit ‘Save’ and wait for Watchy.
- If the connection fails, Watchy will display ‘Setup failed & timed out!’. Otherwise, it will show the local IP address and SSID of the connected network with confirmation.
Troubleshoot WiFi Configuration
- Click ‘Info’ from
192.168.4.1
page. - Check your router settings to ensure the listed MAC address is allowed.
- If the above steps don’t work, try clicking ‘Erase WiFi Config’ from the ‘Info’ page and wait for Watchy to restart. Once it restarts, attempt the WiFi setup again.
PlatformIO Configuration
PlatformIO is a suitable alternative to Arduino, more oriented for command line users but also flexible and predictable in build configurations and dependency management (like libraries).
It comprises two parts: a “core” with the command line tools that build and upload/flash, and an “IDE” consisting of plugins and extensions for editors.
Use any extensions you prefer, but this documentation focuses on the core:
Installation Instructions
- Create a new folder and setup the PlatformIO project layout:
mkdir my_new_watchy_face_project
cd my_new_watchy_face_project
pio project init --board esp32dev
- Add the following to the platformio.ini file. Note that if you want to use a different version of the Watchy library, you can specify any file or git path here.
lib_deps =
sqfmi/Watchy ;
https://github.com/tzapu/WiFiManager.git#v2.0.11-beta ; Pinned for consistency
lib_ldf_mode = deep+
board_build.partitions = min_spiffs.csv
# Run PlatformIO: it will download dependencies such as the Watchy library but will fail to compile because there aren't any source files in src/ yet. So, once dependencies are downloaded, copy the 7_SEG example files to src/.
pio run # will fail compilation but will download dependencies
cp .pio/libdeps/esp32dev/Watchy/examples/WatchFaces/7_SEG/*.{ino,cpp,h} src/
# Plug in your Watchy, compile, and then upload the watch face:
pio run -t upload
# Monitor the serial port output:
pio device monitor
# Celebrate by watching ASCII Star Wars:
telnet towel.blinkenlights.nl
# Additional keys you might want to add to your platformio.ini file:
upload_speed = 3000000
upload_port = /dev/cu.usbserial-MQK8G8
monitor_port = /dev/cu.usbserial-MQK8G8
monitor_speed = 115200
monitor_filters = esp32_exception_decoder