Skip to content

Latest commit

 

History

History
72 lines (48 loc) · 2.4 KB

README.md

File metadata and controls

72 lines (48 loc) · 2.4 KB

Inkarta

A self-hostable, wireless e-ink picture frame system for the Soldered Inkplate 10.

Screenshot 2024-08-25 at 11 19 08 AM

Features

This repository contains two components:

  1. inkplate - Arduino sketch for the Soldered Inkplate, an ESP32-based e-paper display:
    • Displays pictures hosted on server.
    • Automatically updates the picture at midnight.
    • Enters low power mode until the next scheduled refresh or a manual refresh (via wake button), extending battery life to several months.
  2. server - Server written with Axum + HTMX + Jinja:
    • Web dashboard for uploading and managing images.
    • Handles image processing and storage to a SQLite database.
    • Produces single binary for easy deployment.

Getting Started

Server

The server requires a Rust installation in order to build.

  1. Navigate to the server/ directory.
  2. If you're cross-compiling for a different target architecture, you may prefer to use cross. Otherwise run cargo build --release.
    • e.g., Raspberry Pi OS (64-bit): cross build --release --target aarch64-unknown-linux-gnu.
  3. Deploy the binary created in target to your server.

Inkplate

Prerequisites

  1. Install the arduino-cli

    brew install arduino-cli
  2. Create inkplate/secrets.h with your Wi-Fi credentials and server info:

    const char *ssid = "YOUR_WIFI_SSID";
    const char *password = "YOUR_WIFI_PASSWORD";
    
    const char *host = "YOUR_SERVER_IP"
    const uint16_t port = "YOUR_SERVER_PORT";

Installation

  1. Connect the Inkplate to your computer via USB.

  2. Update sketch.yaml with your appropriate Inkplate fqbn and port:

    arduino-cli board list # Identify device's port
  3. Compile and upload the inkplate/inkplate.ino sketch to the Inkplate.

    arduino-cli compile --verbose --upload --profile default

Note

If you encounter a "Bad CPU type in executable" error on Apple Silicon, install Rosetta using softwareupdate --install-rosetta

Reference