返回顶部
e

excalidraw-diagram-generatorExcalidraw图表生成器

Generate Excalidraw diagrams from natural language descriptions. Use when asked to "create a diagram", "make a flowchart", "visualize a process", "draw a system architecture", "create a mind map", or "generate an Excalidraw file". Supports flowcharts, relationship diagrams, mind maps, and system architecture diagrams. Outputs .excalidraw JSON files that can be opened directly in Excalidraw.

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 1.0.0
安全检测
已通过
2,510
下载量
免费
免费
2
收藏
概述
安装方式
版本历史

excalidraw-diagram-generator

Excalidraw Diagram Generator

A skill for generating Excalidraw-format diagrams from natural language descriptions. This skill helps create visual representations of processes, systems, relationships, and ideas without manual drawing.

When to Use This Skill

Use this skill when users request:

  • - "Create a diagram showing..."
  • "Make a flowchart for..."
  • "Visualize the process of..."
  • "Draw the system architecture of..."
  • "Generate a mind map about..."
  • "Create an Excalidraw file for..."
  • "Show the relationship between..."
  • "Diagram the workflow of..."

Supported diagram types:

  • - 📊 Flowcharts: Sequential processes, workflows, decision trees
  • 🔗 Relationship Diagrams: Entity relationships, system components, dependencies
  • 🧠 Mind Maps: Concept hierarchies, brainstorming results, topic organization
  • 🏗️ Architecture Diagrams: System design, module interactions, data flow
  • 📈 Data Flow Diagrams (DFD): Data flow visualization, data transformation processes
  • 🏊 Business Flow (Swimlane): Cross-functional workflows, actor-based process flows
  • 📦 Class Diagrams: Object-oriented design, class structures and relationships
  • 🔄 Sequence Diagrams: Object interactions over time, message flows
  • 🗃️ ER Diagrams: Database entity relationships, data models

Prerequisites

  • - Clear description of what should be visualized
  • Identification of key entities, steps, or concepts
  • Understanding of relationships or flow between elements

Step-by-Step Workflow

Step 1: Understand the Request

Analyze the user's description to determine:

  1. 1. Diagram type (flowchart, relationship, mind map, architecture)
  2. Key elements (entities, steps, concepts)
  3. Relationships (flow, connections, hierarchy)
  4. Complexity (number of elements)

Step 2: Choose the Appropriate Diagram Type

User IntentDiagram TypeExample Keywords
Process flow, steps, proceduresFlowchart"workflow", "process", "steps", "procedure"
Connections, dependencies, associations
Relationship Diagram | "relationship", "connections", "dependencies", "structure" | | Concept hierarchy, brainstorming | Mind Map | "mind map", "concepts", "ideas", "breakdown" | | System design, components | Architecture Diagram | "architecture", "system", "components", "modules" | | Data flow, transformation processes | Data Flow Diagram (DFD) | "data flow", "data processing", "data transformation" | | Cross-functional processes, actor responsibilities | Business Flow (Swimlane) | "business process", "swimlane", "actors", "responsibilities" | | Object-oriented design, class structures | Class Diagram | "class", "inheritance", "OOP", "object model" | | Interaction sequences, message flows | Sequence Diagram | "sequence", "interaction", "messages", "timeline" | | Database design, entity relationships | ER Diagram | "database", "entity", "relationship", "data model" |

Step 3: Extract Structured Information

For Flowcharts:

  • - List of sequential steps
  • Decision points (if any)
  • Start and end points

For Relationship Diagrams:

  • - Entities/nodes (name + optional description)
  • Relationships between entities (from → to, with label)

For Mind Maps:

  • - Central topic
  • Main branches (3-6 recommended)
  • Sub-topics for each branch (optional)

For Data Flow Diagrams (DFD):

  • - Data sources and destinations (external entities)
  • Processes (data transformations)
  • Data stores (databases, files)
  • Data flows (arrows showing data movement from left-to-right or from top-left to bottom-right)
  • Important: Do not represent process order, only data flow

For Business Flow (Swimlane):

  • - Actors/roles (departments, systems, people) - displayed as header columns
  • Process lanes (vertical lanes under each actor)
  • Process boxes (activities within each lane)
  • Flow arrows (connecting process boxes, including cross-lane handoffs)

