Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/otherguy/esp8266weatherstation

A tiny weather forecast station using a NodeMCU ESP8266 and 3 MAX7219 8×8 LED matrices
https://github.com/otherguy/esp8266weatherstation

8x8-led-matrix esp8266 hardware micropython micropython-esp8266 nodemcu nodemcu-esp8266 weather-station

Last synced: 3 months ago
JSON representation

A tiny weather forecast station using a NodeMCU ESP8266 and 3 MAX7219 8×8 LED matrices

Awesome Lists containing this project

README

        

# 🌤 ESP8266 Weather Station

## Hardware

### Bill of Materials (BOM)

The following components are required (all through hole):

| Qty. | Item | Value | Label | Footprint | Price |
|----------|------------------------|----------------|------------|-----------|----------|
| 1 | ESP8266 NodeMCU v3 board (4MB flash) | - | | - | US$ 2.05 |
| 3 | MAX7219 8×8 SPI LED matrix | - | | - | US$ 3.14 |
| 1 | DC Female Power Socket | 5.5 × 2.1mm | `J1` | PTH | US$ 0.07 |
| 1 | Trimmer potentiometer | 3mm, 1kΩ | `R1` | DIP-3 PTH | US$ 0.04 |
| 1 | LED | green, 3mm | `LED1` | THT | US$ 0.02 |
| 1 | LED | yellow, 3mm | `LED2` | THT | US$ 0.02 |
| 1 | Resistor (axial) | 4.7kΩ, ¼W, ±5% | `R2` | THT | US$ 0.01 |
| 2 | Resistor (axial) | 100Ω, ¼W, ±5% | `R3`, `R4` | THT | US$ 0.01 |

