Stop Motion Video Maker

v1.0.0

Turn a sequence of photos or video frames into a fluid stop-motion-video-maker animation in minutes. Upload your images or footage in mp4, mov, avi, webm, or...

0· 75·0 current·0 all-time
Security Scan
VirusTotalVirusTotal
Benign
View report →
OpenClawOpenClaw
Benign
medium confidence
Purpose & Capability
Name/description (stop-motion video maker) matches what the instructions do: upload images/video, call a NemoVideo cloud API, create sessions, upload files, render exports. Declared config path (~/.config/nemovideo/) and a single service token (NEMO_TOKEN) are expected for a cloud backend.
Instruction Scope
Instructions stay within the expected scope: check or generate a client_id in ~/.config/nemovideo/, obtain an anonymous token, create sessions, upload files, poll renders and check credits/state. One point to watch: the runtime describes constructing a workspace claim URL that could include tokens in query parameters — the doc says 'Don't expose tokens', but care must be taken to avoid leaking NEMO_TOKEN in generated links or logs. The skill also reads its own YAML frontmatter and detects install paths for attribution, which is reasonable but requires local file/path reads.
Install Mechanism
Instruction-only skill with no install steps or downloaded code. That minimizes disk-write/exec risk.
Credentials
Only a single service credential (NEMO_TOKEN) and a per-user client_id stored under ~/.config/nemovideo/ are used — appropriate for a cloud API client. Minor metadata inconsistency: the frontmatter/registry shows an empty requires.env list but also declares NEMO_TOKEN as primary credential; this is a bookkeeping mismatch but not a functional red flag.
Persistence & Privilege
always:false (not force-included). The skill requests permission to store a client_id under ~/.config/nemovideo/ and to persist the obtained token for session use — this is ordinary for a cloud-backed skill and does not modify other skills or system-wide settings.
Assessment
This skill appears to be what it says: a cloud-backed stop-motion uploader/renderer that needs a NemoVideo token and will save a small client_id file under ~/.config/nemovideo/. Before installing: 1) Confirm you trust nemovideo.com / mega-api-prod.nemovideo.ai as your files and images will be uploaded to their service. 2) Verify how shared workspace links are constructed — ensure the token is never embedded in public URLs or logs. 3) Note the metadata mismatch (NEMO_TOKEN listed as primaryEnv but not in requires.env); ask the publisher to clarify which env var is required and how tokens are stored. 4) If you want to avoid cloud uploads, do not use this skill — it intentionally sends media to a remote API. If any of the above are unacceptable, do not install or use the skill.

Like a lobster shell, security has layers — review code before you run it.

Runtime requirements

🎞️ Clawdis
Primary envNEMO_TOKEN
latestvk97de74bk8xpdhwkabh8dd1r4n83wn1c
75downloads
0stars
1versions
Updated 2w ago
v1.0.0
MIT-0

Getting Started

Welcome! 🎞️ Ready to turn your photos or footage into a stop-motion animation? Upload your images or video file and tell me your preferred frame rate or style — let's build something frame-worthy together!

Try saying:

  • "I have 120 JPEG photos of a clay figure I animated on my desk — can you turn them into a stop-motion video at 12 frames per second?"
  • "Convert this timelapse MOV file into a stop-motion style video with a slightly choppy, hand-crafted look at 8 fps."
  • "I want to make a stop-motion product reveal using 60 still images of a rotating sneaker — output it as an MP4 that loops cleanly."

Quick Start Setup

This skill connects to NemoVideo's cloud backend. On first use, set up the connection automatically and let the user know ("Connecting to NemoVideo...").

Token check: Look for NEMO_TOKEN in the environment. If found, skip to session creation. Otherwise:

  • Read ~/.config/nemovideo/client_id or generate a UUID and save it there
  • POST https://mega-api-prod.nemovideo.ai/api/auth/anonymous-token with X-Client-Id header
  • Extract data.token from the response — this is your NEMO_TOKEN (100 free credits, 7-day expiry)

Session: POST /api/tasks/me/with-session/nemo_agent at the same host with Bearer auth and body {"task_name":"project"}. Keep the returned session_id for all operations.

Let the user know with a brief "Ready!" when setup is complete. Don't expose tokens or raw API output.

Frame by Frame, Your Story Comes Alive

Stop-motion animation has a charm that no smooth CGI can replicate — the slight imperfections, the tactile feel, the sense that human hands crafted every single frame. This skill is built specifically to help you harness that magic without needing a film school degree or expensive editing software.

Upload a batch of photos you've shot on your phone, a timelapse clip, or even a short video you want to re-sequence as a stop-motion piece. You control the frame rate to set the pace — slow and dreamy or fast and snappy — and the skill stitches everything together into a clean, exportable animation ready for social media, presentations, or personal projects.

Whether you're animating LEGO figures on your kitchen table, documenting a painting coming together stroke by stroke, or building a product reveal for your brand, this tool gives you a straightforward path from a pile of still images to a finished stop-motion video that actually looks intentional and polished.

Routing Your Animation Requests

Each request — whether you're sequencing frames, adjusting frame rate, or exporting your flipbook animation — is parsed and routed to the matching stop motion pipeline endpoint automatically.

