Home
Softono
maptoposter-online

maptoposter-online

Open source MIT TypeScript
477
Stars
21
Forks
1
Issues
1
Watchers
2 weeks
Last Commit

About maptoposter-online

โœจโค๏ธโ€๐Ÿ”ฅTurn the cities you love into stunning designs

Platforms

Web Self-hosted

Languages

TypeScript

MapPoster Online

MapPoster Online

Turn the cities you love into stunning designs

English | ็ฎ€ไฝ“ไธญๆ–‡


Project Description

A browser-based upgrade to maptoposter (Python CLI) โ€” no installation needed, just open and go

React TypeScript Tailwind CSS Bun Rust License

Gallery

Asia

China - Beijing Japan - Tokyo South Korea - Seoul China - Hong Kong
Beijing Tokyo Seoul Hong Kong
Singapore Malaysia - Kuala Lumpur Thailand - Bangkok India - New Delhi
Singapore Kuala Lumpur Bangkok New Delhi

Europe

Switzerland - Zurich Norway - Oslo Sweden - Stockholm Denmark - Copenhagen
Zurich Oslo Stockholm Copenhagen
Austria - Vienna Germany - Berlin United Kingdom - London France - Paris
Vienna Berlin London Paris
Italy - Rome Russia - Moscow Turkey - Istanbul Netherlands - Amsterdam
Rome Moscow Istanbul Amsterdam

Americas, Africa & Oceania

USA - New York Canada - Ottawa Brazil - Sรฃo Paulo Mexico - Mexico City
New York Ottawa Sao Paulo Mexico City
Argentina - Buenos Aires Australia - Melbourne South Africa - Cape Town Chile - Santiago
Buenos Aires Melbourne Cape Town Santiago

Features

  • ๐Ÿš€ Zero installation โ€” Runs entirely in the browser. Open the site, pick a city, and download your poster
  • โšก Rust/WASM rendering engine โ€” High-performance map rendering compiled from Rust to WebAssembly (powered by tiny-skia)
  • ๐Ÿ‘๏ธ Live preview โ€” See changes instantly and confirm results before exporting
  • ๐ŸŽจ 20 built-in themes โ€” From frozen Nordic minimalism to cyberpunk neon, vintage nautical to glitch purple
  • โœ๏ธ Custom color controls โ€” Fine-tune every color: background, roads, water, green spaces, POIs, and text
  • ๐Ÿ“ Multiple export formats โ€” A4 (portrait/landscape), square, phone wallpaper, desktop 16:9, at 300 DPI for high-quality print
  • ๐ŸŒ Multi-language interface โ€” Supports English, Japanese, Korean, Simplified Chinese, German, Spanish, and French
  • ๐Ÿ’พ IndexedDB caching โ€” Previously fetched map data is cached locally for faster regeneration
  • ๐Ÿ”ค Dynamic font loading โ€” Use built-in serif fonts or upload your own TTF/OTF files
  • ๐Ÿ Snake game โ€” Beat boredom while waiting for your poster to generate (inspired by Chrome Dinosaur Game)

How it differs from maptoposter (Python CLI)

This project was inspired by maptoposter (Python CLI) โ€” they each have their own strengths for different use cases:

maptoposter-online maptoposter (Python CLI)
Usage Open in browser, no install needed Command-line interface, requires local setup
Best for Quick start, on-the-go usage Command-line enthusiasts, advanced local customization
Rendering engine Rust/WASM (tiny-skia) Python/matplotlib
Platform Cross-browser, any device Desktop only (requires Python)

Different tech stacks, same goal โ€” turning your favorite city into unique art.

Local Development

Tech Stack

  • Build โ€” Vite 7 + Bun
  • Frontend โ€” React 19 + TypeScript
  • Styling โ€” Tailwind CSS v4
  • UI components โ€” Radix UI + lucide-react
  • Map data โ€” OpenStreetMap (Overpass API) + Protomaps
  • Rendering โ€” Rust (wasm-pack) + tiny-skia
  • i18n โ€” @inlang/paraglide-js
  • Caching โ€” IndexedDB (idb)

Requirements

Setup

# 1. Install dependencies
bun install

# 2. Build the Rust/WASM rendering engine
# Compile Rust to WebAssembly using wasm-pack
cd wasm && wasm-pack build --target web --out-dir ../src/pkg
# Or use the npm script:
bun run build:wasm

# 3. Start the dev server
bun run dev

# 4. App available at http://localhost:5173

Available Scripts

Command Description
bun run dev Start dev server
bun run build Build for production
bun run build:wasm Rebuild WASM engine
bun run preview Preview production build
bun run lint Run linter
bun run fix Format + lint with auto-fix

Engineering Notes

Rendering Engine โ€” Rust/WASM

  • Font anti-aliasing โ€” 2ร— supersampling + Box Filter downsampling
  • Road hierarchy lacking depth โ€” Road casing rendered in two passes (stroke first, then fill) + Z-order controls draw sequence by road class
  • Rendering too slow โ€” Douglas-Peucker in screen coordinate space removes subpixel redundancy; single-scan dispatch by feature type

Data Processing

  • Python OSMnx workflow ported โ€” Professional geospatial data processing logic adapted from osmnx
  • Overpass query failures โ€” Auto-splits oversized areas into smaller chunks (2500kmยฒ default limit) to prevent Overpass failures
  • Single node timeout causing long waits โ€” Concurrent requests to 4 mirror servers, fastest response wins

Page Responsiveness

  • Generation blocking the page โ€” Data fetching, projection transforms, and WASM rendering all run in a Web Worker; road precision auto-reduces at large radii
  • Repeated generation taking too long โ€” IndexedDB Gzip-compressed cache, ~100KB per city; direct read on regeneration

License

MIT License โ€” see LICENSE

๐Ÿ’– Support

If this project has saved you time or made your life easier, consider buying me a coffee. Your support is the driving force behind the continued maintenance of this project!

Platform Payment Method Link
Afdian WeChat / Alipay ๐Ÿ‘‰ Click to Sponsor
Buy Me a Coffee Credit Card / Apple Pay / Google Pay ๐Ÿ‘‰ Click to Sponsor

Acknowledgments

Inspired by @originalankur's maptoposter

Map data provided by OpenStreetMap and Protomaps

Font LXGW Neo ZhiSong (้œž้นœๆ–ฐ่‡ดๅฎ‹) by lxgw, licensed under IPA Font License 1.0