I used [RobotDyn yellow/amber colored modules](https://www.aliexpress.com/item/32732745628.html). A lot
of other modules will also work, but they need to be 5-pin SPI chainable modules. Be aware of the pinout!

For the ESP8266 board, I used a [KeyeStudio NodeMCU](https://www.aliexpress.com/item/32668574859.html) but any
other NodeMCU V2 or V3 board also works.

The knockoff V3 boards are better because they use a CH340 USB controller chip and have the `A0` pin reference
voltage set at `3.3V` instead of `1.0V`, meaning no voltage divider circuit is needed.

### Circuit Board

The circuit board is very simple and just holds the ESP8266 and the 3 LED matrices as
well as the power jack and a trimpot to adjust the LED brightness.

I had 10 boards (1.6mm FR4 ENIG, RoHS, black solder mask) manufactured by [JLPCB](https://jlcpcb.com) for
US$ 44.00 including shipping in April 2021. The black solder mask makes it easy to prevent reflections inside
the case (and it looks gorgeous).

The [Fritzing file](hardware/NodeMCUWeatherStation.fzz) as well as the exported
[Gerber files](hardware/NodeMCUWeatherStation_Gerber.zip) can be found in the [hardware](hardware) folder.

![Finished PCB](resources/jlcpcb_boards.jpg "JLCPCB Finished PCB")

![Breadboard View](resources/NodeMCUWeatherStation_bb.png "Breadboard View")

![Schema View](resources/NodeMCUWeatherStation_schema.png "Schema View")

The [`robotdyn-max7219-LED-matrix.fzpz`](hardware/robotdyn-max7219-LED-matrix.fzpz) Fritzing part was made
by [`@vanepp`](https://forum.fritzing.org/u/vanepp) on the Fritzing forums.

### Outer Case

[TBD]

## Software

### Prerequisites

Install [`esptool`](https://github.com/espressif/esptool) and [`ampy`](https://github.com/scientifichackers/ampy).

```bash
$ pip3 install --user esptool
$ pip3 install --user adafruit-ampy
```

### Install MicroPython

Download the latest [MicroPython firmware for ESP8266](https://micropython.org/download/esp8266/) and flash it to the NodeMCU.
[`esp8266-20220117-v1.18.bin`](firmware/esp8266-20220117-v1.18.bin) and flash it to the ESP8266.

_Note:_ Since July 2024, when using the OpenWeatherMap API, you need to use a custom build of MicroPython with a larger TLS buffer. See the section below for more details.

_Note:_ The USB serial device (`/dev/tty.usbserial-1430`) will be different, depending on your operating
system, USB controller and port you use.

```bash
$ esptool.py --port /dev/tty.usbserial-1430 erase_flash
$ esptool.py --port /dev/tty.usbserial-1430 --baud 460800 write_flash --flash_size=detect -fm dio 0x00 firmware/ESP8266_GENERIC-20240602-v1.23.0.bin
```

### Workaround for TLS buffer overflow in axtls

OpenWeatherMap switched to a new SSL certificate in July 2024 which is too large for the default buffer size in the ESP8266's MicroPython TLS implementation with axTLS. This causes the ESP8266 to crash when trying to fetch weather data. To address this, the buffer size needs to be increased by recompiling the firmware with appropriate settings. More details can be found in [this GitHub issue](https://github.com/micropython/micropython/issues/3279).

I have provided a precompiled firmware image with the necessary changes in the [firmware](firmware) folder. The firmware is based on MicroPython `1.23.0` and has a larger TLS buffer size of 8192 bytes. Simply use the [`ESP8266_GENERIC-20240602-v1.23.0-tls-buffer-8192.bin`](firmware/ESP8266_GENERIC-20240602-v1.23.0-tls-buffer-8192.bin) file instead of [`ESP8266_GENERIC-20240602-v1.23.0.bin`](firmware/ESP8266_GENERIC-20240602-v1.23.0.bin).

You can also compile the firmware for ESP8266 yourself with the following steps:

```bash
gh repo clone micropython/micropython
cd micropython
git checkout v1.23.0
make -C ports/esp8266 submodules
docker run --rm -v $HOME:$HOME -u $UID -w $PWD -e GIT_DISABLE_UNTRACKED_CACHE=1 larsks/esp-open-sdk make -j8 -C mpy-cross
cd ports/esp8266
docker run --rm -v $HOME:$HOME -u $UID -w $PWD -e GIT_DISABLE_UNTRACKED_CACHE=1 larsks/esp-open-sdk make -j8 AXTLS_DEFS_EXTRA="-Dabort=abort_ -DRT_MAX_PLAIN_LENGTH=1024 -DRT_EXTRA=8192" BOARD="ESP8266_GENERIC"
```

The firmware can then be found at `build-ESP8266_GENERIC/firmware.bin`.

### Configure Settings

Edit [`secrets.py`](src/secrets.py) and configure the values for your WiFi network (`WIFI_SSID` and `WIFI_PASSWORD`).

Next, sign up for a free account on [OpenWeather](https://openweathermap.org/), generate
[an API key](https://home.openweathermap.org/api_keys) and set it in the `OW_API_KEY` constant in [`secrets.py`](src/secrets.py).

Find the location you want to display weather data for on [OpenWeather](https://openweathermap.org/) and set the
`GEO_NAME`, `GEO_LAT` and `GEO_LON` constants in [`secrets.py`](src/secrets.py). `GEO_NAME` is not really used at the
moment, so it's only a reminder for you so you know what place you're looking at.

`DISPLAY_OFF_START` and `DISPLAY_OFF_END` are used to control when the display is turned off, e.g. at night. The value
is the hour in 24-hour format, in UTC. Adjust accordingly. If you're in New York City and you want the display to turn
off from 11pm to 7am, you might want to set `DISPLAY_OFF_START` to `3` and `DISPLAY_OFF_END` to `11`. Set both values
to `0` if you never want to turn off the display.

### Upload Software

Use [Adafruit's `ampy` tool](https://github.com/adafruit/ampy) to upload the software to the ESP8266. Adjust the
port according to your operating system and USB controller.

```bash
$ ampy --port /dev/tty.usbserial-1430 --baud 115200 put src/boot.py
$ ampy --port /dev/tty.usbserial-1430 --baud 115200 put src/max7219.py
$ ampy --port /dev/tty.usbserial-1430 --baud 115200 put src/symbols.py
$ ampy --port /dev/tty.usbserial-1430 --baud 115200 put src/secrets.py
$ ampy --port /dev/tty.usbserial-1430 --baud 115200 put src/main.py
```

## Other

### Trimmer Potentiometer

The trimmer potentiometer at `R1` is used to adjust the brightness of the display. The brightness is always
forced to be at the lowest value when the power jack is unplugged. Whe `DISPLAY_OFF_START` and `DISPLAY_OFF_END`
are set to any other value than `0`, the display will be turned off during the specified time period and the
potentiometer value is ignored.

### LEDs

`LED 1` is used to indicate network activity, while connecting to WiFi or fetching weather data.

`LED 2` is used for debugging purposes. It blinks every 2 seconds (or whatever you set in `BLINK_DELAY`). If it
does not blink, it means that the display is not updating and the ESP8266 has locked up.

### Weather Icons

The weather icons were custom designed using this excellent [LED Matrix Editor](https://git.io/J3N9M).

![Weather Icons](resources/weather-icons.png "Custom Weather Icons: #185a66bddb663c00|894218bc3d184291|001ea1a919a6c0ec|00007e818999710e|152a547e8191710e|0a04087e8191710e|55aa55aa55aa55aa|a542a51818a542a5|180018183c3c1800|1800183860663c00")