The `op export` command was removed in 0.7.x but the README still advertised it (#116). The pen-mcp README also documented an `npx @zseven-w/pen-mcp` quick-start that never worked because the package ships TypeScript source against workspace-only deps with no `bin` entry (#117). - Strip `op export` references from all 15 root and 15 cli READMEs - Sync AGENTS.md, CLAUDE.md, apps/cli/CLAUDE.md to match the codegen- pipeline reality (no standalone export command anymore) - Rewrite pen-mcp README's quick-start: explain the package ships as part of the OpenPencil app and external clients connect over HTTP Closes #116 Closes #117
25 KiB
OpenPencil
世界初のオープンソース AI ネイティブベクターデザインツール。
並行エージェントチーム • Design-as-Code • 内蔵 MCP サーバー • マルチモデルインテリジェンス
English · 简体中文 · 繁體中文 · 日本語 · 한국어 · Français · Español · Deutsch · Português · Русский · हिन्दी · Türkçe · ไทย · Tiếng Việt · Bahasa Indonesia
画像をクリックしてデモ動画を視聴
注: 同名の別のオープンソースプロジェクト — OpenPencil があります。そちらは Figma 互換のビジュアルデザインとリアルタイムコラボレーションに特化しています。本プロジェクトは AI ネイティブのデザインからコードへのワークフローに特化しています。
Why OpenPencil
🎨 プロンプト → キャンバス自然言語で任意の UI を記述。ストリーミングアニメーションでリアルタイムに無限キャンバス上に表示。要素を選択してチャットすることで既存のデザインを修正。 |
🤖 並行エージェントチームオーケストレーターが複雑なページを空間的なサブタスクに分解。複数の AI エージェントがヒーロー、機能紹介、フッターなど異なるセクションを同時に処理し、すべてが並列でストリーミング。 |
🧠 マルチモデルインテリジェンス各モデルの能力に自動適応。Claude にはシンキング付きフルプロンプト、GPT-4o/Gemini ではシンキングを無効化、小規模モデル(MiniMax、Qwen、Llama)には信頼性の高い出力のために簡略化プロンプトを使用。 |
🔌 MCP サーバーClaude Code、Codex、Gemini、OpenCode、Kiro、Copilot CLI にワンクリックでインストール。ターミナルからデザイン — MCP 対応エージェントを通じて |
📦 Design-as-Code
|
🖥️ どこでも動作Web アプリ + Electron による macOS・Windows・Linux ネイティブデスクトップ。GitHub Releases からの自動アップデート。 |
⌨️ CLI —
|
🎯 マルチプラットフォームコードエクスポート1つの |
クイックスタート
# 依存関係をインストール
bun install
# http://localhost:3000 で開発サーバーを起動
bun --bun run dev
またはデスクトップアプリとして実行:
bun run electron:dev
Docker
複数のイメージバリアントが利用可能です — ニーズに合ったものを選択してください:
| イメージ | サイズ | 含まれるもの |
|---|---|---|
openpencil:latest |
~226 MB | Web アプリのみ |
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 | すべての CLI ツール |
実行(Web のみ):
docker run -d -p 3000:3000 ghcr.io/zseven-w/openpencil:latest
AI CLI 付きで実行(例:Claude Code):
AI チャットは Claude CLI OAuth ログインに依存しています。Docker ボリュームを使用してログインセッションを永続化してください:
# ステップ 1 — ログイン(初回のみ)
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
# ステップ 2 — 起動
docker run -d -p 3000:3000 \
-v openpencil-claude-auth:/root/.claude \
ghcr.io/zseven-w/openpencil-claude:latest
ローカルビルド:
# ベース(Web のみ)
docker build --target base -t openpencil .
# 特定の CLI 付き
docker build --target with-claude -t openpencil-claude .
# フル(すべての CLI)
docker build --target full -t openpencil-full .
AI ネイティブデザイン
プロンプトから UI へ
- テキストからデザインへ — ページを説明すると、ストリーミングアニメーションでリアルタイムにキャンバス上に生成
- オーケストレーター — 複雑なページを空間サブタスクに分解し、並列生成をサポート
- デザイン修正 — 要素を選択し、自然言語で変更内容を記述
- ビジョン入力 — スクリーンショットやモックアップを参照として添付してデザイン
マルチエージェントサポート
| エージェント | 設定方法 |
|---|---|
| ビルトイン(9+ プロバイダー) | プロバイダープリセットから選択し、リージョンを切り替え — Anthropic、OpenAI、Google、DeepSeek など |
| Claude Code | 設定不要 — ローカル OAuth で Claude Agent SDK を使用 |
| Codex CLI | エージェント設定で接続(Cmd+,) |
| OpenCode | エージェント設定で接続(Cmd+,) |
| GitHub Copilot | copilot login 後、エージェント設定で接続(Cmd+,) |
| Gemini CLI | エージェント設定で接続(Cmd+,) |
モデル能力プロファイル — モデルの階層に応じてプロンプト、シンキングモード、タイムアウトを自動適応。フル階層モデル(Claude)には完全なプロンプト、標準階層(GPT-4o、Gemini、DeepSeek)ではシンキングを無効化、ベーシック階層(MiniMax、Qwen、Llama、Mistral)には最大限の信頼性のために簡略化されたネスト JSON プロンプトを使用。
i18n — 15言語での完全なインターフェースローカライゼーション:English、简体中文、繁體中文、日本語、한국어、Français、Español、Deutsch、Português、Русский、हिन्दी、Türkçe、ไทย、Tiếng Việt、Bahasa Indonesia。
MCP サーバー
- 内蔵 MCP サーバー — Claude Code / Codex / Gemini / OpenCode / Kiro / Copilot CLI にワンクリックでインストール
- Node.js を自動検出 — 未インストールの場合は HTTP トランスポートに自動フォールバックし、MCP HTTP サーバーを自動起動
- ターミナルからのデザイン自動化:MCP 対応エージェントを通じて
.opファイルの読み取り、作成、編集が可能 - レイヤードデザインワークフロー —
design_skeleton→design_content→design_refineによる高忠実度マルチセクションデザイン - セグメント化プロンプト取得 — 必要なデザイン知識のみをロード(schema、layout、roles、icons、planning など)
- マルチページサポート — MCP ツールを通じてページの作成、名前変更、並べ替え、複製が可能
コード生成
- React + Tailwind CSS、HTML + CSS、CSS Variables
- Vue、Svelte、Flutter、SwiftUI、Jetpack Compose、React Native
CLI — op
グローバルインストールしてターミナルからデザインツールを操作:
npm install -g @zseven-w/openpencil
op start # デスクトップアプリを起動
op design @landing.txt # ファイルからバッチデザイン
op insert '{"type":"RECT"}' # ノードを挿入
op import:figma design.fig # Figma ファイルをインポート
cat design.dsl | op design - # stdin からパイプ入力
3つの入力方法に対応:インライン文字列、@filepath(ファイルから読み込み)、-(stdin から読み込み)。デスクトップアプリまたは Web 開発サーバーと連携。完全なコマンドリファレンスは CLI README を参照。
LLM スキル — OpenPencil Skill プラグインをインストールすると、AIエージェント(Claude Code、Cursor、Codex、Gemini CLI など)に op を使ったデザインを教えられます。
機能
キャンバスと描画
- パン、ズーム、スマートアライメントガイド、スナッピング対応の無限キャンバス
- 矩形、楕円、直線、多角形、ペン(ベジェ)、Frame、テキスト
- ブーリアン演算 — 合体、型抜き、交差(コンテキストツールバー付き)
- アイコンピッカー(Iconify)と画像インポート(PNG/JPEG/SVG/WebP/GIF)
- オートレイアウト — 垂直/水平方向、ギャップ・パディング・justify・align 対応
- タブナビゲーション付きマルチページドキュメント
デザインシステム
- デザイン変数 — カラー・数値・文字列トークン、
$variable参照付き - マルチテーマサポート — 複数のテーマ軸、各軸に複数バリアント(Light/Dark、Compact/Comfortable)
- コンポーネントシステム — インスタンスとオーバーライドを持つ再利用可能なコンポーネント
- CSS 同期 — カスタムプロパティの自動生成、コード出力に
var(--name)を使用 - 再利用可能な UIKit —
.penファイルからコンポーネントキットをインポート/エクスポート
AI とエージェント
- ストリーミング生成とオーケストレーター駆動の空間分解によるプロンプトからキャンバスへの変換
- 並行エージェントチーム — 複数のデザイナーが異なるセクションを並列で処理し、各メンバーにキャンバスインジケーター
- レイヤードワークフロー —
design_skeleton→design_content→design_refine、各フェーズごとに焦点を絞ったプロンプト - スタイルガイド — 50+ のビルトインスタイル(glassmorphism、brutalist、retro など)、タグベースのファジーマッチング対応、プランニングと生成に統合
- マルチモデル能力プロファイル — モデル階層に応じてシンキングモード、エフォート、プロンプト形状を自動適応
- ビルトインエージェントランタイム(
agent-native、Zig NAPI)+ Anthropic、Claude Agent SDK、OpenCode、Codex、Copilot、Gemini プロバイダー - 中国系 LLM プロバイダー向け Anthropic フォーマットパススルー — Kimi、Zhipu、GLM、DouBao、Ark、Bailian/DashScope、ModelScope、Coding Plans
Git 統合
- SSH / HTTPS 認証と SSH キー管理を備えたクローンウィザード
- ブランチピッカー — 作成、切り替え、削除、マージをすべて Git パネルから
- プル / プッシュカスケード — 認証リトライとノンファストフォワード処理対応
- フォルダーモード三方向マージ — ディスク上の
MERGE_HEAD状態追跡付き - コンフリクトパネル — ノード/フィールド単位の三方向カード、インライン JSON エディター、一括操作、インライン diff ブロック
- リモート設定と SSH キー UI、Git サーフェス全体にわたる 15 ロケール i18n
エクスポート
- キャンバスエクスポート — PNG、JPEG、WEBP、PDF(
Cmd+Shift+P) - コードエクスポート — React + Tailwind、HTML + CSS、Vue、Svelte、Flutter、SwiftUI、Jetpack Compose、React Native
- インクリメンタル MCP コード生成パイプライン —
codegen_plan、codegen_submit_chunk、codegen_assemble、codegen_clean
Figma インポート
- レイアウト、フィル、ストローク、エフェクト、テキスト、画像、ベクターを保持して
.figファイルをインポート
デスクトップアプリ
- Electron によるネイティブ macOS・Windows・Linux 対応
.opファイル関連付け — ダブルクリックで開く、シングルインスタンスロック- GitHub Releases からの自動アップデート
- 名前を付けて保存、最近使った項目を開く、および終了時の未保存変更ダイアログを備えたネイティブアプリケーションメニュー
- 最近使ったファイルの永続化
技術スタック
| フロントエンド | React 19 · TanStack Start · Tailwind CSS v4 · shadcn/ui · i18next |
| キャンバス | CanvasKit/Skia(WASM、GPU アクセラレーション) |
| 状態管理 | Zustand v5 |
| サーバー | Nitro |
| デスクトップ | Electron 35 |
| CLI | op — ターミナル制御、バッチデザインDSL |
| AI | Vercel AI SDK v6 · Anthropic SDK · Claude Agent SDK · OpenCode SDK · Copilot SDK |
| ランタイム | Bun · Vite 7 |
| ファイル形式 | .op — JSON ベース、人間が読みやすく、Git フレンドリー |
プロジェクト構成
openpencil/
├── apps/
│ ├── web/ TanStack Start Web アプリ
│ │ ├── src/
│ │ │ ├── canvas/ CanvasKit/Skia エンジン — 描画、同期、レイアウト
│ │ │ ├── components/ React UI — エディター、パネル、共有ダイアログ、アイコン
│ │ │ ├── services/ai/ AI チャット、オーケストレーター、デザイン生成、ストリーミング
│ │ │ ├── stores/ Zustand — キャンバス、ドキュメント、ページ、履歴、AI
│ │ │ ├── mcp/ 外部 CLI 統合用 MCP サーバーツール
│ │ │ ├── hooks/ キーボードショートカット、ファイルドロップ、Figma ペースト
│ │ │ └── uikit/ 再利用可能なコンポーネントキットシステム
│ │ └── server/
│ │ ├── api/ai/ Nitro API — ストリーミングチャット、生成、バリデーション
│ │ └── utils/ Claude CLI、OpenCode、Codex、Copilot ラッパー
│ ├── desktop/ Electron デスクトップアプリ
│ │ ├── main.ts ウィンドウ、Nitro フォーク、ネイティブメニュー、自動アップデーター
│ │ ├── ipc-handlers.ts ネイティブファイルダイアログ、テーマ同期、設定 IPC
│ │ └── preload.ts IPC ブリッジ
│ └── cli/ CLIツール — `op` コマンド
│ ├── src/commands/ デザイン、ドキュメント、エクスポート、インポート、ノード、ページ、変数コマンド
│ ├── connection.ts 実行中アプリへのWebSocket接続
│ └── launcher.ts デスクトップアプリまたはWebサーバーの自動検出・起動
├── packages/
│ ├── pen-types/ PenDocument モデルの型定義
│ ├── pen-core/ ドキュメントツリー操作、レイアウトエンジン、変数
│ ├── pen-codegen/ コードジェネレーター(React、HTML、Vue、Flutter、...)
│ ├── pen-figma/ Figma .fig ファイルパーサーとコンバーター
│ ├── pen-renderer/ スタンドアロン CanvasKit/Skia レンダラー
│ ├── pen-sdk/ アンブレラ SDK(全パッケージの再エクスポート)
│ ├── pen-ai-skills/ AI プロンプトスキルエンジン(フェーズ駆動プロンプト読込)
│ └── agent/ AI エージェント SDK(Vercel AI SDK、マルチプロバイダー、エージェントチーム)
└── .githooks/ ブランチ名からのプレコミットバージョン同期
キーボードショートカット
| キー | 操作 | キー | 操作 | |
|---|---|---|---|---|
V |
選択 | Cmd+S |
保存 | |
R |
矩形 | Cmd+Z |
元に戻す | |
O |
楕円 | Cmd+Shift+Z |
やり直す | |
L |
直線 | Cmd+C/X/V/D |
コピー/カット/ペースト/複製 | |
T |
テキスト | Cmd+G |
グループ化 | |
F |
Frame | Cmd+Shift+G |
グループ解除 | |
P |
ペンツール | Cmd+Shift+P |
エクスポート (PNG/JPG/WEBP/PDF) | |
H |
ハンド(パン) | Cmd+Shift+C |
コードパネル | |
Del |
削除 | Cmd+Shift+V |
変数パネル | |
[ / ] |
重ね順の変更 | Cmd+J |
AI チャット | |
| 矢印キー | 1px 微調整 | Cmd+, |
エージェント設定 | |
Cmd+Alt+U |
ブーリアン合体 | Cmd+Alt+S |
ブーリアン型抜き | |
Cmd+Alt+I |
ブーリアン交差 | Cmd+Shift+S |
名前を付けて保存 |
スクリプト
bun --bun run dev # 開発サーバー(ポート 3000)
bun --bun run build # 本番ビルド
bun --bun run test # テストの実行(Vitest)
npx tsc --noEmit # 型チェック
bun run bump <version> # すべての package.json のバージョンを同期
bun run electron:dev # Electron 開発モード
bun run electron:build # Electron パッケージング
bun run cli:dev # ソースから CLI を実行
bun run cli:compile # CLI を dist にコンパイル
コントリビュート
コントリビューションを歓迎します!アーキテクチャの詳細とコードスタイルについては CLAUDE.md をご覧ください。
- フォークしてクローン
- バージョン同期を設定:
git config core.hooksPath .githooks - ブランチを作成:
git checkout -b feat/my-feature - チェックを実行:
npx tsc --noEmit && bun --bun run test - Conventional Commits 形式でコミット:
feat(canvas): add rotation snapping mainブランチに PR を作成
ロードマップ
- CSS 同期付きデザイン変数とトークン
- コンポーネントシステム(インスタンスとオーバーライド)
- オーケストレーター付き AI デザイン生成
- レイヤードデザインワークフロー付き MCP サーバー統合
- マルチページサポート
- Figma
.figインポート - ブーリアン演算(合体、型抜き、交差)
- マルチモデル能力プロファイル
- 再利用可能なパッケージによるモノレポ構成
- CLIツール(
op)ターミナル制御 - ビルトイン AI エージェント SDK(マルチプロバイダー対応)
- i18n — 15言語対応
- Git 統合(クローン、ブランチ、プッシュ/プル、フォルダーモード三方向マージ)
- キャンバスのラスターエクスポート(PNG / JPEG / WEBP / PDF)
- 共同編集
- プラグインシステム
コントリビューター
スポンサー
OpenPencil は無料でオープンソースです。開発は、これを便利だと感じてくださる皆さんの支援で成り立っています — キャンバスを開いたままにしてくれてありがとう。
MrQyun さん、ありがとうございます — あなたの名前もここに並べませんか?スポンサーになる →
コミュニティ
Star History
ライセンス
MIT — Copyright (c) 2026 ZSeven-W