Skip to content

Latest commit

 

History

History
124 lines (82 loc) · 3.73 KB

README.md

File metadata and controls

124 lines (82 loc) · 3.73 KB

WIFI CLOCK 2

A WiFi enabled smart-clock for ESP32 development boards.

gif

This is a work in progress rewrite of my original WiFi Clock. It's being rewritten to use my zIOTBP32 Biolerplate which enabled a soft AP for confiuguring WiFi access as well as many other quality of life features.

How It Works

First it will start a soft AP using a captive (sign in) portal. This lets you connect the device to your WiFi network.

Connect to the AP: WIFICLOCK

Enter your real SSID and password on the setup page.

Click "CONNECT".

Disconnect from the WIFICLOCK AP and connect to your real AP.

Now you are able to use a web based UI (either served from the device itself or locally) to control the clock.

The web UI can be accessed either from http://<deviceIP>/app or by directly opening the ui/index.html file in your browser.

You will never have to manually adjust this clock and it will always be perfectly in sync with the clock on your phone and computer (via NTP). It also has an onboard temp/humidity sensor (DHT11) for getting local environmental readings.

Using the web UI, you can control lots of things like the brightness of the LEDs, the border, the mode (clock, temp/humidity ect.).

Features

  • Soft AP for configuring WiFi credentials.
  • Web based UI.
  • Automatic state syncing between the device and the UI.
  • Automatic NTP time fetching.
  • Display local (indoor) temperature and humidity readings using an onboard sensor.
  • Display external (web based) weather conditions.
  • USB Powered.

Required Libraries

Required Components

  • ESP32 Dev Board
  • 4x MAX72xx LED Matrix Displays
  • DHT11
  • Jumper cables and breadboards.
  • 3D Printer (optional)

Wiring

All devices powered in parallel on 3.3v.

  • ESP32: Pin 18 (or SCK) -> Matrix: CLK

  • ESP32: Pin 23 (or MOSI) -> Matrix: DATA

  • ESP32: Pin 5 (or SS) -> Matrix: CS

  • ESP32: Pin 17 -> DHT: Out

wiring

Full Kicad files in Repo

Full resolution diagram only

Web UI

desktop-ui

(desktop UI)

mobile-ui

(mobile UI)

The web UI can be accessed either from http://<deviceIP>/app or by directly opening the ui/index.html file in your browser.

Using The API

In addition to the built-in web UI, you can also control the device directly through it's API.

GET /localTime

Get the local time of the clock.

GET /border

Get the border mode value.

GET /border?set={mode}

Set the border mode.

GET /mode

Get the mode value.

GET /mode?set={mode}

Set the mode.

GET /intensity

Get the intensity (brightness) value.

GET /intensity?set={0-15}

Set the intensity (brightness).

GET /say

Get the value of the stored text.

GET /say?set={text}

Set the value of the stored text. Also switches the mode to "say".

GET /state

Get the state of the device in JSON format.

GET /syncTime?hour={hour}&minute={minute}&second={second}

Set the time.

More Device Images

clock (clock mode) dht (temp/humidity mode) wiring (wiring)

Printing the housing

See the Housing README

Preview Housing On Github

housing-screenshot