[Deprecated: use baoyu-image-cards] Generates Xiaohongshu (Little Red Book) image card series with 12 visual styles, 8 layouts, and 3 color palettes. Breaks content into 1-10 cartoon-style image cards optimized for XHS engagement. Use when user mentions "小红书图片", "XHS images", "RedNote infographics", "小红书种草", "小绿书", "微信图文", "微信贴图", or wants social media infographic series for Chinese platforms.
82
81%
Does it follow best practices?
Impact
Pending
No eval scenarios have been run
Passed
No known issues
Break down complex content into eye-catching image card series with multiple style options.
When this skill prompts the user, follow this tool-selection rule (priority order):
AskUserQuestion, request_user_input, clarify, ask_user, or any equivalent.Concrete AskUserQuestion references below are examples — substitute the local equivalent in other runtimes.
When this skill needs to render an image, resolve the backend in this order:
EXTEND.md sets preferred_image_backend to a backend available right now, use it.auto, unset, or the pinned backend isn't available):
imagegen, Hermes image_generate), use it. Runtime-native tools are preferred by default — agents that know their own tool inventory should surface the native one here.baoyu-imagine), use it.Setting preferred_image_backend: ask forces the step-3 prompt every run regardless of available backends. Users change the pinned backend via the ## Changing Preferences section below.
Prompt file requirement (hard): write each image's full, final prompt to a standalone file under prompts/ (naming: NN-{type}-[slug].md) BEFORE invoking any backend. The file is the reproducibility record and lets you switch backends without regenerating prompts.
Concrete tool names (imagegen, image_generate, baoyu-imagine) above are examples — substitute the local equivalents under the same rule.
Default behavior: confirm before generation.
EXTEND.md defaults as recommendation inputs only. None of them authorizes skipping confirmation.--yes, "直接生成", "不用确认", "跳过确认", "按默认出图", or equivalent wording.Respond in the user's language across questions, progress, errors, and completion summary. Keep technical tokens (style names, file paths, code) in English.
| Option | Description |
|---|---|
--style <name> | Visual style (see Styles below) |
--layout <name> | Information layout (see Layouts below) |
--palette <name> | Color override: macaron / warm / neon |
--preset <name> | Style + layout + optional palette shorthand (see Presets below; per-preset prompt fragments in references/style-presets.md) |
--ref <files...> | Reference images applied to image 1 as the series anchor |
--yes | Non-interactive: skip all confirmations, use EXTEND.md or built-in defaults, auto-confirm recommended plan (Path A) |
Three independent knobs combine freely:
| Dimension | Controls | Options |
|---|---|---|
| Style | Visual aesthetics (lines, decorations, rendering) | 12 styles (see Styles below) |
| Layout | Information structure (density, arrangement) | 8 layouts (see Layouts below) |
| Palette (optional) | Color override, replaces the style's default colors | macaron / warm / neon (see Palettes below) |
Example: --style notion --layout dense makes an intellectual knowledge card; add --palette macaron to soften the colors without changing notion's rendering rules. A --preset is a shorthand for style + layout (+ optional palette).
Palette behavior: no --palette → style's built-in colors; --palette <name> → overrides colors only, rendering rules unchanged. Some styles declare a default_palette (e.g., sketch-notes defaults to macaron).
| Style | Description |
|---|---|
cute (Default) | Sweet, adorable, girly aesthetic |
fresh | Clean, refreshing, natural |
warm | Cozy, friendly, approachable |
bold | High impact, attention-grabbing |
minimal | Ultra-clean, sophisticated |
retro | Vintage, nostalgic, trendy |
pop | Vibrant, energetic, eye-catching |
notion | Minimalist hand-drawn line art, intellectual |
chalkboard | Colorful chalk on black board, educational |
study-notes | Realistic handwritten photo style, blue pen + red annotations + yellow highlighter |
screen-print | Bold poster art, halftone textures, limited colors, symbolic storytelling |
sketch-notes | Hand-drawn educational infographic, macaron pastels on warm cream, wobble lines |
Per-style specifications: references/presets/<style>.md.
| Layout | Description |
|---|---|
sparse (Default) | 1-2 points, maximum impact |
balanced | 3-4 points, standard |
dense | 5-8 points, knowledge-card style |
list | Enumeration / ranking (4-7 items) |
comparison | Side-by-side contrast |
flow | Process / timeline (3-6 steps) |
mindmap | Center-radial (4-8 branches) |
quadrant | Four-quadrant / circular sections |
Layout specs: references/elements/canvas.md.
Replaces the style's colors while keeping rendering rules (line treatment, textures) intact.
| Palette | Background | Zone Colors | Accent | Feel |
|---|---|---|---|---|
macaron | Warm cream #F5F0E8 | Blue #A8D8EA, Lavender #D5C6E0, Mint #B5E5CF, Peach #F8D5C4 | Coral #E8655A | Soft, educational |
warm | Soft peach #FFECD2 | Orange #ED8936, Terracotta #C05621, Golden #F6AD55, Rose #D4A09A | Sienna #A0522D | Earth tones, cozy |
neon | Dark purple #1A1025 | Cyan #00F5FF, Magenta #FF00FF, Green #39FF14, Pink #FF6EC7 | Yellow #FFFF00 | High-energy, futuristic |
Palette specs: references/palettes/<palette>.md.
Quick-start combos, grouped by scenario. Use --preset <name> or recommend during Step 2.
Knowledge & Learning:
| Preset | Style | Layout | Best For |
|---|---|---|---|
knowledge-card | notion | dense | 干货知识卡、概念科普 |
checklist | notion | list | 清单、排行榜 |
concept-map | notion | mindmap | 概念图、知识脉络 |
swot | notion | quadrant | SWOT 分析、四象限 |
tutorial | chalkboard | flow | 教程步骤、操作流程 |
classroom | chalkboard | balanced | 课堂笔记、知识讲解 |
study-guide | study-notes | dense | 学习笔记、考试重点 |
hand-drawn-edu | sketch-notes | flow | 手绘教程、流程图解 |
sketch-card | sketch-notes | dense | 手绘知识卡 |
sketch-summary | sketch-notes | balanced | 手绘总结、图文笔记 |
Lifestyle & Sharing:
| Preset | Style | Layout | Best For |
|---|---|---|---|
cute-share | cute | balanced | 少女风分享、日常种草 |
girly | cute | sparse | 甜美封面、氛围感 |
cozy-story | warm | balanced | 生活故事、情感分享 |
product-review | fresh | comparison | 产品对比、测评 |
nature-flow | fresh | flow | 健康流程、自然主题 |
Impact & Opinion:
| Preset | Style | Layout | Best For |
|---|---|---|---|
warning | bold | list | 避坑指南、重要提醒 |
versus | bold | comparison | 正反对比 |
clean-quote | minimal | sparse | 金句、极简封面 |
pro-summary | minimal | balanced | 专业总结、商务内容 |
Trend & Entertainment:
| Preset | Style | Layout | Best For |
|---|---|---|---|
retro-ranking | retro | list | 复古排行、经典盘点 |
throwback | retro | balanced | 怀旧分享 |
pop-facts | pop | list | 趣味冷知识 |
hype | pop | sparse | 炸裂封面、惊叹分享 |
Poster & Editorial:
| Preset | Style | Layout | Best For |
|---|---|---|---|
poster | screen-print | sparse | 海报风封面、影评书评 |
editorial | screen-print | balanced | 观点文章、文化评论 |
cinematic | screen-print | comparison | 电影对比、戏剧张力 |
Full prompt-fragment definitions: references/style-presets.md.
Match content signals to the best combo. First row whose keywords appear wins; fall back to cute-share if nothing matches.
| Signals in source | Style | Layout | Recommended preset |
|---|---|---|---|
| beauty, fashion, cute, girl, pink | cute | sparse/balanced | cute-share, girly |
| health, nature, fresh, organic | fresh | balanced/flow | product-review, nature-flow |
| life, story, emotion, warm | warm | balanced | cozy-story |
| warning, important, must, critical | bold | list/comparison | warning, versus |
| professional, business, elegant | minimal | sparse/balanced | clean-quote, pro-summary |
| classic, vintage, traditional | retro | balanced | throwback, retro-ranking |
| fun, exciting, wow, amazing | pop | sparse/list | hype, pop-facts |
| knowledge, concept, productivity, SaaS | notion | dense/list | knowledge-card, checklist |
| education, tutorial, learning, classroom | chalkboard | balanced/dense | tutorial, classroom |
| notes, handwritten, study guide, realistic | study-notes | dense/list/mindmap | study-guide |
| movie, poster, opinion, editorial, cinematic | screen-print | sparse/comparison | poster, editorial, cinematic |
| hand-drawn, infographic, workflow, 手绘, 图解 | sketch-notes | flow/balanced/dense | hand-drawn-edu, sketch-card, sketch-summary |
Compatibility scores (✓✓ highly recommended, ✓ works well, ✗ avoid). Use when the user picks a non-default combo and you want to flag a poor match.
| sparse | balanced | dense | list | comparison | flow | mindmap | quadrant | |
|---|---|---|---|---|---|---|---|---|
| cute | ✓✓ | ✓✓ | ✓ | ✓✓ | ✓ | ✓ | ✓ | ✓ |
| fresh | ✓✓ | ✓✓ | ✓ | ✓ | ✓ | ✓✓ | ✓ | ✓ |
| warm | ✓✓ | ✓✓ | ✓ | ✓ | ✓✓ | ✓ | ✓ | ✓ |
| bold | ✓✓ | ✓ | ✓ | ✓✓ | ✓✓ | ✓ | ✓ | ✓✓ |
| minimal | ✓✓ | ✓✓ | ✓✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
| retro | ✓✓ | ✓✓ | ✓ | ✓✓ | ✓ | ✓ | ✓ | ✓ |
| pop | ✓✓ | ✓✓ | ✓ | ✓✓ | ✓✓ | ✓ | ✓ | ✓ |
| notion | ✓✓ | ✓✓ | ✓✓ | ✓✓ | ✓✓ | ✓✓ | ✓✓ | ✓✓ |
| chalkboard | ✓✓ | ✓✓ | ✓✓ | ✓✓ | ✓ | ✓✓ | ✓✓ | ✓ |
| study-notes | ✗ | ✓ | ✓✓ | ✓✓ | ✓ | ✓ | ✓✓ | ✓ |
| screen-print | ✓✓ | ✓✓ | ✗ | ✓ | ✓✓ | ✓ | ✗ | ✓✓ |
| sketch-notes | ✓ | ✓✓ | ✓✓ | ✓✓ | ✓ | ✓✓ | ✓✓ | ✓ |
Three differentiated approaches — each produces a structurally different outline. The workflow recommends one; Path C generates all three and lets the user choose.
| Strategy | Concept | Best for | Structure |
|---|---|---|---|
| A — Story-Driven | Personal experience as the thread, emotional resonance first | Reviews, personal shares, transformation | Hook → Problem → Discovery → Experience → Conclusion |
| B — Information-Dense | Value-first, efficient information delivery | Tutorials, comparisons, checklists | Core conclusion → Info card → Pros/Cons → Recommendation |
| C — Visual-First | Visual impact as core, minimal text | High-aesthetic products, lifestyle, mood content | Hero image → Detail shots → Lifestyle scene → CTA |
User-supplied refs are separate from the internal "image-1 as anchor" chain (Step 3) — they layer on top of it.
Intake: via --ref <files...> or paths pasted in conversation.
refs/NN-ref-{slug}.{ext}Usage modes (per reference):
| Usage | Effect |
|---|---|
direct | Pass the file to the backend (typically on image 1 only, so the anchor propagates through the chain) |
style | Extract style traits and append to every card's prompt body |
palette | Extract hex colors and append to every card's prompt body |
Record refs in each affected card's prompt frontmatter:
references:
- ref_id: 01
filename: 01-ref-brand.png
usage: directAt generation time: verify files exist. Image 1 with usage: direct + backend that accepts refs → pass via the backend's ref parameter (becomes the chain anchor). Images 2+ keep using image-1 as --ref per Step 3 — do NOT re-stack user refs on top (avoids conflicting signals). For style/palette, embed extracted traits in every prompt.
image-cards/{topic-slug}/
├── source-{slug}.{ext}
├── analysis.md
├── outline-strategy-{a,b,c}.md # Path C only
├── outline.md
├── prompts/NN-{type}-{slug}.md
├── NN-{type}-{slug}.png
└── refs/ # only if --ref usedSlug: 2-4 words, kebab-case. "AI 工具推荐" → ai-tools-recommend. On collision, append -YYYYMMDD-HHMMSS.
Backup rule (applies throughout): before overwriting any file — source, outline, prompt, image — rename the existing one to <name>-backup-YYYYMMDD-HHMMSS.<ext>. This protects user edits.
- [ ] Step 0: Load EXTEND.md ⛔ BLOCKING (interactive only)
- [ ] Step 1: Analyze content → analysis.md
- [ ] Step 2: Smart Confirm ⚠️ REQUIRED (Path A / B / C)
- [ ] Step 3: Generate images
- [ ] Step 4: Completion reportCheck these paths in order; first hit wins:
| Path | Scope |
|---|---|
.baoyu-skills/baoyu-image-cards/EXTEND.md | Project |
${XDG_CONFIG_HOME:-$HOME/.config}/baoyu-skills/baoyu-image-cards/EXTEND.md | XDG |
$HOME/.baoyu-skills/baoyu-image-cards/EXTEND.md | User home |
references/config/first-time-setup.md) and save before anything else. Do NOT analyze content or ask style questions until preferences exist — this keeps first-run behavior predictable.--yes → skip setup, use built-in defaults (no watermark, style/layout auto-selected, language from content). Do not prompt, do not create EXTEND.md.EXTEND.md keys: watermark, preferred style/layout, custom style definitions, language preference. Schema: references/config/preferences-schema.md.
analysis.mdsource.md exists).references/workflows/analysis-framework.md: content type, hook potential, audience, engagement signals, visual opportunity map, swipe flow.analysis.md.Hard gate: this step is mandatory per the Confirmation Policy — Step 3 cannot start until the user confirms here (or explicitly opts out with --yes / equivalent wording in the current request).
Goal: present the auto-recommended plan and let the user confirm or adjust. Skip this step entirely under --yes — proceed with Path A using the analysis and any CLI overrides.
Display summary before asking:
📋 内容分析
主题:[topic] | 类型:[content_type]
要点:[key points]
受众:[audience]
🎨 推荐方案(自动匹配)
策略:[A/B/C] [name]([reason])
风格:[style] · 布局:[layout] · 配色:[palette or 默认] · 预设:[preset]
图片:[N]张(封面+[N-2]内容+结尾)
元素:[background] / [decorations] / [emphasis]Then ask one question — three paths. Verbatim option copy: references/confirmation.md.
Path A — Quick confirm (trust auto-recommendation): generate a single outline using the recommended strategy + style → save to outline.md → Step 3.
Path B — Customize: ask five questions (strategy/style, layout, palette, count, optional notes) with the recommendation pre-filled — blanks keep the recommendation. Generate one outline with the user's choices → outline.md → Step 3. See references/confirmation.md.
Path C — Detailed mode: two sub-confirmations.
analysis.md.outline-strategy-a.md, outline-strategy-b.md, outline-strategy-c.md. Each MUST have a different structure AND a different recommended style — include style_reason in the frontmatter. Page-count heuristic: A ~4-6, B ~3-5, C ~3-4. Template: references/workflows/outline-template.md; frontmatter example in references/confirmation.md.outline.md → Step 3.With confirmed outline + style + layout + palette:
Visual consistency — image-1 anchor chain: character / mascot / color rendering drifts between calls unless you anchor them. Generate image 1 (cover) first WITHOUT --ref, then pass image 1 as --ref to every subsequent image. This is the single most important consistency trick for this skill — don't skip it even if the backend also supports a session ID.
For each image (cover, content, ending):
prompts/NN-{type}-{slug}.md in the user's preferred language (backup rule applies).--ref (establishes the anchor).--ref <path-to-image-01.png>.Watermark (if enabled in EXTEND.md): append to the generation prompt:
Include a subtle watermark "[content]" positioned at [position].
The watermark should be legible but not distracting.See references/config/watermark-guide.md.
Backend selection: per the Image Generation Tools rule at the top — use whatever is available, ask once if multiple, before any generation. Under --yes, use the EXTEND.md preference and fall back to the first available backend. Prompt files MUST exist before invoking any backend.
Session ID (if the backend supports --sessionId): use cards-{topic-slug}-{timestamp} for every image; combined with the ref chain this gives maximum consistency.
Image Card Series Complete!
Topic: [topic]
Mode: [Quick / Custom / Detailed]
Strategy: [A/B/C/Combined]
Style: [name]
Palette: [name or "default"]
Layout: [name or "varies"]
Location: [directory]
Images: N total
✓ analysis.md
✓ outline.md
✓ outline-strategy-a/b/c.md (detailed mode only)
- 01-cover-[slug].png ✓ Cover (sparse)
- 02-content-[slug].png ✓ Content (balanced)
- ...
- NN-ending-[slug].png ✓ Ending (sparse)| Position | Purpose | Typical layout |
|---|---|---|
| Cover (image 1) | Hook + visual impact | sparse |
| Content (middle) | Core value per image | balanced / dense / list / comparison / flow |
| Ending (last) | CTA / summary | sparse or balanced |
For the style × layout compatibility matrix, see the Style × Layout Matrix above.
| Action | How |
|---|---|
| Edit | Update prompts/NN-{type}-{slug}.md first, then regenerate with the same session ID |
| Add | Specify position, create prompt, generate, renumber subsequent files NN+1, update outline |
| Delete | Remove files, renumber subsequent NN-1, update outline |
Always update the prompt file before regenerating — it's the source of truth and makes changes reproducible.
| File | Content |
|---|---|
references/confirmation.md | Verbatim AskUserQuestion copy for every confirmation path |
references/style-presets.md | Full preset shortcut definitions |
references/presets/<style>.md | Per-style element definitions |
references/palettes/<name>.md | Per-palette color definitions |
references/elements/canvas.md | Aspect ratios, safe zones, grid layouts |
references/elements/image-effects.md | Cutout, stroke, filters |
references/elements/typography.md | Decorated text, tags, text direction |
references/elements/decorations.md | Emphasis marks, backgrounds, doodles, frames |
references/workflows/analysis-framework.md | Content analysis framework |
references/workflows/outline-template.md | Outline template with layout guide |
references/workflows/prompt-assembly.md | Prompt assembly guide |
references/config/preferences-schema.md | EXTEND.md schema |
references/config/first-time-setup.md | First-time setup flow |
references/config/watermark-guide.md | Watermark configuration |
EXTEND.md lives at the first matching path listed in Step 0. Three ways to change it:
references/config/preferences-schema.md.preferred_image_backend: auto — default; runtime-native tool wins, falls back to the only installed backend, asks only if multiple non-native are present.preferred_image_backend: codex-imagegen — pin to Codex's built-in.preferred_image_backend: baoyu-imagine — pin to the baoyu-imagine skill.preferred_image_backend: ask — confirm backend every run.preferred_style: notion, preferred_layout: dense, preferred_palette: macaron, language: zh.watermark.enabled: true + watermark.content: "@handle" — add a watermark.505a7e1
If you maintain this skill, you can claim it as your own. Once claimed, you can manage eval scenarios, bundle related skills, attach documentation or rules, and ensure cross-agent compatibility.