Skip to main content

A minimalist PNG dashboard shown as an always-on screensaver on Kindle e-readers.

Project description

Kindle Dashboard

A minimalist Python web service that renders a greyscale PNG dashboard for Kindle-sized screens.

Usage Guide

The Dashboard

Kindle Dashboard screenshot

  • The time and battery are shown in the top-right
  • The next significant rainfall window is shown in the top-left (>1 mm precipitation)
  • Cloud cover is shown as a darkness band at the top of the graph
  • Temperature is shown as a line graph, with the daily low and high points marked
  • The temperature guide lines are spaced at 5 °C
  • Sunrise and sunset are indicated subtly
  • Precipitation is shown as bars at the bottom, with the peak labelled
  • Precipitation guide lines are spaced every 0.2 mm
  • When showers dominate rain, the precipitation bars are dotted

Depending on your online screensaver configuration, the information will be somewhat out-of-date - notably the time.

Weather data is retrieved from Open-Meteo in the forecast location's local timezone.

Quick guide to standing in rain for one hour:

  • 0.1mm: you'll be dry
  • 0.3mm: you'll be damp
  • 0.5mm: you'll be wet
  • 0.7mm: you'll be soaked
  • 0.9mm: you'll be dripping

Prerequisites

  • Python 3.14+

On Your Kindle

Put the dashboard on your Kindle using https://github.com/FalconFour/onlinescreensaverPW2.

Running the Server

The simplest way is using uv.

Try it out without installing: WEATHER_LATITUDE=5 WEATHER_LONGITUDE=-5 uvx kindle-dashboard.

Or, install for your user, and run from there:

uv tool install kindle-dashboard
kindle-dashboard

The server serves the dashboard image on http://127.0.0.1:42137/, by default.

There is an example systemd service file.

Configuration

  • HOST (default: 127.0.0.1)
  • PORT (default: 42137)
  • IMAGE_WIDTH (default: 600)
  • IMAGE_HEIGHT (default: 800)
  • RENDER_SUPERSAMPLE_SCALE (default: 2)
  • WEATHER_UPDATE_SECS (default: 1800)
  • NEXT_RAIN_GAP_TOLERANCE_HOURS (default: 1; merges rain events separated by dry gaps up to this many hours)
  • WEATHER_LATITUDE (optional; must be set together with WEATHER_LONGITUDE)
  • WEATHER_LONGITUDE (optional; must be set together with WEATHER_LATITUDE)
  • LOG_LEVEL (default: INFO; standard Python logging levels)
  • LOG_SYSTEMD (optional; set 1/true to force systemd log format, 0/false to disable auto-detect)

The weather graph is shown shown if the latitude and longitude variables are set.

When JOURNAL_STREAM is present (typical under systemd), logging automatically switches to systemd-compatible output.

Development Guide

Development

uv sync
  • bin/fix applies automatic linting fixes (run this first)
  • bin/check runs linting, type checks, and release validation
  • bin/test runs the test suite
uv run kindle-dashboard

Build and Publish

bin/publish

Development Notes

  • Precipitation bars represent the hour interval ending at the API timestamp (for example, a value at 16:00 is drawn for 15:00-16:00).
  • The Kindle Basic 7th Generation has a 16-level greyscale display.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

kindle_dashboard-3.tar.gz (32.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

kindle_dashboard-3-py3-none-any.whl (38.7 kB view details)

Uploaded Python 3

File details

Details for the file kindle_dashboard-3.tar.gz.

File metadata

  • Download URL: kindle_dashboard-3.tar.gz
  • Upload date:
  • Size: 32.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Arch Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for kindle_dashboard-3.tar.gz
Algorithm Hash digest
SHA256 2a74517a48ac216a41b53457ce77939dc6bd2f65698b24301dab2fdfd96d84a3
MD5 8ac74350c66ad10c2efec5b9505acb9b
BLAKE2b-256 d01788c62d3dff4293d0ecc320594d7e110a14f8ec2f74f5d0e928e3e2958ac6

See more details on using hashes here.

File details

Details for the file kindle_dashboard-3-py3-none-any.whl.

File metadata

  • Download URL: kindle_dashboard-3-py3-none-any.whl
  • Upload date:
  • Size: 38.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Arch Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for kindle_dashboard-3-py3-none-any.whl
Algorithm Hash digest
SHA256 78a60b69362eeed8b777a20424ec41ebea84676116f88e3b16ef0840ab2517e2
MD5 f23c327ad2144d093ab297f7be23a65c
BLAKE2b-256 b26e274f40e88325c109bed592226d5873f0f95e2e0853fcf551f66ae00e785b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page