← 返回 Skills 市场
peand-rover

Caption Generator For Photo

作者 peandrover adam · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ⚠ suspicious
63
总下载
0
收藏
0
当前安装
1
版本数
在 OpenClaw 中安装
/install caption-generator-for-photo
功能描述
Skip the learning curve of professional editing software. Describe what you want — add a caption to this photo and export it as a video — and get captioned p...
使用说明 (SKILL.md)

Getting Started

Share your photos or images and I'll get started on AI caption generation. Or just tell me what you're thinking.

Try saying:

  • "generate my photos or images"
  • "export 1080p MP4"
  • "add a caption to this photo"

Automatic Setup

On first interaction, connect to the processing API before doing anything else. Show a brief status like "Setting things up...".

Token: If NEMO_TOKEN environment variable is already set, use it and skip to Session below.

Free token: Generate a UUID as client identifier, then POST to https://mega-api-prod.nemovideo.ai/api/auth/anonymous-token with header X-Client-Id: \x3Cuuid>. The response field data.token becomes your NEMO_TOKEN (100 credits, 7-day expiry).

Session: POST to https://mega-api-prod.nemovideo.ai/api/tasks/me/with-session/nemo_agent with Bearer auth and body {"task_name":"project"}. Save session_id from the response.

Confirm to the user you're connected and ready. Don't print tokens or raw JSON.

Caption Generator for Photo — Add Captions to Photos

Drop your photos or images in the chat and tell me what you need. I'll handle the AI caption generation on cloud GPUs — you don't need anything installed locally.

Here's a typical use: you send a a single product photo or portrait image, ask for add a caption to this photo and export it as a video, and about 20-40 seconds later you've got a MP4 file ready to download. The whole thing runs at 1080p by default.

One thing worth knowing — square images work best for Instagram, vertical for Stories and Reels.

Matching Input to Actions

User prompts referencing caption generator for photo, aspect ratio, text overlays, or audio tracks get routed to the corresponding action via keyword and intent classification.

User says... Action Skip SSE?
"export" / "导出" / "download" / "send me the video" → §3.5 Export
"credits" / "积分" / "balance" / "余额" → §3.3 Credits
"status" / "状态" / "show tracks" → §3.4 State
"upload" / "上传" / user sends file → §3.2 Upload
Everything else (generate, edit, add BGM…) → §3.1 SSE

Cloud Render Pipeline Details

Each export job queues on a cloud GPU node that composites video layers, applies platform-spec compression (H.264, up to 1080x1920), and returns a download URL within 30-90 seconds. The session token carries render job IDs, so closing the tab before completion orphans the job.

Base URL: https://mega-api-prod.nemovideo.ai

Endpoint Method Purpose
/api/tasks/me/with-session/nemo_agent POST Start a new editing session. Body: {"task_name":"project","language":"\x3Clang>"}. Returns session_id.
/run_sse POST Send a user message. Body includes app_name, session_id, new_message. Stream response with Accept: text/event-stream. Timeout: 15 min.
/api/upload-video/nemo_agent/me/\x3Csid> POST Upload a file (multipart) or URL.
/api/credits/balance/simple GET Check remaining credits (available, frozen, total).
/api/state/nemo_agent/me/\x3Csid>/latest GET Fetch current timeline state (draft, video_infos, generated_media).
/api/render/proxy/lambda POST Start export. Body: {"id":"render_\x3Cts>","sessionId":"\x3Csid>","draft":\x3Cjson>,"output":{"format":"mp4","quality":"high"}}. Poll status every 30s.

Accepted file types: mp4, mov, avi, webm, mkv, jpg, png, gif, webp, mp3, wav, m4a, aac.

Headers are derived from this file's YAML frontmatter. X-Skill-Source is caption-generator-for-photo, X-Skill-Version comes from the version field, and X-Skill-Platform is detected from the install path (~/.clawhub/ = clawhub, ~/.cursor/skills/ = cursor, otherwise unknown).

Include Authorization: Bearer \x3CNEMO_TOKEN> and all attribution headers on every request — omitting them triggers a 402 on export.

Error Handling

Code Meaning Action
0 Success Continue
1001 Bad/expired token Re-auth via anonymous-token (tokens expire after 7 days)
1002 Session not found New session §3.0
2001 No credits Anonymous: show registration URL with ?bind=\x3Cid> (get \x3Cid> from create-session or state response when needed). Registered: "Top up credits in your account"
4001 Unsupported file Show supported formats
4002 File too large Suggest compress/trim
400 Missing X-Client-Id Generate Client-Id and retry (see §1)
402 Free plan export blocked Subscription tier issue, NOT credits. "Register or upgrade your plan to unlock export."
429 Rate limit (1 token/client/7 days) Retry in 30s once

SSE Event Handling

Event Action
Text response Apply GUI translation (§4), present to user
Tool call/result Process internally, don't forward
heartbeat / empty data: Keep waiting. Every 2 min: "⏳ Still working..."
Stream closes Process final response

~30% of editing operations return no text in the SSE stream. When this happens: poll session state to verify the edit was applied, then summarize changes to the user.

Translating GUI Instructions

The backend responds as if there's a visual interface. Map its instructions to API calls:

  • "click" or "点击" → execute the action via the relevant endpoint
  • "open" or "打开" → query session state to get the data
  • "drag/drop" or "拖拽" → send the edit command through SSE
  • "preview in timeline" → show a text summary of current tracks
  • "Export" or "导出" → run the export workflow

