image-forge
Image Forge
Pixel-precise image editing with three-tier routing: deterministic CLI tools for exact operations, AI models for semantic edits, vision models for analysis.
Routing Decision
Use AI when the edit requires understanding what is in the image. Use ImageMagick when the edit requires knowing exactly what to do to the pixels.
Tier 1: Deterministic (magick, sips, rembg)
Use for operations with exact, numeric parameters:
| Task | Tool | Command |
|---|---|---|
| Resize to exact dimensions | magick | magick in.jpg -resize 800x600! out.jpg |
| Resize fit (preserve aspect) | magick | magick in.jpg -resize 800x600 out.jpg |
| Resize fill + crop | magick | magick in.jpg -resize 800x600^ -gravity center -extent 800x600 out.jpg |
| Resize shrink only | magick | magick in.jpg -resize '800x600>' out.jpg |
| Crop at offset | magick | magick in.jpg -crop 600x400+100+50 +repage out.jpg |
| Center crop | magick | magick in.jpg -gravity center -crop 600x400+0+0 +repage out.jpg |
| Auto-trim whitespace | magick | magick in.jpg -fuzz 10% -trim +repage out.jpg |
| Format convert | magick | magick in.png -quality 85 out.jpg |
| Add text | magick | magick in.jpg -fill white -pointsize 36 -annotate +10+50 'Text' out.jpg |
| Composite overlay | magick | magick bg.png fg.png -geometry +50+100 -composite out.png |
| Watermark | magick | magick photo.jpg wm.png -gravity SouthEast -geometry +10+10 -compose Dissolve -define compose:args=25 -composite out.jpg |
| Adjust brightness/contrast | magick | magick in.jpg -brightness-contrast 10x20 out.jpg |
| Adjust saturation | magick | magick in.jpg -modulate 100,130,100 out.jpg |
| Grayscale | magick | magick in.jpg -colorspace Gray out.jpg |
| Sepia | magick | magick in.jpg -sepia-tone 80% out.jpg |
| Blur | magick | magick in.jpg -blur 0x3 out.jpg |
| Sharpen | magick | magick in.jpg -sharpen 0x1 out.jpg |
| Remove background | rembg | rembg i in.jpg out.png |
| Strip metadata | magick | magick in.jpg -strip out.jpg |
| Set DPI | magick | magick in.jpg -density 300 out.jpg |
| Batch resize | batch_ops.py |
python3 scripts/batch_ops.py *.jpg --op resize --width 800 --output resized/ |
| Montage/contact sheet | magick | magick montage *.jpg -geometry 200x200+5+5 -tile 4x out.jpg |
| Quick format convert (macOS) | sips | sips -s format jpeg in.png --out out.jpg |
| Quick resize (macOS) | sips | sips -Z 800 in.jpg --out out.jpg |
Tier 2: AI Semantic (nano-banana-pro / Gemini)
Delegate to the nano-banana-pro skill when the edit requires understanding image content:
- Remove a person/object from a photo
- Change sky, weather, time of day
- Apply artistic style transfer
- Inpaint/outpaint regions
- Generate new image from scratch
- Content-aware fill after object removal
Tier 3: Vision Analysis (Claude Read tool)
Use the Read tool to inspect images before/after edits:
- Verify an edit succeeded
- Describe image contents
- Check composition and framing
- Identify colors, objects, text in image
Scripts
All scripts are in ~/.claude/skills/image-forge/scripts/. Run with python3.
image_info.py — Inspect Image Metadata
python3 ~/.claude/skills/image-forge/scripts/image_info.py photo.jpg
python3 ~/.claude/skills/image-forge/scripts/image_info.py photo.jpg --field dimensions
python3 ~/.claude/skills/image-forge/scripts/image_info.py photo.jpg --field width
Returns clean JSON: dimensions, format, color space, depth, alpha, DPI, ICC profile, EXIF.
image_pipeline.py — Declarative Edit Pipeline
Write a JSON spec, get a single chained magick command. No intermediate files.
# Create spec
cat > /tmp/pipeline.json << 'EOF'
{
"input": "photo.jpg",
"output": "result.png",
"steps": [
{"op": "resize", "width": 800, "height": 600, "mode": "fill"},
{"op": "brightness_contrast", "brightness": 5, "contrast": 10},
{"op": "annotate", "text": "Title", "gravity": "South", "pointsize": 36, "fill": "white", "stroke": "black", "strokewidth": 2},
{"op": "composite", "overlay": "watermark.png", "gravity": "SouthEast", "opacity": 25},
{"op": "quality", "value": 90},
{"op": "strip"}
]
}
EOF
# Dry run (print command)
python3 ~/.claude/skills/image-forge/scripts/image_pipeline.py /tmp/pipeline.json --dry-run
# Execute
python3 ~/.claude/skills/image-forge/scripts/image_pipeline.py /tmp/pipeline.json
Available operations:
| Op | Parameters |
|---|---|
resize |
width, height, mode (fit/fill/exact/shrink/enlarge/percent), filter |
crop |
w/width, h/height, x, y, gravity |
trim |
fuzz (%) |
annotate |
text, font, pointsize, fill, stroke, strokewidth, gravity, x, y |
composite |
overlay, gravity, x, y, opacity, compose, resize |
rotate |
angle, background |
blur |
sigma, radius |
sharpen |
sigma, radius |
unsharp |
sigma, radius, amount, threshold |
modulate |
brightness, saturation, hue (100 = no change) |
brightness_contrast |
brightness, contrast |
levels |
black, white, gamma |
gamma |
value |
sigmoidal_contrast |
strength, midpoint |
colorize |
color, amount (%) |
sepia |
threshold (%) |
grayscale |
(none) |
negate |
(none) |
auto_level |
(none) |
normalize |
(none) |
auto_orient |
(none) |
flip / flop |
(none) |
border |
color, size |
extent |
width, height, background, gravity |
shadow |
opacity, sigma, x, y |
transparent |
color, fuzz (%) |
alpha_remove |
background |
alpha_set |
(none) |
quality |
value (1-100) |
strip |
(none) |
density |
value (DPI) |
draw |
primitive, fill, stroke, strokewidth |
raw |
args (string or array of raw magick args) |
smart_crop.py — Gravity-Based Smart Crop
python3 ~/.claude/skills/image-forge/scripts/smart_crop.py photo.jpg --target 800x600
python3 ~/.claude/skills/image-forge/scripts/smart_crop.py photo.jpg --target 800x600 --gravity north
python3 ~/.claude/skills/image-forge/scripts/smart_crop.py photo.jpg --target 1080x1080 --output cropped/
python3 ~/.claude/skills/image-forge/scripts/smart_crop.py photo.jpg --target 800x600 --dry-run
Gravities: center, north, south, east, west, northwest, northeast, southwest, southeast.
batch_ops.py — Parallel Batch Processing
python3 ~/.claude/skills/image-forge/scripts/batch_ops.py *.jpg --op resize --width 800 --output resized/
python3 ~/.claude/skills/image-forge/scripts/batch_ops.py *.png --op format --to jpg --quality 85 --output converted/
python3 ~/.claude/skills/image-forge/scripts/batch_ops.py *.jpg --op thumbnail --width 200 --height 200 --output thumbs/
python3 ~/.claude/skills/image-forge/scripts/batch_ops.py *.jpg --op strip --output clean/
python3 ~/.claude/skills/image-forge/scripts/batch_ops.py *.jpg --op watermark --overlay wm.png --opacity 25 --output marked/
python3 ~/.claude/skills/image-forge/scripts/batch_ops.py *.jpg --op resize --width 800 --parallel 8 --output resized/
Operations: resize, thumbnail, format, strip, auto_orient, watermark, crop.
montage_builder.py — Contact Sheets
python3 ~/.claude/skills/image-forge/scripts/montage_builder.py *.jpg --output contact.jpg
python3 ~/.claude/skills/image-forge/scripts/montage_builder.py *.jpg --cols 3 --thumb 300x300 --label --output grid.jpg
python3 ~/.claude/skills/image-forge/scripts/montage_builder.py *.jpg --background '#1a1a2e' --border 2 --output dark_grid.jpg
Quick Recipes
Social Media Crops
# Instagram square
magick in.jpg -resize 1080x1080^ -gravity center -extent 1080x1080 instagram.jpg
# Instagram story
magick in.jpg -resize 1080x1920^ -gravity center -extent 1080x1920 story.jpg
# Twitter/X header
magick in.jpg -resize 1500x500^ -gravity center -extent 1500x500 header.jpg
# OG image
magick in.jpg -resize 1200x630^ -gravity center -extent 1200x630 og.jpg
Watermark
# Text watermark
magick photo.jpg -fill 'rgba(255,255,255,0.3)' -gravity SouthEast \
-font Helvetica -pointsize 24 -annotate +10+10 '© 2026' out.jpg
# Image watermark at 25%
magick photo.jpg wm.png -gravity SouthEast -geometry +10+10 \
-compose Dissolve -define compose:args=25 -composite out.jpg
Borders and Shadows
# Solid border
magick in.jpg -bordercolor '#333' -border 10 out.jpg
# Drop shadow
magick in.png \( +clone -background black -shadow 60x5+5+5 \) \
+swap -background none -layers merge +repage shadow.png
Color Effects
# Vintage
magick in.jpg -modulate 105,80,100 -fill '#704214' -colorize 15% \
-sigmoidal-contrast 3x60% vintage.jpg
# High contrast B&W
magick in.jpg -colorspace Gray -sigmoidal-contrast 10x50% bw.jpg
Geometry Syntax Quick Reference
| Syntax | Meaning |
|---|---|
800x600 |
Fit within box, preserve aspect |
800x600! |
Force exact (distort) |
800x600> |
Shrink only if larger |
800x600< |
Enlarge only if smaller |
800x600^ |
Fill box (minimum dimension matches) |
50% |
Scale by percentage |
+X+Y |
Offset from gravity anchor |
Shell escaping: Quote geometry with >, <, ^:
magick in.jpg -resize '800x600>' out.jpg
Critical Reminders
- Always
+repageafter-crop— Virtual canvas offset persists without it -modulateorder is B,S,H — Brightness, Saturation, Hue (not H,S,L)- Settings persist, operators execute immediately — Order matters in magick commands
- Use
rembgfor background removal —rembg i input.jpg output.png(add-afor alpha matting) - Quote geometry —
>,<,^are shell metacharacters -alpha offis permanent in IM7 — Use-alpha deactivate/-alpha activatefor temporary toggle- Inspect before editing — Run
image_info.pyfirst to know dimensions, format, alpha state - Pipeline for multi-step — Use
image_pipeline.pyinstead of chaining shell commands
References
Detailed references in ~/.claude/skills/image-forge/references/:
magick-reference.md— Complete ImageMagick 7 command reference (resize, crop, color, text, drawing, batch, identify)compositing.md— All compositing operators (Duff-Porter, mathematical, lighting, HSL, special)recipes.md— 30+ recipes (borders, shadows, watermarks, social sizing, color effects, sprites, batch patterns)
Dependencies
| Tool | Version | Install |
|---|---|---|
| ImageMagick | 7.1.2-7 (Q16-HDRI) | brew install imagemagick |
| rembg | 2.0.72 | uv pip install rembg |
| sips | macOS built-in | — |
| Pillow | 10.4.0 | uv pip install Pillow |
More from tdimino/claude-code-minoan
academic-research
Search academic papers, build literature reviews, and synthesize research findings — combines Exa MCP (research_paper category, arxiv filtering) with arxiv-mcp-server for paper discovery, download, and deep analysis. Triggers on academic paper, literature review, research synthesis, arxiv, find papers, scholarly search.
69travel-requirements-expert
Plan a trip, create an itinerary, or research a destination through a structured 5-phase workflow---discovery questions, Exa/Firecrawl research, expert detail gathering, and a day-by-day requirements spec. This skill should be used when a user says "plan a trip," "create an itinerary," "help me visit [place]," or needs travel research with specific venues, safety protocols, and dietary accommodations.
67twilio-api
Use this skill when working with Twilio communication APIs for SMS/MMS messaging, voice calls, phone number management, TwiML, webhook integration, two-way SMS conversations, bulk sending, or production deployment of telephony features. Includes official Twilio patterns, production code examples from Twilio-Aldea (provider-agnostic webhooks, signature validation, TwiML responses), and comprehensive TypeScript examples.
65figma-mcp
Convert Figma designs into production-ready code using MCP server tools. Use this skill when users provide Figma URLs, request design-to-code conversion, ask to implement Figma mockups, or need to extract design tokens and system values from Figma files. Works with frames, components, and entire design files to generate HTML, CSS, React, or other frontend code.
61firecrawl
Scrape web pages to clean markdown using Firecrawl v2 — handles JS-heavy pages, site crawls, URL mapping, document parsing (PDF/DOCX/XLSX), LLM-powered extraction, autonomous agent scraping, and post-scrape browser interaction (Interact API). Prefer over WebFetch for quality and completeness. Triggers on scrape URL, fetch page, crawl site, extract content, parse document, web to markdown, DeepWiki, Firecrawl.
51scrapling
Scrape pages locally with anti-bot bypass, TLS impersonation, and adaptive element tracking — no API keys, no cloud. Handles Cloudflare protection, CSS/XPath element extraction, and survives site redesigns. Complements firecrawl (cloud) with 100% local execution. Triggers on Cloudflare bypass, anti-bot scraping, stealth fetch, local scraping, Scrapling.
47