For Class Diagrams:

  • - Classes with names
  • Attributes with visibility (+, -, #)
  • Methods with visibility and parameters
  • Relationships: inheritance (solid line + white triangle), implementation (dashed line + white triangle), association (solid line), dependency (dashed line), aggregation (solid line + white diamond), composition (solid line + filled diamond)
  • Multiplicity notations (1, 0..1, 1.., )

For Sequence Diagrams:

  • - Objects/actors (arranged horizontally at top)
  • Lifelines (vertical lines from each object)
  • Messages (horizontal arrows between lifelines)
  • Synchronous messages (solid arrow), asynchronous messages (dashed arrow)
  • Return values (dashed arrows)
  • Activation boxes (rectangles on lifelines during execution)
  • Time flows from top to bottom

For ER Diagrams:

  • - Entities (rectangles with entity names)
  • Attributes (listed inside entities)
  • Primary keys (underlined or marked with PK)
  • Foreign keys (marked with FK)
  • Relationships (lines connecting entities)
  • Cardinality: 1:1 (one-to-one), 1:N (one-to-many), N:M (many-to-many)
  • Junction/associative entities for many-to-many relationships (dashed rectangles)

Step 4: Generate the Excalidraw JSON

Create the .excalidraw file with appropriate elements:

Available element types:

  • - rectangle: Boxes for entities, steps, concepts
  • INLINECODE2: Alternative shapes for emphasis
  • INLINECODE3: Decision points
  • INLINECODE4: Directional connections
  • INLINECODE5: Labels and annotations

Key properties to set:

  • - Position: x, y coordinates
  • Size: width, INLINECODE9
  • Style: strokeColor, backgroundColor, INLINECODE12
  • Font: fontFamily: 5 (Excalifont - required for all text elements)
  • Text: Embedded text for labels
  • Connections: points array for arrows

Important: All text elements must use fontFamily: 5 (Excalifont) for consistent visual appearance.

Step 5: Format the Output

Structure the complete Excalidraw file:

CODEBLOCK0

Step 6: Save and Provide Instructions

  1. 1. Save as INLINECODE16
  2. Inform user how to open:
- Visit https://excalidraw.com - Click "Open" or drag-and-drop the file - Or use Excalidraw VS Code extension

Best Practices

Element Count Guidelines

Diagram TypeRecommended CountMaximum
Flowchart steps3-1015
Relationship entities
3-8 | 12 | | Mind map branches | 4-6 | 8 | | Mind map sub-topics per branch | 2-4 | 6 |

Layout Tips

  1. 1. Start positions: Center important elements, use consistent spacing
  2. Spacing:
- Horizontal gap: 200-300px between elements - Vertical gap: 100-150px between rows
  1. 3. Colors: Use consistent color scheme
- Primary elements: Light blue (#a5d8ff) - Secondary elements: Light green (#b2f2bb) - Important/Central: Yellow (#ffd43b) - Alerts/Warnings: Light red (#ffc9c9)
  1. 4. Text sizing: 16-24px for readability
  2. Font: Always use fontFamily: 5 (Excalifont) for all text elements
  3. Arrow style: Use straight arrows for simple flows, curved for complex relationships

Complexity Management

If user request has too many elements:

  • - Suggest breaking into multiple diagrams
  • Focus on main elements first
  • Offer to create detailed sub-diagrams

Example response:
CODEBLOCK1

Example Prompts and Responses

Example 1: Simple Flowchart

User: "Create a flowchart for user registration"

Agent generates:

  1. 1. Extract steps: "Enter email" → "Verify email" → "Set password" → "Complete"
  2. Create flowchart with 4 rectangles + 3 arrows
  3. Save as INLINECODE22

Example 2: Relationship Diagram

User: "Diagram the relationship between User, Post, and Comment entities"

Agent generates:

  1. 1. Entities: User, Post, Comment
  2. Relationships: User → Post ("creates"), User → Comment ("writes"), Post → Comment ("contains")
  3. Save as INLINECODE23

Example 3: Mind Map

User: "Mind map about machine learning concepts"

Agent generates:

  1. 1. Center: "Machine Learning"
  2. Branches: Supervised Learning, Unsupervised Learning, Reinforcement Learning, Deep Learning
  3. Sub-topics under each branch
  4. Save as INLINECODE24

Troubleshooting

IssueSolution
Elements overlapIncrease spacing between coordinates
Text doesn't fit in boxes
Increase box width or reduce font size | | Too many elements | Break into multiple diagrams | | Unclear layout | Use grid layout (rows/columns) or radial layout (mind maps) | | Colors inconsistent | Define color palette upfront based on element types |

Advanced Techniques

Grid Layout (for Relationship Diagrams)

CODEBLOCK2

Radial Layout (for Mind Maps)

CODEBLOCK3

Auto-generated IDs

Use timestamp + random string for unique IDs: CODEBLOCK4

Output Format

Always provide:

  1. 1. ✅ Complete .excalidraw JSON file
  2. 📊 Summary of what was created
  3. 📝 Element count
  4. 💡 Instructions for opening/editing

Example summary:
CODEBLOCK5

Validation Checklist

Before delivering the diagram:

  • - [ ] All elements have unique IDs
  • [ ] Coordinates prevent overlapping
  • [ ] Text is readable (font size 16+)
  • [ ] All text elements use fontFamily: 5 (Excalifont)
  • [ ] Arrows connect logically
  • [ ] Colors follow consistent scheme
  • [ ] File is valid JSON
  • [ ] Element count is reasonable (<20 for clarity)

Icon Libraries (Optional Enhancement)

For specialized diagrams (e.g., AWS/GCP/Azure architecture diagrams), you can use pre-made icon libraries from Excalidraw. This provides professional, standardized icons instead of basic shapes.

When User Requests Icons

If user asks for AWS/cloud architecture diagrams or mentions wanting to use specific icons:

  1. 1. Check if library exists: Look for INLINECODE27
  2. If library exists: Proceed to use icons (see AI Assistant Workflow below)
  3. If library does NOT exist: Respond with setup instructions:

CODEBLOCK6

User Setup Instructions (Detailed)

Step 1: Create Library Directory
CODEBLOCK7

Step 2: Download Library

  • - Visit: https://libraries.excalidraw.com/
  • Search for your desired icon set (e.g., "AWS Architecture Icons")
  • Click download to get the .excalidrawlib file
  • Example categories (availability varies; confirm on the site):

- Cloud service icons
- UI/Material icons
- Flowchart symbols

Step 3: Place Library File

  • - Rename the downloaded file to match the directory name (e.g., aws-architecture-icons.excalidrawlib)
  • Move it to the directory created in Step 1

Step 4: Run Splitter Script
CODEBLOCK8

Step 5: Verify Setup
After running the script, verify the following structure exists:
CODEBLOCK9

AI Assistant Workflow

When icon libraries are available in libraries/:

RECOMMENDED APPROACH: Use Python Scripts (Efficient & Reliable)

The repository includes Python scripts that handle icon integration automatically:

  1. 1. Create base diagram structure:
- Create .excalidraw file with basic layout (title, boxes, regions) - This establishes the canvas and overall structure
  1. 2. Add icons using Python script:
   python skills/excalidraw-diagram-generator/scripts/add-icon-to-diagram.py \
     <diagram-path> <icon-name> <x> <y> [--label "Text"] [--library-path PATH]
   
- Edit via .excalidraw.edit is enabled by default to avoid overwrite issues; pass --no-use-edit-suffix to disable.

Examples:
CODEBLOCK11

  1. 3. Add connecting arrows:
   python skills/excalidraw-diagram-generator/scripts/add-arrow.py \
     <diagram-path> <from-x> <from-y> <to-x> <to-y> [--label "Text"] [--style solid|dashed|dotted] [--color HEX]
   
- Edit via .excalidraw.edit is enabled by default to avoid overwrite issues; pass --no-use-edit-suffix to disable.

Examples:
CODEBLOCK13

  1. 4. Workflow summary:
CODEBLOCK14

Benefits of Python Script Approach:

  • - ✅ No token consumption: Icon JSON data (200-1000 lines each) never enters AI context
  • Accurate transformations: Coordinate calculations handled deterministically
  • ID management: Automatic UUID generation prevents conflicts
  • Reliable: No risk of coordinate miscalculation or ID collision
  • Fast: Direct file manipulation, no parsing overhead
  • Reusable: Works with any Excalidraw library you provide

ALTERNATIVE: Manual Icon Integration (Not Recommended)

Only use this if Python scripts are unavailable:

  1. 1. Check for libraries:
CODEBLOCK15
  1. 2. Read reference.md:
CODEBLOCK16
  1. 3. Find relevant icons:
CODEBLOCK17
  1. 4. Load specific icon data (WARNING: Large files):
CODEBLOCK18
  1. 5. Extract and transform elements:
CODEBLOCK19
  1. 6. Position icons and add connections:
CODEBLOCK20

Manual Integration Challenges:

  • - ⚠️ High token consumption (200-1000 lines per icon × number of icons)
  • ⚠️ Complex coordinate transformation calculations
  • ⚠️ Risk of ID collision if not handled carefully
  • ⚠️ Time-consuming for diagrams with many icons

Example: Creating AWS Diagram with Icons

Request: "Create an AWS architecture diagram with Internet Gateway, VPC, ELB, EC2, and RDS"

Recommended Workflow (using Python scripts):
Request: "Create an AWS architecture diagram with Internet Gateway, VPC, ELB, EC2, and RDS"

Recommended Workflow (using Python scripts):

CODEBLOCK21

Benefits:

  • - No manual coordinate calculation
  • No token consumption for icon data
  • Deterministic, reliable results
  • Easy to iterate and adjust positions

Alternative Workflow (manual, if scripts unavailable):

  1. 1. Check: libraries/aws-architecture-icons/reference.md exists → Yes
  2. Read reference.md → Find entries for Internet-gateway, VPC, ELB, EC2, RDS
  3. Load:

- icons/Internet-gateway.json (298 lines)
- icons/VPC.json (550 lines)
- icons/ELB.json (363 lines)
- icons/EC2.json (231 lines)
- icons/RDS.json (similar size)
Total: ~2000+ lines of JSON to process
  1. 4. Extract elements from each JSON
  2. Calculate bounding boxes and offsets for each icon
  3. Transform all coordinates (x, y) for positioning
  4. Generate unique IDs for all elements
  5. Add arrows showing data flow
  6. Add text labels
  7. Generate final .excalidraw file

Challenges with manual approach:

  • - High token consumption (~2000-5000 lines)
  • Complex coordinate math
  • Risk of ID conflicts

Supported Icon Libraries (Examples — verify availability)

  • - This workflow works with any valid .excalidrawlib file you provide.
  • Examples of library categories you may find on https://libraries.excalidraw.com/:
- Cloud service icons - Kubernetes / infrastructure icons - UI / Material icons - Flowchart / diagram symbols - Network diagram icons
  • - Availability and naming can change; verify exact library names on the site before use.

Fallback: No Icons Available

If no icon libraries are set up:

  • - Create diagrams using basic shapes (rectangles, ellipses, arrows)
  • Use color coding and text labels to distinguish components
  • Inform user they can add icons later or set up libraries for future diagrams
  • The diagram will still be functional and clear, just less visually polished

References

See bundled references for:

  • - references/excalidraw-schema.md - Complete Excalidraw JSON schema
  • INLINECODE45 - Detailed element type specifications
  • INLINECODE46 - Basic flowchart starter
  • INLINECODE47 - Relationship diagram starter
  • INLINECODE48 - Mind map starter
  • INLINECODE49 - Tool to split .excalidrawlib files
  • INLINECODE51 - Documentation for library tools
  • INLINECODE52 - Prevents local Python artifacts from being committed

Limitations

  • - Complex curves are simplified to straight/basic curved lines
  • Hand-drawn roughness is set to default (1)
  • No embedded images support in auto-generation
  • Maximum recommended elements: 20 per diagram
  • No automatic collision detection (use spacing guidelines)

Future Enhancements

Potential improvements:

  • - Auto-layout optimization algorithms
  • Import from Mermaid/PlantUML syntax
  • Template library expansion
  • Interactive editing after generation

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 excalidraw-diagram-generator-1776420024 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 excalidraw-diagram-generator-1776420024 技能

通过命令行安装

skillhub install excalidraw-diagram-generator-1776420024

下载

⬇ 下载 excalidraw-diagram-generator v1.0.0(免费)

文件大小: 14.85 KB | 发布时间: 2026-4-17 20:15

v1.0.0 最新 2026-4-17 20:15
Initial release – generate Excalidraw diagrams from natural language descriptions.

- Supports flowcharts, relationship diagrams, mind maps, system architecture diagrams, data flow diagrams, swimlanes, class, sequence, and ER diagrams.
- Outputs valid .excalidraw JSON files compatible with Excalidraw and its VS Code extension.
- Includes detailed usage instructions, diagram type selection guidance, and element formatting standards.
- Applies best practices for diagram clarity, element limits, color schemes, and layout consistency.
- Ensures all text uses Excalifont (fontFamily: 5) for visual consistency.

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部