agent-canvas
npx skills add https://github.com/whq25/agent-canvas --skill agent-canvas
Agent 安装分布
Skill 文档
Agent Canvas
A CLI tool to interact with an Excalidraw canvas for creating diagrams and visualizations.
Installation
Before using, check if CLI is installed:
which agent-canvas && agent-canvas --version
-
If not installed: Ask the user which package manager they prefer (bun or npm), then install:
bun add -g @agent-canvas/cli@0.11.0 # or npm install -g @agent-canvas/cli@0.11.0 -
If installed but version differs from 0.11.0: Upgrade using the same package manager:
- Path contains
.bunâbun add -g @agent-canvas/cli@0.11.0 - Otherwise â
npm install -g @agent-canvas/cli@0.11.0
- Path contains
-
After install/upgrade: Verify with
agent-canvas --versionto confirm version is 0.11.0
Quick Start
-
Start the canvas (opens in browser):
agent-canvas start -
Use CLI commands to draw on the canvas.
Commands Reference
Start Canvas
agent-canvas start # Start server and open browser
Load File
agent-canvas load file.excalidraw # Load .excalidraw file into current canvas
When loading from file: Remember the file path and save back to it with agent-canvas save <original-file>.
Canvas Management
The canvas supports multiple canvases. Each canvas is stored independently and can be switched between.
agent-canvas list # List all canvases (* marks active)
agent-canvas new -n "Name" [--use] # Create new canvas, optionally switch to it
agent-canvas use "Name" # Switch to canvas by name
agent-canvas rename "New Name" # Rename current canvas
Notes:
- Canvas names are case-insensitive and must be unique
- Delete canvases via UI (hover over canvas in sidebar, click “…” menu)
- Each canvas has its own scene data; switching automatically saves current canvas
Add Text
agent-canvas add-text -t "<text>" --ax <x> --ay <y> [options]
-
Options:
--font-size <size>,--text-align <left|center|right>,-a/--anchor <anchor>,--stroke-color <hex>,-n/--note <text> -
Font sizes: S=16, M=20 (default), L=28, XL=36
-
Anchor (
-a): Since text size is unknown until rendered, anchor gives you precise positioning control by specifying which point of the text bounding box aligns to (–ax, –ay). Default:bottomLeft.Anchor Common Text Types topLeftBadge, Tag, Icon label topCenterSubtitle, Description below shape topRightTimestamp, Version, Status leftCenterSide annotation (right of shape) centerCentered title, Main label rightCenterSide annotation (left of shape) bottomLeftFootnote, Note bottomCenterTitle, Header above shape bottomRightFootnote, Signature -
Returns:
Text created (id: <id>, x: <x>, y: <y>, <width>x<height>)â actual top-left position and dimensions for precise layout
Add Drawing Elements
All drawing commands share common style options:
- Stroke:
--stroke-color <hex>(default: #1e1e1e),--stroke-width <1-4>(default: 2),--stroke-style <solid|dashed|dotted>(default: solid) - Fill (shapes only):
--background-color <hex>(default: transparent),--fill-style <solid|hachure|cross-hatch>(default: solid) - Meta:
-n/--note <text>– semantic description for the element. Use liberally – notes help understand diagram intent when reading back later. - Animated:
--animated– auto-scroll viewport to show the newly added element. Small elements zoom in, large elements zoom out, normal elements scroll minimally.
Recommended Colors (from Excalidraw palette):
| Color | Stroke (dark) | Background (light) |
|---|---|---|
| Red | #e03131 | #ffc9c9 |
| Blue | #1971c2 | #a5d8ff |
| Green | #2f9e44 | #b2f2bb |
| Yellow | #f08c00 | #ffec99 |
| Cyan | #0c8599 | #99e9f2 |
| Violet | #6741d9 | #b197fc |
| Gray | #495057 | #dee2e6 |
Shapes
agent-canvas add-shape -t <type> -x <x> -y <y> [-w <width>] [-h <height>] [-l <label>]
- Types:
rectangle,ellipse,diamond - Use
-l/--labelto add text inside the shape (fontSize: 16 by default),--label-font-size <n>to adjust - Label color inherits from
--stroke-colorby default; use--label-stroke-color <hex>to override - Returns:
Shape created (id: <id> x=<x> y=<y> w=<width> h=<height>)â actual dimensions after auto-sizing for labels
â ï¸ Label Sizing – CRITICAL: Calculate BEFORE drawing
If shape size is too small, Excalidraw auto-expands, breaking arrow coordinates. You MUST:
- Calculate minimum dimensions using the formulas below
- Use the calculated values directly â NEVER estimate or use smaller values
Step 1: Calculate text dimensions (fontSize=16 by default)
textWidth = charCount à fontSize à 0.6 (English/numbers)
textWidth = charCount à fontSize (CJK characters)
textHeight = lineCount à fontSize à 1.35
Step 2: Calculate minimum shape size (use these values, not smaller!)
rectangle: width = textWidth + 50, height = textHeight + 50
ellipse: width = textWidth à 1.42 + 55, height = textHeight à 1.42 + 55
diamond: width = textWidth à 2 + 60, height = textHeight à 2 + 60
Example: Label “Message Queue” (13 chars) in ellipse
textWidth = 13 Ã 16 Ã 0.6 = 124.8
textHeight = 1 Ã 16 Ã 1.35 = 21.6
ellipse width = 124.8 Ã 1.42 + 55 = 232
ellipse height = 21.6 Ã 1.42 + 55 = 86
â Use: -w 232 -h 86 (or round up to -w 240 -h 90)
Tip: For long labels, insert \n manually, then recalculate with updated lineCount.
Lines & Arrows
agent-canvas add-line -x <x1> -y <y1> --end-x <x2> --end-y <y2>
agent-canvas add-arrow -x <x1> -y <y1> --end-x <x2> --end-y <y2>
- Arrow-specific:
--start-arrowhead,--end-arrowhead(arrow, bar, dot, triangle, diamond, none)
Arrow Types (--arrow-type):
| Type | Description | Use Case |
|---|---|---|
sharp |
Straight line (default) | Direct connections |
round |
Curved line with control point | Organic flows, avoiding overlaps |
elbow |
Right-angle turns (90°) | Flowcharts, circuit diagrams |
Intermediate Points (--via):
Use --via to specify intermediate points as absolute coordinates in format "x1,y1;x2,y2;...":
# Round arrow: one control point determines curve direction
# Vertical arrow curving left (control point at x=50, left of the line)
agent-canvas add-arrow -x 100 -y 100 --end-x 100 --end-y 300 --arrow-type round --via "50,200"
# Elbow arrow: multiple points for 90° turns
# Loop back pattern: down â left â up (for flowchart iterations)
agent-canvas add-arrow -x 175 -y 520 --end-x 175 --end-y 280 --arrow-type elbow --via "120,520;120,280"
Tips:
- For
round: curve bends toward the control point (offset from straight path) - For
elbow: points define the corners of the 90° path
Polygon
agent-canvas add-polygon -p '[{"x":0,"y":0},{"x":100,"y":0},{"x":50,"y":100}]'
Image
agent-canvas add-image -f <path> -x <x> -y <y> [-w <width>] [-h <height>] [-n <note>]
- Supported formats: PNG, JPEG, GIF, SVG, WebP
- Width/height default to original image dimensions; specify one to scale proportionally
- Image data is embedded as base64 in the canvas (stored in browser IndexedDB)
- Returns:
Image added (id: <id>, x: <x>, y: <y>, <width>x<height>)
Manipulate Elements
agent-canvas delete-elements -i <id1>,<id2>,...
agent-canvas rotate-elements -i <id1>,<id2>,... -a <degrees>
agent-canvas move-elements -i <id1>,<id2>,... --delta-x <dx> --delta-y <dy>
agent-canvas resize-elements -i <id1>,<id2>,... [--top <n>] [--bottom <n>] [--left <n>] [--right <n>]
agent-canvas group-elements -i <id1>,<id2>,...
agent-canvas ungroup-element -i <id>
Resize Elements (resize-elements):
Expand or contract element edges (rectangle, ellipse, diamond, image). Values are in element’s local coordinate system (respects rotation).
Examples:
# Expand bottom edge by 50px (increase height)
agent-canvas resize-elements -i abc123 --bottom 50
# Expand both right and bottom (like dragging bottom-right corner)
agent-canvas resize-elements -i abc123 --right 50 --bottom 30
# Contract left edge by 20px (decrease width)
agent-canvas resize-elements -i abc123 --left -20
# Expand all sides uniformly
agent-canvas resize-elements -i abc123 --top 25 --bottom 25 --left 25 --right 25
Read Scene
agent-canvas read # TOON format (compact, ~7% of JSON size)
agent-canvas read --with-style # Include stroke/bg colors
agent-canvas read --json # Raw Excalidraw scene JSON
TOON output structure:
shapes[N]{id,type,x,y,w,h,angle,labelId,note} # rectangle, ellipse, diamond, polygon
lines[N]{id,type,x,y,endX,endY,via,angle,note} # line, arrow
labels[N]{id,containerId,content,x,y,w,h} # text bound to shapes (via labelId)
texts[N]{id,content,x,y,w,h,angle,note} # standalone text elements
groups[N]{id,elementIds} # element groupings
labelIdin shapes links toidin labelsviashows intermediate points in same format as--viainput ("x1,y1;x2,y2"ornullif none)--with-styleaddsstroke,bgfields--jsonreturns full Excalidraw format (use withjqto query specific elements)
Save, Export and Clear
agent-canvas save file.excalidraw
agent-canvas export -o out.png [--scale 2] [--dark] [--no-background]
agent-canvas clear # Clear all elements from the canvas
Note: Before running clear, ask the user if they want to save or export the current canvas first.
Design Philosophy
You are a perfectionist. If it looks slightly off, it IS off. Fix it.
Core principle: Consistency reflects meaning.
-
Same relationship â Same alignment & spacing
- Elements with the same relationship should share identical alignment
- Gaps between same-level elements should be equal throughout
- Snap to grid (e.g., 10px units) for precision
-
Same type â Same color & size
- Same-type nodes share identical dimensions
- Same color = same meaning; max 3-4 colors; less is more
- Important elements = larger size
-
Details matter
- Arrows connect precisely to shape edges
- Review via
exportand fix any imperfections
IMPERATIVE GUIDE
-
Coordinates: Origin (0,0) is top-left. Xâright, Yâdown. Colors in hex (
#FF5733) ortransparent. -
Workflow: Read canvas â Plan layout â Draw shapes â Add arrows/lines(if necessary) â Adjust.
- IMPORTANT: Canvas content is auto-saved to browser localStorage. Always run
agent-canvas readfirst to check for existing content before drawing. - If old content exists, ask the user whether to: (a) continue editing, (b) clear and start fresh, or (c) save/export first then clear.
- Shapes define the layout and provide exact coordinates
- Arrow endpoints depend on shape positions â drawing arrows first leads to misalignment
- Adjust: After initial draft, run
readandexportto review. Check against Design Philosophy:- Alignment issues? â
move-elementsto snap to grid - Inconsistent spacing? â
move-elementsto equalize gaps - Overlapping elements? â
move-elementsordelete-elementsand redraw - Wrong sizes? â
delete-elementsand redraw - Misaligned arrows? â
delete-elementsand redraw with correct endpoints - Container size issue? â
resize-elementsto adjust to perfect size
- Alignment issues? â
- IMPORTANT: Canvas content is auto-saved to browser localStorage. Always run
-
Progressive Canvas Reading:
read– Start here. Compact TOON format (~7% of JSON size)read --with-style– Add color info when styling mattersexport -o canvas.png+ view image – For visual/spatial understandingread --json | jq '.elements[] | select(.id=="<id>")'– Query specific element details
-
Batch Commands: Chain with
&&for efficiency. DO NOT WRITE BASH COMMENT IN DRAWING COMMANDSagent-canvas add-shape -t rectangle -x 100 -y 100 -l "A" && \ agent-canvas add-shape -t rectangle -x 300 -y 100 -l "B" && \ agent-canvas add-arrow -x 220 -y 130 --end-x 300 --end-y 130
Drawing Tutorials
Before drawing, identify the diagram type and check for tutorials:
- Determine what type of diagram the user wants (flowchart, architecture, mindmap, UI mockup, etc.)
- Read references/REFERENCE.md â this is the tutorial index listing all available diagram tutorials
- If a matching tutorial exists: Read the specific tutorial FIRST before drawing â tutorials contain type-specific rules, layout patterns, and best practices
- Apply the tutorial guidelines while drawing