CRITICAL: Use for Makepad GUI screenshot debugging and visual inspection. Triggers on: /screenshot, 截图, 看看UI, 查看界面, capture makepad, run and capture, 运行并截图, 看看效果, UI截图, 界面截图, screenshot makepad, capture app, 截取应用, bring to front
Install
npx skillscat add zhanghandong/makepad-component/makepad-screenshot Install via the SkillsCat registry.
Makepad Screenshot Skill
Automated screenshot debugging for Makepad GUI applications
Trigger Words
/screenshot- Capture current running Makepad app/screenshot <app-name>- Capture specific app/run-and-capture <package>- Build, run and capture- "截图", "看看UI", "查看界面", "capture makepad"
Features
Automates visual debugging workflow for Makepad apps:
- Bring app window to front
- Capture screenshot
- Analyze screenshot with Read tool
- Report UI issues or confirm correct rendering
Usage
1. Capture Current Running App
/screenshotAuto-detects and captures windows containing "makepad" or current project name.
2. Capture Specific App
/screenshot a2ui-demoCaptures app with window name containing "a2ui".
3. Build, Run and Capture
/run-and-capture a2ui-demoFull workflow: cargo build → cargo run → wait for startup → capture.
Implementation Steps
Step 1: Detect Running App
# Find Makepad-related processes
ps aux | grep -E "(makepad|cargo.*run)" | grep -v grepStep 2: Bring Window to Front (macOS)
# Generic pattern - match by process name
osascript -e 'tell application "System Events" to set frontmost of (first process whose name contains "APP_NAME") to true'
# Example
osascript -e 'tell application "System Events" to set frontmost of (first process whose name contains "a2ui") to true'Step 3: Capture to Scratchpad
# Silent capture (-x suppresses shutter sound)
screencapture -x $SCRATCHPAD/screenshot.pngStep 4: View with Read Tool
Read $SCRATCHPAD/screenshot.pngClaude's Read tool supports image files and can directly analyze screenshot content.
Complete Automation Script
Capture Current App
APP_NAME="${1:-makepad}"
SCRATCHPAD="${SCRATCHPAD_DIR:-/tmp}"
SCREENSHOT="$SCRATCHPAD/makepad_screenshot_$(date +%H%M%S).png"
# Bring to front
osascript -e "tell application \"System Events\" to set frontmost of (first process whose name contains \"$APP_NAME\") to true" 2>/dev/null
sleep 0.5
# Capture
screencapture -x "$SCREENSHOT"
echo "$SCREENSHOT"Build, Run and Capture
PACKAGE="$1"
SCRATCHPAD="${SCRATCHPAD_DIR:-/tmp}"
SCREENSHOT="$SCRATCHPAD/${PACKAGE}_$(date +%H%M%S).png"
# Kill old process
pkill -f "$PACKAGE" 2>/dev/null
# Build and run
cargo build -p "$PACKAGE" && \
(cargo run -p "$PACKAGE" 2>&1 &) && \
sleep 5 && \
osascript -e "tell application \"System Events\" to set frontmost of (first process whose name contains \"$PACKAGE\") to true" && \
sleep 1 && \
screencapture -x "$SCREENSHOT"
echo "$SCREENSHOT"Claude Execution Flow
When user says "截图" or "/screenshot":
Detect App
ps aux | grep -E "cargo.*run|makepad" | grep -v grep | head -1Determine App Name
- Extract from process list
- Or use current project's package name
Execute Screenshot
osascript -e 'tell application "System Events" to set frontmost of (first process whose name contains "APP") to true' sleep 0.5 screencapture -x /path/to/scratchpad/screenshot.pngRead and Analyze
Read /path/to/scratchpad/screenshot.pngReport Results
- Describe visible UI elements
- Point out any issues (layout, colors, missing components)
- Confirm functionality
Notes
- macOS Only - Uses
screencaptureandosascript - Permission Required - osascript needs accessibility permission
- Window Occlusion - Must bring to front first
- Startup Time - Need to sleep after cargo run to wait for window
- Scratchpad - Use session-specific scratchpad directory for screenshots
Example Interactions
Example 1: Quick Screenshot
User: 截图看看现在的 UI
Claude:
1. Detected running a2ui-demo
2. Execute screenshot command
3. Read screenshot file
4. Analysis: "UI displays normally, TextField shows input '你好', product list rendered 3 cards..."Example 2: Build Run and Capture
User: /run-and-capture a2ui-demo
Claude:
1. pkill old process
2. cargo build -p a2ui-demo
3. cargo run -p a2ui-demo &
4. sleep 5 wait for startup
5. Capture and analyzeExample 3: Verify Two-way Binding
User: I entered "Hello😊" in TextField, help me verify two-way binding with screenshot
Claude:
1. Execute screenshot, save to scratchpad
2. Read screenshot, analyze UI
3. Output verification report:
┌────────────────────────────────────────┐
│ A2UI Demo - Product Catalog │
├────────────────────────────────────────┤
│ [Search Products] │
│ ┌──────────────────────────────────┐ │
│ │ Hello😊 │ │ ← TextField shows input
│ └──────────────────────────────────┘ │
│ Hello😊 │ ← Text (caption) synced
│ │
│ Products (Template Rendering) │
│ ┌──────────────────────────────────┐ │
│ │ Premium Headphones | $99.99 | + │ │
│ └──────────────────────────────────┘ │
└────────────────────────────────────────┘
✅ Two-way binding verification successful:
| Component | Binding Path | Display Content |
|-----------|--------------|-----------------|
| TextField | /search/query | Hello😊 |
| Text (caption) | /search/query | Hello😊 |UI Analysis Report Format
After screenshot, Claude should provide structured analysis:
Basic Report
## Screenshot Analysis
**Application**: a2ui-demo
**Time**: 2026-02-01 14:30:00
**Window State**: Normal display
### UI Elements
| Element | Type | Content/State |
|---------|------|---------------|
| Title | Label | "A2UI Demo - Product Catalog" |
| Search Box | TextField | Empty/Has input |
| Product List | PortalList | 3 cards |
### Issue Detection
- ✅ Layout normal
- ✅ Text rendering normal
- ⚠️ Image not loaded (network image)Function Verification Report
## Function Verification: TextField Two-way Binding
**Test Scenario**: User enters content in TextField, verify data model sync
### Verification Result
| Component | Binding Path | Expected | Actual | Status |
|-----------|--------------|----------|--------|--------|
| TextField | /search/query | Hello😊 | Hello😊 | ✅ |
| Text (caption) | /search/query | Hello😊 | Hello😊 | ✅ |
### Conclusion
✅ **Two-way binding works correctly**
- Unicode Chinese characters: ✅
- Emoji characters: ✅
- Real-time sync: ✅Common Issue Troubleshooting
Window Cannot Be Brought to Front
# Check if process is running
ps aux | grep -E "a2ui|makepad" | grep -v grep
# Try using process ID
osascript -e 'tell application "System Events" to set frontmost of (first process whose unix id is PID) to true'Screenshot is Black Screen
Possible causes:
- Window occluded by other windows - bring to front first
- App still starting - increase sleep time
- GPU rendering delay - wait 1-2 seconds before capture
App Name Matching Issues
Makepad compiled app names are usually package names (underscores to hyphens):
a2ui-demo→ process name containsa2uiora2ui-demomy_app→ process name containsmy_appormy-app
Related Skills
makepad-basics- Makepad fundamentalsmakepad-widgets- Widget usagememory-skills- Memory system
Context: For automated visual debugging of Makepad GUI applications
Tags: makepad, screenshot, debugging, gui, automation, macos