* chore(ai): update dependencies and enhance logging functionality - Bump version of `@github/copilot-sdk` and related packages to `0.1.32` and `1.0.7` for improved features and bug fixes. - Update Discord invite links across multiple README files to the new server. - Introduce a new logging utility in `server/utils/server-logger.ts` for better server process logging, including automatic log cleanup and directory management. - Enhance the `connect-agent.ts` and `install-agent.ts` files to improve OpenCode binary resolution and installation commands. - Refactor `resolve-claude-cli.ts` and `resolve-copilot-cli.ts` to include detailed logging for CLI binary resolution processes. This update improves dependency management, enhances user experience with updated links, and provides better insights into server operations through logging. * chore: bump version from 0.4.0 to 0.4.3 in package.json
18 KiB
OpenPencil
เครื่องมือออกแบบเวกเตอร์โอเพนซอร์สที่ขับเคลื่อนด้วย AI ตัวแรกของโลก
ทีม Agent ทำงานพร้อมกัน • Design-as-Code • MCP Server ในตัว • ปัญญาหลายโมเดล
English · 简体中文 · 繁體中文 · 日本語 · 한국어 · Français · Español · Deutsch · Português · Русский · हिन्दी · Türkçe · ไทย · Tiếng Việt · Bahasa Indonesia
คลิกที่รูปภาพเพื่อดูวิดีโอสาธิต
ทำไมต้อง OpenPencil
🎨 Prompt → Canvasอธิบาย UI ใดก็ได้ด้วยภาษาธรรมชาติ ดูมันปรากฏบน Canvas ไม่จำกัดขนาดแบบเรียลไทม์พร้อม animation แบบ streaming แก้ไขดีไซน์ที่มีอยู่โดยเลือกองค์ประกอบแล้วพิมพ์สนทนา |
🤖 ทีม Agent ทำงานพร้อมกันOrchestrator แบ่งหน้าที่ซับซ้อนออกเป็น sub-task เชิงพื้นที่ AI agent หลายตัวทำงานในส่วนต่าง ๆ พร้อมกัน — hero, features, footer — ทั้งหมด streaming แบบขนาน |
🧠 ปัญญาหลายโมเดลปรับตัวตามความสามารถของแต่ละโมเดลโดยอัตโนมัติ Claude ได้ prompt เต็มรูปแบบพร้อม thinking; GPT-4o/Gemini ปิด thinking; โมเดลขนาดเล็ก (MiniMax, Qwen, Llama) ได้ prompt แบบย่อเพื่อผลลัพธ์ที่เสถียร |
🔌 MCP Serverติดตั้งได้ด้วยคลิกเดียวใน Claude Code, Codex, Gemini, OpenCode, Kiro หรือ Copilot CLIs ออกแบบจาก terminal ของคุณ — อ่าน สร้าง และแก้ไขไฟล์ |
📦 Design-as-Codeไฟล์ |
🖥️ ใช้งานได้ทุกที่เว็บแอป + เดสก์ท็อปแบบ native บน macOS, Windows และ Linux ผ่าน Electron อัปเดตอัตโนมัติจาก GitHub Releases เชื่อมโยงไฟล์ |
เริ่มต้นอย่างรวดเร็ว
# ติดตั้ง dependencies
bun install
# เริ่ม dev server ที่ http://localhost:3000
bun --bun run dev
หรือรันเป็นแอปพลิเคชัน Desktop:
bun run electron:dev
การติดตั้งด้วย Docker
มี image หลายรูปแบบให้เลือก — เลือกแบบที่เหมาะกับความต้องการของคุณ:
| Image | ขนาด | รวม |
|---|---|---|
openpencil:latest |
~226 MB | เว็บแอปเท่านั้น |
openpencil-claude:latest |
— | + Claude Code CLI |
openpencil-codex:latest |
— | + Codex CLI |
openpencil-opencode:latest |
— | + OpenCode CLI |
openpencil-copilot:latest |
— | + GitHub Copilot CLI |
openpencil-full:latest |
~1 GB | เครื่องมือ CLI ทั้งหมด |
รัน (เว็บเท่านั้น):
docker run -d -p 3000:3000 ghcr.io/zseven-w/openpencil:latest
รันพร้อม AI CLI (เช่น Claude Code):
AI chat ต้องใช้การเข้าสู่ระบบ OAuth ของ Claude CLI ใช้ Docker volume เพื่อเก็บรักษา session การเข้าสู่ระบบ:
# ขั้นตอนที่ 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
Build ในเครื่อง:
# พื้นฐาน (เว็บเท่านั้น)
docker build --target base -t openpencil .
# พร้อม CLI เฉพาะตัว
docker build --target with-claude -t openpencil-claude .
# เต็มรูปแบบ (CLI ทั้งหมด)
docker build --target full -t openpencil-full .
การออกแบบที่ขับเคลื่อนด้วย AI
จาก Prompt สู่ UI
- ข้อความเป็นดีไซน์ — อธิบายหน้า แล้วสร้างขึ้นบน Canvas แบบเรียลไทม์พร้อม animation แบบ streaming
- Orchestrator — แบ่งหน้าที่ซับซ้อนออกเป็น sub-task เชิงพื้นที่เพื่อการสร้างแบบขนาน
- การแก้ไขดีไซน์ — เลือกองค์ประกอบ แล้วอธิบายการเปลี่ยนแปลงด้วยภาษาธรรมชาติ
- Vision input — แนบ screenshot หรือ mockup เพื่อใช้เป็นข้อมูลอ้างอิงในการออกแบบ
รองรับหลาย Agent
| Agent | วิธีตั้งค่า |
|---|---|
| Claude Code | ไม่ต้องตั้งค่า — ใช้ Claude Agent SDK พร้อม local OAuth |
| Codex CLI | เชื่อมต่อใน Agent Settings (Cmd+,) |
| OpenCode | เชื่อมต่อใน Agent Settings (Cmd+,) |
| GitHub Copilot | copilot login จากนั้นเชื่อมต่อใน Agent Settings (Cmd+,) |
โปรไฟล์ความสามารถของโมเดล — ปรับ prompt, โหมด thinking และ timeout ตามระดับโมเดลโดยอัตโนมัติ โมเดลระดับเต็ม (Claude) ได้ prompt ครบถ้วน; โมเดลระดับมาตรฐาน (GPT-4o, Gemini, DeepSeek) ปิด thinking; โมเดลระดับพื้นฐาน (MiniMax, Qwen, Llama, Mistral) ได้ prompt แบบ nested-JSON ที่ย่อลงเพื่อความเสถียรสูงสุด
MCP Server
- MCP Server ในตัว — ติดตั้งได้ด้วยคลิกเดียวใน Claude Code / Codex / Gemini / OpenCode / Kiro / Copilot CLIs
- ตรวจจับ Node.js อัตโนมัติ — หากไม่ได้ติดตั้ง จะสำรองไปใช้ HTTP transport โดยอัตโนมัติและเริ่ม MCP HTTP เซิร์ฟเวอร์
- การทำ Design Automation จาก Terminal: อ่าน สร้าง และแก้ไขไฟล์
.opผ่าน agent ที่รองรับ MCP - Layered design workflow —
design_skeleton→design_content→design_refineสำหรับดีไซน์หลายส่วนที่มีความละเอียดสูงขึ้น - Segmented prompt retrieval — โหลดเฉพาะความรู้ด้านดีไซน์ที่ต้องการ (schema, layout, roles, icons, planning ฯลฯ)
- รองรับหลายหน้า — สร้าง เปลี่ยนชื่อ เรียงลำดับ และทำซ้ำหน้าผ่าน MCP tools
การสร้างโค้ด
- React + Tailwind CSS, HTML + CSS, CSS Variables
- Vue, Svelte, Flutter, SwiftUI, Jetpack Compose, React Native
ฟีเจอร์
Canvas และการวาด
- Canvas ไม่จำกัดขนาดพร้อม pan, zoom, smart alignment guides และ snapping
- Rectangle, Ellipse, Line, Polygon, Pen (Bezier), Frame, Text
- การดำเนินการบูลีน — รวม ลบ ตัดกัน พร้อมแถบเครื่องมือตามบริบท
- ตัวเลือก Icon (Iconify) และนำเข้ารูปภาพ (PNG/JPEG/SVG/WebP/GIF)
- Auto-layout — แนวตั้ง/แนวนอนพร้อม gap, padding, justify, align
- เอกสารหลายหน้าพร้อมการนำทางด้วย tab
Design System
- Design variables — color, number, string tokens พร้อมการอ้างอิง
$variable - รองรับหลาย theme — หลาย axis แต่ละ axis มี variants (Light/Dark, Compact/Comfortable)
- ระบบ Component — component ที่นำกลับมาใช้ใหม่ได้พร้อม instance และ override
- CSS sync — สร้าง custom properties อัตโนมัติ,
var(--name)ในผลลัพธ์โค้ด
นำเข้าจาก Figma
- นำเข้าไฟล์
.figโดยคงไว้ซึ่ง layout, fills, strokes, effects, text, images และ vectors
Desktop App
- รองรับ macOS, Windows และ Linux แบบ native ผ่าน Electron
- เชื่อมโยงไฟล์
.op— ดับเบิลคลิกเพื่อเปิด, single-instance lock - อัปเดตอัตโนมัติจาก GitHub Releases
- เมนูแอปพลิเคชันและ file dialog แบบ native
Tech Stack
| Frontend | React 19 · TanStack Start · Tailwind CSS v4 · shadcn/ui |
| Canvas | CanvasKit/Skia (WASM, GPU-accelerated) |
| State | Zustand v5 |
| Server | Nitro |
| Desktop | Electron 35 |
| AI | Anthropic SDK · Claude Agent SDK · OpenCode SDK · Copilot SDK |
| Runtime | Bun · Vite 7 |
| รูปแบบไฟล์ | .op — ใช้ JSON, อ่านได้โดยมนุษย์, Git-friendly |
โครงสร้างโปรเจกต์
src/
canvas/ CanvasKit/Skia engine — การวาด, sync, layout, guides, pen tool
components/ React UI — editor, panels, shared dialogs, icons
services/ai/ AI chat, orchestrator, การสร้างดีไซน์, streaming
services/figma/ Figma .fig binary import pipeline
services/codegen React+Tailwind และ HTML+CSS code generators
stores/ Zustand — canvas, document, pages, history, AI, settings
variables/ การแก้ไข design token และการจัดการ reference
mcp/ MCP server tools สำหรับการเชื่อมต่อ CLI ภายนอก
uikit/ ระบบ component kit ที่นำกลับมาใช้ใหม่ได้
server/
api/ai/ Nitro API — streaming chat, generation, validation
utils/ Claude CLI, OpenCode, Codex, Copilot client wrappers
electron/
main.ts Window, Nitro fork, native menu, auto-updater
preload.ts IPC bridge
คีย์ลัด
| คีย์ | การทำงาน | คีย์ | การทำงาน | |
|---|---|---|---|---|
V |
เลือก | Cmd+S |
บันทึก | |
R |
Rectangle | Cmd+Z |
เลิกทำ | |
O |
Ellipse | Cmd+Shift+Z |
ทำซ้ำ | |
L |
Line | Cmd+C/X/V/D |
คัดลอก/ตัด/วาง/ทำซ้ำ | |
T |
Text | Cmd+G |
จัดกลุ่ม | |
F |
Frame | Cmd+Shift+G |
ยกเลิกการจัดกลุ่ม | |
P |
Pen tool | Cmd+Shift+E |
ส่งออก | |
H |
Hand (pan) | Cmd+Shift+C |
Code panel | |
Del |
ลบ | Cmd+Shift+V |
Variables panel | |
[ / ] |
เรียงลำดับ | Cmd+J |
AI chat | |
| ลูกศร | เลื่อน 1px | Cmd+, |
Agent settings | |
Cmd+Alt+U |
รวมบูลีน | Cmd+Alt+S |
ลบบูลีน | |
Cmd+Alt+I |
ตัดกันบูลีน |
Scripts
bun --bun run dev # Dev server (port 3000)
bun --bun run build # Production build
bun --bun run test # รันการทดสอบ (Vitest)
npx tsc --noEmit # ตรวจสอบ type
bun run electron:dev # Electron dev
bun run electron:build # Electron package
การมีส่วนร่วม
ยินดีต้อนรับการมีส่วนร่วมทุกรูปแบบ! ดู CLAUDE.md สำหรับรายละเอียดสถาปัตยกรรมและรูปแบบโค้ด
- Fork และ clone
- สร้าง branch:
git checkout -b feat/my-feature - รันการตรวจสอบ:
npx tsc --noEmit && bun --bun run test - Commit ด้วย Conventional Commits:
feat(canvas): add rotation snapping - เปิด PR เข้า
main
Roadmap
- Design variables และ tokens พร้อม CSS sync
- ระบบ Component (instances และ overrides)
- การสร้างดีไซน์ด้วย AI พร้อม orchestrator
- การเชื่อมต่อ MCP server พร้อม layered design workflow
- รองรับหลายหน้า
- นำเข้า Figma
.fig - Boolean operations (union, subtract, intersect)
- โปรไฟล์ความสามารถหลายโมเดล
- การแก้ไขร่วมกัน
- ระบบปลั๊กอิน
ผู้มีส่วนร่วม
ชุมชน
Star History
สัญญาอนุญาต
MIT — Copyright (c) 2026 ZSeven-W