User says...ActionSkip 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

NemoVideo Backend Reference

The NemoVideo backend stitches your uploaded still images into a timed frame sequence, applying your chosen fps and transition settings to render the final stop motion output. Every frame order, dwell time, and export format you specify flows directly through the NemoVideo API.

Skill attribution — read from this file's YAML frontmatter at runtime:

  • X-Skill-Source: stop-motion-video-maker
  • X-Skill-Version: from frontmatter version
  • X-Skill-Platform: detect from install path (~/.clawhub/clawhub, ~/.cursor/skills/cursor, else unknown)

All requests must include: Authorization: Bearer <NEMO_TOKEN>, X-Skill-Source, X-Skill-Version, X-Skill-Platform. Missing attribution headers will cause export to fail with 402.

API base: https://mega-api-prod.nemovideo.ai

Create session: POST /api/tasks/me/with-session/nemo_agent — body {"task_name":"project","language":"<lang>"} — returns task_id, session_id. After creating a session, give the user a link: https://nemovideo.com/workspace/claim?token=&task=<task_id>&session=<session_id>&skill_name=stop-motion-video-maker&skill_version=1.0.0&skill_source=<platform>

Send message (SSE): POST /run_sse — body {"app_name":"nemo_agent","user_id":"me","session_id":"<sid>","new_message":{"parts":[{"text":"<msg>"}]}} with Accept: text/event-stream. Max timeout: 15 minutes.

Upload: POST /api/upload-video/nemo_agent/me/<sid> — file: multipart -F "files=@/path", or URL: {"urls":["<url>"],"source_type":"url"}

Credits: GET /api/credits/balance/simple — returns available, frozen, total

Session state: GET /api/state/nemo_agent/me/<sid>/latest — key fields: data.state.draft, data.state.video_infos, data.state.generated_media

Export (free, no credits): POST /api/render/proxy/lambda — body {"id":"render_<ts>","sessionId":"<sid>","draft":<json>,"output":{"format":"mp4","quality":"high"}}. Poll GET /api/render/proxy/lambda/<id> every 30s until status = completed. Download URL at output.url.

Supported formats: mp4, mov, avi, webm, mkv, jpg, png, gif, webp, mp3, wav, m4a, aac.

SSE Event Handling

EventAction
Text responseApply GUI translation (§4), present to user
Tool call/resultProcess internally, don't forward
heartbeat / empty data:Keep waiting. Every 2 min: "⏳ Still working..."
Stream closesProcess 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.

Backend Response Translation

The backend assumes a GUI exists. Translate these into API actions:

Backend saysYou do
"click [button]" / "点击"Execute via API
"open [panel]" / "打开"Query session state
"drag/drop" / "拖拽"Send edit via SSE
"preview in timeline"Show track summary
"Export button" / "导出"Execute 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)

Error Handling

CodeMeaningAction
0SuccessContinue
1001Bad/expired tokenRe-auth via anonymous-token (tokens expire after 7 days)
1002Session not foundNew session §3.0
2001No creditsAnonymous: show registration URL with ?bind=<id> (get <id> from create-session or state response when needed). Registered: "Top up at nemovideo.ai"
4001Unsupported fileShow supported formats
4002File too largeSuggest compress/trim
400Missing X-Client-IdGenerate Client-Id and retry (see §1)
402Free plan export blockedSubscription tier issue, NOT credits. "Register at nemovideo.ai to unlock export."
429Rate limit (1 token/client/7 days)Retry in 30s once

Performance Notes

Large image sets: Uploading sequences of 200+ high-resolution images will take longer to process. For faster results, resize images to 1920×1080 or lower before uploading — stop-motion animation rarely requires 4K source frames to look great at typical playback sizes.

Frame rate and file size: Lower frame rates (8–12 fps) produce smaller output files and are stylistically appropriate for most stop-motion aesthetics. Higher frame rates (18–24 fps) increase file size and processing time but create smoother motion, which suits product photography or nature timelapse conversions.

Video source files: When converting an existing mp4, mov, avi, webm, or mkv file into a stop-motion style, the skill extracts individual frames and re-sequences them at your target fps. Very long source videos (over 5 minutes) may be trimmed or require you to specify a clip range to keep processing manageable.

Export format: The default output is mp4 (H.264), which offers broad compatibility across devices, platforms, and social media upload tools.

Frequently Asked Questions

What file types can I upload? You can upload images in common formats (JPG, PNG) as a sequence, or existing video files in mp4, mov, avi, webm, or mkv that you'd like re-rendered as stop-motion.

How many frames do I need for a good stop-motion video? It depends on your desired length and frame rate. At 12 fps, 60 images gives you a 5-second clip. For smoother motion at 24 fps, plan for more frames. The skill works well anywhere from 8 fps (classic choppy stop-motion) to 24 fps (fluid animation).

Can I add music or a voiceover? Currently the skill focuses on the visual stop-motion assembly — frame sequencing, timing, and export. Audio layering is best handled in a secondary editing step after export.

Will the output loop? Yes — you can request a seamless loop output, which is especially useful for social media posts, GIFs converted from the video, or display installations.

Comments

Loading comments...