Draft field mapping: t=tracks, tt=track type (0=video, 1=audio, 7=text), sg=segments, d=duration(ms), m=metadata.

Timeline (3 tracks): 1. Video: city timelapse (0-10s) 2. BGM: Lo-fi (0-10s, 35%) 3. Title: "Urban Dreams" (0-3s)

Tips and Tricks

The backend processes faster when you're specific. Instead of "make it look better", try "add a caption to this photo and export it as a video" — concrete instructions get better results.

Max file size is 200MB. Stick to JPG, PNG, WEBP, HEIC for the smoothest experience.

Export as MP4 for widest compatibility across all social platforms.

Common Workflows

Quick edit: Upload → "add a caption to this photo and export it as a video" → Download MP4. Takes 20-40 seconds for a 30-second clip.

Batch style: Upload multiple files in one session. Process them one by one with different instructions. Each gets its own render.

Iterative: Start with a rough cut, preview the result, then refine. The session keeps your timeline state so you can keep tweaking.

安全使用建议
This skill will upload images and related data to an external service (mega-api-prod.nemovideo.ai) and requires a NEMO_TOKEN bearer token to operate. Before installing, confirm you are comfortable with your images being sent to that domain and review nemo's privacy/terms. Ask the publisher to clarify the apparent metadata mismatch: SKILL.md references storing config under ~/.config/nemovideo/ and detecting install paths, but the registry metadata lists no config paths — if you prefer tokens not be persisted to disk, ask whether the skill will write the anonymous token/session to your filesystem and where. Finally, verify the API hostname is legitimate (nemovideo.ai) and avoid sending sensitive or regulated images unless you trust that service.
功能分析
Type: OpenClaw Skill Name: caption-generator-for-photo Version: 1.0.0 The skill bundle provides a legitimate integration with the nemovideo.ai API for generating captioned photo videos. It includes well-defined instructions for session management, file uploads, and rendering via the domain mega-api-prod.nemovideo.ai, with explicit safety instructions for the agent to avoid leaking tokens or raw JSON. No malicious patterns, data exfiltration, or harmful prompt injection behaviors were identified.
能力评估
Purpose & Capability
Name/description match the actions in SKILL.md: the skill sends images to a remote nemo-video rendering API and returns MP4s. Requiring a NEMO_TOKEN for Bearer auth is proportionate. However the SKILL.md frontmatter also references a local config path (~/.config/nemovideo/) while the registry metadata lists no config paths — this mismatch is unexplained.
Instruction Scope
Instructions are largely limited to API calls (anonymous token generation, session creation, upload, SSE, render), which is expected. A few instructions imply local detection/writes: deriving X-Skill-Platform by checking install paths (~/.clawhub/, ~/.cursor/skills/) and references to a local config path suggest the agent may inspect the filesystem or persist session/token state. The skill does not ask to read arbitrary unrelated files or other env vars.
Install Mechanism
No install spec and no code files — instruction-only skill. This minimizes install-time risk; nothing is downloaded or written by an installer in the bundle itself.
Credentials
The only declared required env var is NEMO_TOKEN (primary credential), which is appropriate for an API-backed renderer. However the SKILL.md instructs generating and saving an anonymous token if none exists and the frontmatter mentions a local config path (~/.config/nemovideo/), implying token persistence to disk; that extra storage access is not reflected in the registry metadata and should be clarified.
Persistence & Privilege
always is false and the skill is user-invocable only. Nothing in the instructions asks the skill to change other skills or system-wide agent settings. The only persistence implied is saving session_id / token for reuse (normal for API clients).
如何使用
  1. 确保已安装 OpenClaw(本地或 Docker 部署)
  2. 在对话框中输入安装命令:/install caption-generator-for-photo
  3. 安装完成后,直接呼叫该 Skill 的名称或使用 /caption-generator-for-photo 触发
  4. 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v1.0.0
Initial release of Caption Generator for Photo — Add Captions to Photos. - Quickly add AI-generated captions to photos and export as 1080p MP4 video. - Supports JPG, PNG, WEBP, HEIC up to 200MB; optimized for social media creators. - Fully cloud-based processing — no local setup or design tools required. - Simple onboarding with free, anonymous tokens and automated session management. - Includes robust status updates, error handling, and workflow for editing, uploading, previewing, and exporting. - User-friendly command mapping for common photo-to-caption-to-video tasks.
元数据
Slug caption-generator-for-photo
版本 1.0.0
许可证 MIT-0
累计安装 0
当前安装数 0
历史版本数 1
常见问题

Caption Generator For Photo 是什么?

Skip the learning curve of professional editing software. Describe what you want — add a caption to this photo and export it as a video — and get captioned p... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 63 次。

如何安装 Caption Generator For Photo?

在 OpenClaw 或 Claude Code 对话框中运行命令「/install caption-generator-for-photo」即可一键安装,无需额外配置。

Caption Generator For Photo 是免费的吗?

是的,Caption Generator For Photo 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。

Caption Generator For Photo 支持哪些平台?

Caption Generator For Photo 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。

谁开发了 Caption Generator For Photo?

由 peandrover adam(@peand-rover)开发并维护,当前版本 v1.0.0。

💬 留言讨论