* 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>
17 KiB
OpenPencil
Le premier outil de design vectoriel open-source natif IA au monde.
Equipes d'agents concurrents • Design-as-Code • Serveur MCP intégré • Intelligence multi-modèles
English · 简体中文 · 繁體中文 · 日本語 · 한국어 · Français · Español · Deutsch · Português · Русский · हिन्दी · Türkçe · ไทย · Tiếng Việt · Bahasa Indonesia
Cliquez sur l'image pour regarder la vidéo de démonstration
Pourquoi OpenPencil
🎨 Prompt → CanevasDécrivez n'importe quelle interface en langage naturel. Regardez-la apparaître sur le canevas infini en temps réel avec une animation en streaming. Modifiez des designs existants en sélectionnant des éléments et en conversant. |
🤖 Équipes d'agents concurrentsL'orchestrateur décompose les pages complexes en sous-tâches spatiales. Plusieurs agents IA travaillent simultanément sur différentes sections — hero, fonctionnalités, pied de page — le tout en streaming parallèle. |
🧠 Intelligence multi-modèlesS'adapte automatiquement aux capacités de chaque modèle. Claude obtient des prompts complets avec réflexion ; GPT-4o/Gemini désactivent la réflexion ; les modèles plus petits (MiniMax, Qwen, Llama) reçoivent des prompts simplifiés pour une sortie fiable. |
🔌 Serveur MCPInstallation en un clic dans les CLI Claude Code, Codex, Gemini, OpenCode, Kiro ou Copilot. Designez depuis votre terminal — lisez, créez et modifiez des fichiers |
📦 Design-as-CodeLes fichiers |
🖥️ Fonctionne partoutApplication web + bureau natif sur macOS, Windows et Linux via Electron. Mises à jour automatiques depuis GitHub Releases. Association de fichiers |
⌨️ CLI —
|
🎯 Export de Code Multi-PlateformeExportez depuis un seul fichier |
Démarrage rapide
# Installer les dépendances
bun install
# Démarrer le serveur de développement sur http://localhost:3000
bun --bun run dev
Ou lancer en tant qu'application de bureau :
bun run electron:dev
Docker
Plusieurs variantes d'images sont disponibles — choisissez celle qui correspond à vos besoins :
| Image | Taille | Contenu |
|---|---|---|
openpencil:latest |
~226 Mo | Application web uniquement |
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 Go | Tous les outils CLI |
Exécuter (web uniquement) :
docker run -d -p 3000:3000 ghcr.io/zseven-w/openpencil:latest
Exécuter avec un CLI IA (ex. Claude Code) :
Le chat IA repose sur la connexion OAuth de Claude CLI. Utilisez un volume Docker pour conserver la session de connexion :
# Étape 1 — Connexion (une seule fois)
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
# Étape 2 — Démarrer
docker run -d -p 3000:3000 \
-v openpencil-claude-auth:/root/.claude \
ghcr.io/zseven-w/openpencil-claude:latest
Compiler localement :
# Base (web uniquement)
docker build --target base -t openpencil .
# Avec un CLI spécifique
docker build --target with-claude -t openpencil-claude .
# Complet (tous les CLIs)
docker build --target full -t openpencil-full .
Design natif IA
Du prompt à l'interface
- Texte vers design — décrivez une page, elle est générée en temps réel sur le canevas avec une animation en streaming
- Orchestrateur — décompose les pages complexes en sous-tâches spatiales pour une génération parallèle
- Modification de design — sélectionnez des éléments, puis décrivez les modifications en langage naturel
- Entrée vision — joignez des captures d'écran ou des maquettes pour un design basé sur des références
Support multi-agents
| Agent | Configuration |
|---|---|
| Claude Code | Aucune configuration — utilise le Claude Agent SDK avec OAuth local |
| Codex CLI | Connecter dans les Paramètres de l'agent (Cmd+,) |
| OpenCode | Connecter dans les Paramètres de l'agent (Cmd+,) |
| GitHub Copilot | copilot login puis connecter dans les Paramètres de l'agent (Cmd+,) |
| Gemini CLI | Connecter dans les Paramètres de l'agent (Cmd+,) |
Profils de capacités des modèles — adapte automatiquement les prompts, le mode de réflexion et les délais d'attente par niveau de modèle. Les modèles de niveau complet (Claude) reçoivent des prompts complets ; le niveau standard (GPT-4o, Gemini, DeepSeek) désactive la réflexion ; le niveau basique (MiniMax, Qwen, Llama, Mistral) reçoit des prompts JSON imbriqués simplifiés pour une fiabilité maximale.
Serveur MCP
- Serveur MCP intégré — installation en un clic dans les CLI Claude Code / Codex / Gemini / OpenCode / Kiro / Copilot
- Détection automatique de Node.js — si non installé, bascule vers le transport HTTP et démarre automatiquement le serveur MCP HTTP
- Automatisation du design depuis le terminal : lire, créer et modifier des fichiers
.opvia tout agent compatible MCP - Workflow de design en couches —
design_skeleton→design_content→design_refinepour des designs multi-sections de plus haute fidélité - Récupération segmentée des prompts — chargez uniquement les connaissances de design nécessaires (schéma, layout, rôles, icônes, planification, etc.)
- Support multi-pages — créer, renommer, réordonner et dupliquer des pages via les outils MCP
Génération de code
- React + Tailwind CSS, HTML + CSS, CSS Variables
- Vue, Svelte, Flutter, SwiftUI, Jetpack Compose, React Native
CLI — op
Installez globalement et contrôlez l'outil de design depuis votre terminal :
npm install -g @zseven-w/openpencil
op start # Lancer l'app de bureau
op design @landing.txt # Design par lots depuis un fichier
op insert '{"type":"RECT"}' # Insérer un nœud
op export react --out . # Exporter en React + Tailwind
op import:figma design.fig # Importer un fichier Figma
cat design.dsl | op design - # Pipe depuis stdin
Supporte trois méthodes d'entrée : chaîne en ligne, @filepath (lecture depuis un fichier), ou - (lecture depuis stdin). Fonctionne avec l'app de bureau ou le serveur de développement web. Voir le README du CLI pour la référence complète des commandes.
Fonctionnalités
Canevas et dessin
- Canevas infini avec panoramique, zoom, guides d'alignement intelligents et magnétisme
- Rectangle, Ellipse, Ligne, Polygone, Plume (Bézier), Frame, Texte
- Opérations booléennes — union, soustraction, intersection avec barre d'outils contextuelle
- Sélecteur d'icônes (Iconify) et import d'images (PNG/JPEG/SVG/WebP/GIF)
- Auto-layout — vertical/horizontal avec gap, padding, justify, align
- Documents multi-pages avec navigation par onglets
Système de design
- Variables de design — tokens de couleur, nombre et chaîne avec références
$variable - Support multi-thèmes — plusieurs axes, chacun avec des variantes (Clair/Sombre, Compact/Confortable)
- Système de composants — composants réutilisables avec instances et substitutions
- Synchronisation CSS — propriétés personnalisées auto-générées,
var(--name)dans la sortie de code
Import Figma
- Importer des fichiers
.figen préservant la mise en page, les remplissages, les contours, les effets, le texte, les images et les vecteurs
Application de bureau
- macOS, Windows et Linux natifs via Electron
- Association de fichiers
.op— double-cliquez pour ouvrir, verrouillage d'instance unique - Mise à jour automatique depuis GitHub Releases
- Menu d'application natif et boîtes de dialogue de fichiers
Stack technique
| Frontend | React 19 · TanStack Start · Tailwind CSS v4 · shadcn/ui |
| Canevas | CanvasKit/Skia (WASM, accélération GPU) |
| État | Zustand v5 |
| Serveur | Nitro |
| Bureau | Electron 35 |
| CLI | op — contrôle depuis le terminal, DSL de design par lots, export de code |
| IA | Anthropic SDK · Claude Agent SDK · OpenCode SDK · Copilot SDK |
| Runtime | Bun · Vite 7 |
| Format de fichier | .op — basé sur JSON, lisible par l'humain, compatible Git |
Structure du projet
openpencil/
├── apps/
│ ├── web/ Application web TanStack Start
│ │ ├── src/
│ │ │ ├── canvas/ Moteur CanvasKit/Skia — dessin, sync, mise en page
│ │ │ ├── components/ Interface React — éditeur, panneaux, boîtes de dialogue partagées, icônes
│ │ │ ├── services/ai/ Chat IA, orchestrateur, génération de design, streaming
│ │ │ ├── stores/ Zustand — canevas, document, pages, historique, IA
│ │ │ ├── mcp/ Outils serveur MCP pour l'intégration CLI externe
│ │ │ ├── hooks/ Raccourcis clavier, dépôt de fichiers, collage Figma
│ │ │ └── uikit/ Système de kits de composants réutilisables
│ │ └── server/
│ │ ├── api/ai/ API Nitro — chat en streaming, génération, validation
│ │ └── utils/ Enveloppes Claude CLI, OpenCode, Codex, Copilot
│ ├── desktop/ Application de bureau Electron
│ │ ├── main.ts Fenêtre, fork Nitro, menu natif, mise à jour automatique
│ │ ├── ipc-handlers.ts Dialogues fichiers natifs, sync thème, préférences IPC
│ │ └── preload.ts Pont IPC
│ └── cli/ Outil CLI — commande `op`
│ ├── src/commands/ Commandes design, document, export, import, nœud, page, variable
│ ├── connection.ts Connexion WebSocket à l'app en cours d'exécution
│ └── launcher.ts Détection automatique et lancement de l'app de bureau ou du serveur web
├── packages/
│ ├── pen-types/ Définitions de types pour le modèle PenDocument
│ ├── pen-core/ Opérations sur l'arbre du document, moteur de mise en page, variables
│ ├── pen-codegen/ Générateurs de code (React, HTML, Vue, Flutter, ...)
│ ├── pen-figma/ Parseur et convertisseur de fichiers Figma .fig
│ ├── pen-renderer/ Moteur de rendu CanvasKit/Skia autonome
│ └── pen-sdk/ SDK parapluie (réexporte tous les packages)
└── .githooks/ Synchronisation de version pre-commit depuis le nom de branche
Raccourcis clavier
| Touche | Action | Touche | Action | |
|---|---|---|---|---|
V |
Sélectionner | Cmd+S |
Enregistrer | |
R |
Rectangle | Cmd+Z |
Annuler | |
O |
Ellipse | Cmd+Shift+Z |
Rétablir | |
L |
Ligne | Cmd+C/X/V/D |
Copier/Couper/Coller/Dupliquer | |
T |
Texte | Cmd+G |
Grouper | |
F |
Frame | Cmd+Shift+G |
Dégrouper | |
P |
Outil plume | Cmd+Shift+E |
Exporter | |
H |
Main (panoramique) | Cmd+Shift+C |
Panneau de code | |
Del |
Supprimer | Cmd+Shift+V |
Panneau des variables | |
[ / ] |
Réordonner | Cmd+J |
Chat IA | |
| Flèches | Déplacer de 1px | Cmd+, |
Paramètres de l'agent | |
Cmd+Alt+U |
Union booléenne | Cmd+Alt+S |
Soustraction booléenne | |
Cmd+Alt+I |
Intersection booléenne |
Scripts
bun --bun run dev # Serveur de développement (port 3000)
bun --bun run build # Build de production
bun --bun run test # Lancer les tests (Vitest)
npx tsc --noEmit # Vérification des types
bun run bump <version> # Synchroniser la version dans tous les package.json
bun run electron:dev # Développement Electron
bun run electron:build # Packaging Electron
bun run cli:dev # Exécuter le CLI depuis les sources
bun run cli:compile # Compiler le CLI vers dist
Contribuer
Les contributions sont les bienvenues ! Consultez CLAUDE.md pour les détails d'architecture et le style de code.
- Forker et cloner
- Configurer la synchronisation de version :
git config core.hooksPath .githooks - Créer une branche :
git checkout -b feat/my-feature - Exécuter les vérifications :
npx tsc --noEmit && bun --bun run test - Commiter avec Conventional Commits :
feat(canvas): add rotation snapping - Ouvrir une PR contre
main
Feuille de route
- Variables de design & tokens avec synchronisation CSS
- Système de composants (instances & substitutions)
- Génération de design IA avec orchestrateur
- Intégration du serveur MCP avec workflow de design en couches
- Support multi-pages
- Import Figma
.fig - Opérations booléennes (union, soustraction, intersection)
- Profils de capacités multi-modèles
- Restructuration en monorepo avec packages réutilisables
- Outil CLI (
op) pour le contrôle depuis le terminal - Édition collaborative
- Système de plugins
Contributeurs
Communauté
Star History
Licence
MIT — Copyright (c) 2026 ZSeven-W