* fix(docker): support multi-platform builds and fix monorepo paths Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * perf(renderer): cache pre-rasterized paragraph images to avoid per-frame glyph rasterization (#76) * fix(canvas): stabilize frame label size during zoom Draw frame labels in screen-space after the viewport transform restore, converting scene coords manually. Previously fontSize=12/zoom fed into Math.ceil caused integer-boundary jumps that made labels flicker during zoom. Also skip shadow rendering while actively zooming for smoother performance. * perf(renderer): cache pre-rasterized paragraph images to avoid per-frame glyph rasterization - Add paraImageCache (SkImage, 128 MB LRU limit) keyed on the same key as paraCache - Use drawImageRect instead of drawParagraph on cache hit, skipping per-frame glyph shaping and rasterization - Fall back to direct drawParagraph only when off-screen surface creation (MakeSurface) fails - Extract _dpr getter to deduplicate device-pixel-ratio resolution logic across draw paths - Evict oldest entries when cache exceeds byte limit; delete SkImage on eviction and dispose() * feat(cli): introduce OpenPencil CLI for terminal control of the design tool - Added a new CLI application under `apps/cli` to manage OpenPencil from the terminal. - Implemented commands for app control (`start`, `stop`, `status`), document operations (`open`, `save`, `get`, `selection`), and design manipulation (`design`, `import`). - Enhanced documentation with usage instructions and platform support details. - Updated build scripts to include CLI compilation and publishing processes. - Introduced a new GitHub Actions workflow for publishing the CLI to npm. - Updated existing workflows to integrate CLI build steps and ensure proper versioning across packages. * docs: update README files to include CLI tool details and multi-platform code export - Added CLI section to README files in multiple languages, detailing commands for terminal control of the design tool. - Included instructions for global installation and usage examples for the CLI. - Expanded documentation on multi-platform code export capabilities from a single `.op` file to various frameworks. - Updated CLAUDE.md to reference the new CLI documentation and its integration with the design tool. * chore(bun.lock): update package dependencies to specific versions - Removed workspace references for several packages in the bun.lock file. - Updated dependencies for `@zseven-w/pen-core`, `@zseven-w/pen-types`, `@zseven-w/pen-codegen`, `@zseven-w/pen-figma`, and `@zseven-w/pen-renderer` to version `0.5.1-beta.1`. - Ensured consistency in dependency management across the project. --------- Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com> Co-authored-by: leinaldo <60176594+leinaldo@users.noreply.github.com>
16 KiB
OpenPencil
Das weltweit erste KI-native Open-Source-Vektordesign-Werkzeug.
Parallele Agententeams • Design-as-Code • Eingebauter MCP-Server • Multi-Modell-Intelligenz
English · 简体中文 · 繁體中文 · 日本語 · 한국어 · Français · Español · Deutsch · Português · Русский · हिन्दी · Türkçe · ไทย · Tiếng Việt · Bahasa Indonesia
Auf das Bild klicken, um das Demo-Video anzusehen
Warum OpenPencil
🎨 Prompt → CanvasBeschreiben Sie jede UI in natürlicher Sprache. Beobachten Sie, wie sie in Echtzeit mit Streaming-Animation auf der unendlichen Canvas erscheint. Ändern Sie bestehende Designs, indem Sie Elemente auswählen und chatten. |
🤖 Parallele AgententeamsDer Orchestrierer zerlegt komplexe Seiten in räumliche Teilaufgaben. Mehrere KI-Agenten arbeiten gleichzeitig an verschiedenen Bereichen — Hero, Features, Footer — alle parallel streamend. |
🧠 Multi-Modell-IntelligenzPasst sich automatisch an die Fähigkeiten jedes Modells an. Claude erhält vollständige Prompts mit Thinking; GPT-4o/Gemini deaktivieren Thinking; kleinere Modelle (MiniMax, Qwen, Llama) erhalten vereinfachte Prompts für zuverlässige Ausgabe. |
🔌 MCP-ServerEin-Klick-Installation in Claude Code, Codex, Gemini, OpenCode, Kiro oder Copilot CLIs. Designen Sie aus Ihrem Terminal — |
📦 Design-as-Code
|
🖥️ Läuft überallWeb-App + native Desktop-Anwendung auf macOS, Windows und Linux über Electron. Auto-Updates über GitHub Releases. |
⌨️ CLI —
|
🎯 Multiplattform-Code-ExportExport aus einer einzigen |
Schnellstart
# Abhängigkeiten installieren
bun install
# Entwicklungsserver auf http://localhost:3000 starten
bun --bun run dev
Oder als Desktop-App ausführen:
bun run electron:dev
Docker
Mehrere Image-Varianten sind verfügbar — wählen Sie die passende für Ihre Anforderungen:
| Image | Größe | Enthält |
|---|---|---|
openpencil:latest |
~226 MB | Nur Web-App |
openpencil-claude:latest |
— | + Claude Code CLI |
openpencil-codex:latest |
— | + Codex CLI |
openpencil-opencode:latest |
— | + OpenCode CLI |
openpencil-copilot:latest |
— | + GitHub Copilot CLI |
openpencil-gemini:latest |
— | + Gemini CLI |
openpencil-full:latest |
~1 GB | Alle CLI-Tools |
Ausführen (nur Web):
docker run -d -p 3000:3000 ghcr.io/zseven-w/openpencil:latest
Mit KI-CLI ausführen (z.B. Claude Code):
Der KI-Chat basiert auf Claude CLI OAuth-Login. Verwenden Sie ein Docker-Volume, um die Login-Sitzung beizubehalten:
# Schritt 1 — Login (einmalig)
docker volume create openpencil-claude-auth
docker run -it --rm \
-v openpencil-claude-auth:/root/.claude \
ghcr.io/zseven-w/openpencil-claude:latest claude login
# Schritt 2 — Starten
docker run -d -p 3000:3000 \
-v openpencil-claude-auth:/root/.claude \
ghcr.io/zseven-w/openpencil-claude:latest
Lokal bauen:
# Basis (nur Web)
docker build --target base -t openpencil .
# Mit einem bestimmten CLI
docker build --target with-claude -t openpencil-claude .
# Vollständig (alle CLIs)
docker build --target full -t openpencil-full .
KI-natives Design
Vom Prompt zur UI
- Text-zu-Design — eine Seite beschreiben und sie wird in Echtzeit mit Streaming-Animation auf der Canvas generiert
- Orchestrierer — zerlegt komplexe Seiten in räumliche Teilaufgaben zur parallelen Generierung
- Design-Modifikation — Elemente auswählen und Änderungen in natürlicher Sprache beschreiben
- Bildeingabe — Screenshots oder Mockups als Referenz für referenzbasiertes Design anhängen
Multi-Agenten-Unterstützung
| Agent | Einrichtung |
|---|---|
| Claude Code | Keine Konfiguration — verwendet Claude Agent SDK mit lokalem OAuth |
| Codex CLI | In den Agenteneinstellungen verbinden (Cmd+,) |
| OpenCode | In den Agenteneinstellungen verbinden (Cmd+,) |
| GitHub Copilot | copilot login dann in den Agenteneinstellungen verbinden (Cmd+,) |
| Gemini CLI | In den Agenteneinstellungen verbinden (Cmd+,) |
Modell-Fähigkeitsprofile — passt Prompts, Thinking-Modus und Timeouts automatisch pro Modellstufe an. Modelle der Vollstufe (Claude) erhalten vollständige Prompts; Standardstufe (GPT-4o, Gemini, DeepSeek) deaktiviert Thinking; Basisstufe (MiniMax, Qwen, Llama, Mistral) erhält vereinfachte verschachtelte JSON-Prompts für maximale Zuverlässigkeit.
MCP-Server
- Eingebauter MCP-Server — Ein-Klick-Installation in Claude Code / Codex / Gemini / OpenCode / Kiro / Copilot CLIs
- Automatische Node.js-Erkennung — falls nicht installiert, automatischer Fallback auf HTTP-Transport und automatischer Start des MCP-HTTP-Servers
- Design-Automatisierung vom Terminal aus:
.op-Dateien über jeden MCP-kompatiblen Agenten lesen, erstellen und bearbeiten - Mehrstufiger Design-Workflow —
design_skeleton→design_content→design_refinefür hochwertigere mehrteilige Designs - Segmentierter Prompt-Abruf — laden Sie nur das benötigte Design-Wissen (Schema, Layout, Rollen, Icons, Planung usw.)
- Mehrseitige Unterstützung — Seiten erstellen, umbenennen, neu ordnen und duplizieren über MCP-Tools
Codegenerierung
- React + Tailwind CSS, HTML + CSS, CSS Variables
- Vue, Svelte, Flutter, SwiftUI, Jetpack Compose, React Native
CLI — op
Global installieren und das Design-Tool vom Terminal aus steuern:
npm install -g @zseven-w/openpencil
op start # Desktop-App starten
op design @landing.txt # Batch-Design aus Datei
op insert '{"type":"RECT"}' # Knoten einfügen
op export react --out . # Nach React + Tailwind exportieren
op import:figma design.fig # Figma-Datei importieren
cat design.dsl | op design - # Pipe von stdin
Unterstützt drei Eingabemethoden: Inline-String, @filepath (aus Datei lesen) oder - (von stdin lesen). Funktioniert mit der Desktop-App oder dem Web-Entwicklungsserver. Siehe CLI README für die vollständige Befehlsreferenz.
Funktionen
Canvas und Zeichnen
- Unendliche Canvas mit Pan, Zoom, intelligenten Ausrichtungshilfslinien und Einrasten
- Rechteck, Ellipse, Linie, Polygon, Stift (Bezier), Frame, Text
- Boolesche Operationen — Vereinigung, Subtraktion, Schnittmenge mit kontextbezogener Werkzeugleiste
- Icon-Auswahl (Iconify) und Bildimport (PNG/JPEG/SVG/WebP/GIF)
- Auto-Layout — vertikal/horizontal mit Gap, Padding, Justify, Align
- Mehrseitige Dokumente mit Tab-Navigation
Designsystem
- Designvariablen — Farb-, Zahl- und Text-Tokens mit
$variable-Referenzen - Multi-Theme-Unterstützung — mehrere Achsen, jeweils mit Varianten (Hell/Dunkel, Kompakt/Komfortabel)
- Komponentensystem — wiederverwendbare Komponenten mit Instanzen und Überschreibungen
- CSS-Synchronisierung — automatisch generierte benutzerdefinierte Eigenschaften,
var(--name)in der Code-Ausgabe
Figma-Import
.fig-Dateien importieren mit erhaltenem Layout, Füllungen, Konturen, Effekten, Text, Bildern und Vektoren
Desktop-App
- Natives macOS, Windows und Linux über Electron
.op-Dateizuordnung — Doppelklick zum Öffnen, Einzelinstanzsperre- Automatische Aktualisierung über GitHub Releases
- Natives Anwendungsmenü und Dateidialoge
Technologie-Stack
| Frontend | React 19 · TanStack Start · Tailwind CSS v4 · shadcn/ui |
| Canvas | CanvasKit/Skia (WASM, GPU-beschleunigt) |
| State | Zustand v5 |
| Server | Nitro |
| Desktop | Electron 35 |
| CLI | op — Terminal-Steuerung, Batch-Design-DSL, Code-Export |
| KI | Anthropic SDK · Claude Agent SDK · OpenCode SDK · Copilot SDK |
| Laufzeit | Bun · Vite 7 |
| Dateiformat | .op — JSON-basiert, menschenlesbar, Git-freundlich |
Projektstruktur
openpencil/
├── apps/
│ ├── web/ TanStack Start Web-App
│ │ ├── src/
│ │ │ ├── canvas/ CanvasKit/Skia-Engine — Zeichnen, Sync, Layout
│ │ │ ├── components/ React-UI — Editor, Panels, gemeinsame Dialoge, Icons
│ │ │ ├── services/ai/ KI-Chat, Orchestrierer, Designgenerierung, Streaming
│ │ │ ├── stores/ Zustand — Canvas, Dokument, Seiten, Verlauf, KI
│ │ │ ├── mcp/ MCP-Server-Tools für externe CLI-Integration
│ │ │ ├── hooks/ Tastaturkürzel, Datei-Drop, Figma-Paste
│ │ │ └── uikit/ Wiederverwendbares Komponenten-Kit-System
│ │ └── server/
│ │ ├── api/ai/ Nitro-API — Streaming-Chat, Generierung, Validierung
│ │ └── utils/ Claude CLI, OpenCode, Codex, Copilot-Wrapper
│ ├── desktop/ Electron-Desktop-App
│ │ ├── main.ts Fenster, Nitro-Fork, natives Menü, Auto-Updater
│ │ ├── ipc-handlers.ts Native Dateidialoge, Theme-Sync, Einstellungen-IPC
│ │ └── preload.ts IPC-Brücke
│ └── cli/ CLI-Tool — `op`-Befehl
│ ├── src/commands/ Design-, Dokument-, Export-, Import-, Knoten-, Seiten-, Variablen-Befehle
│ ├── connection.ts WebSocket-Verbindung zur laufenden App
│ └── launcher.ts Automatische Erkennung und Start der Desktop-App oder des Webservers
├── packages/
│ ├── pen-types/ Typdefinitionen für das PenDocument-Modell
│ ├── pen-core/ Dokumentbaum-Operationen, Layout-Engine, Variablen
│ ├── pen-codegen/ Codegeneratoren (React, HTML, Vue, Flutter, ...)
│ ├── pen-figma/ Figma-.fig-Datei-Parser und -Konverter
│ ├── pen-renderer/ Eigenständiger CanvasKit/Skia-Renderer
│ └── pen-sdk/ Umbrella-SDK (re-exportiert alle Pakete)
└── .githooks/ Pre-Commit-Versionssynchronisierung vom Branch-Namen
Tastaturkürzel
| Taste | Aktion | Taste | Aktion | |
|---|---|---|---|---|
V |
Auswählen | Cmd+S |
Speichern | |
R |
Rechteck | Cmd+Z |
Rückgängig | |
O |
Ellipse | Cmd+Shift+Z |
Wiederholen | |
L |
Linie | Cmd+C/X/V/D |
Kopieren/Ausschneiden/Einfügen/Duplizieren | |
T |
Text | Cmd+G |
Gruppieren | |
F |
Frame | Cmd+Shift+G |
Gruppierung aufheben | |
P |
Stiftwerkzeug | Cmd+Shift+E |
Exportieren | |
H |
Hand (Pan) | Cmd+Shift+C |
Code-Panel | |
Del |
Löschen | Cmd+Shift+V |
Variablen-Panel | |
[ / ] |
Reihenfolge ändern | Cmd+J |
KI-Chat | |
| Pfeiltasten | 1px verschieben | Cmd+, |
Agenteneinstellungen | |
Cmd+Alt+U |
Boolesche Vereinigung | Cmd+Alt+S |
Boolesche Subtraktion | |
Cmd+Alt+I |
Boolesche Schnittmenge |
Skripte
bun --bun run dev # Entwicklungsserver (Port 3000)
bun --bun run build # Produktions-Build
bun --bun run test # Tests ausführen (Vitest)
npx tsc --noEmit # Typprüfung
bun run bump <version> # Version über alle package.json synchronisieren
bun run electron:dev # Electron-Entwicklung
bun run electron:build # Electron-Paketierung
bun run cli:dev # CLI aus Quellcode ausführen
bun run cli:compile # CLI nach dist kompilieren
Mitwirken
Beiträge sind willkommen! Siehe CLAUDE.md für Architekturdetails und Code-Stil.
- Forken und klonen
- Versionssynchronisierung einrichten:
git config core.hooksPath .githooks - Branch erstellen:
git checkout -b feat/my-feature - Prüfungen ausführen:
npx tsc --noEmit && bun --bun run test - Mit Conventional Commits committen:
feat(canvas): add rotation snapping - Pull Request gegen
mainöffnen
Roadmap
- Designvariablen & Tokens mit CSS-Synchronisierung
- Komponentensystem (Instanzen & Überschreibungen)
- KI-Designgenerierung mit Orchestrierer
- MCP-Server-Integration mit mehrstufigem Design-Workflow
- Mehrseitige Unterstützung
- Figma-
.fig-Import - Boolesche Operationen (Vereinigung, Subtraktion, Schnittmenge)
- Multi-Modell-Fähigkeitsprofile
- Monorepo-Umstrukturierung mit wiederverwendbaren Paketen
- CLI-Tool (
op) für Terminal-Steuerung - Kollaboratives Bearbeiten
- Plugin-System
Mitwirkende
Community
Star History
Lizenz
MIT — Copyright (c) 2026 ZSeven-W