A tool for creating videos from YAML specification files
Project description
SceneWeaver
SceneWeaver is a command-line tool for creating videos from a declarative YAML specification. Under the hood, it uses MoviePy to render and assemble scenes, allowing for repeatable and version-controllable video production.
For larger projects it supports modular composition and caching, and you can include other videos as well.
| Feature | |
|---|---|
| ✅ Re-usable Templates | Check the template library for a gallery. |
| ✅ Animated SVGs | Generate complex, animated graphics using templated SVG files. |
| ✅ Repeatable Production | Define videos in a version-controllable YAML specification. |
| ✅ Scene-Based Composition | Compose videos from modular scenes (images, video clips, templates, etc.). |
| ✅ Intelligent Caching | Automatically caches rendered scenes, only re-rendering what has changed. |
| ✅ Interactive CLI Tool | Interactive CLI for creating specs, adding scenes, and recording audio. |
| ✅ Audio Integration & Recording | Add audio tracks to scenes; includes a built-in recorder. |
| ✅ Annotations, Transitions & Effects | Apply text annotations, transitions, and video effects. |
Installation
sudo apt install ffmpeg portaudio19-dev # Ubuntu 24.04. May be different on other distros
pip install sceneweaver
Usage
Starting
First, create a new specification file to define your video's structure.
sceneweaver create my_video.yaml # creates a new template you can edit
sceneweaver generate my_video.yaml
Example specification
Here is a basic example of a my_video.yaml file:
settings:
width: 1920
height: 1080
fps: 30
output_file: "output.mp4"
scenes:
- id: intro_card
type: template
name: title_and_subtitle
with:
title: Hello, SceneWeaver!
subtitle: Using a built-in template
audio: my/narration.wav
transition:
type: cross-fade
duration: 1
- id: main_image
type: image
duration: 10
image: "~/path/to/your/image.png"
stretch: false # Preserves aspect ratio
width: 80 # As 80% of the screen width
annotations:
- type: text
location: bottom
content: This is a caption for the image.
cache:
max-size: "2GB"
transition:
type: cross-fade
duration: 2
- id: outro
type: video
file: something.mp4
effects:
- type: fade-out
duration: 1
Other Commands
Rendering and Cache
-
Render a single scene (for quick previews):
sceneweaver generate my_video.yaml:intro_card
-
Force re-rendering (ignoring the cache):
sceneweaver generate my_video.yaml --force
-
Clear the cache of all previously rendered scenes:
sceneweaver clean
Managing Scenes
-
Interactively add a new scene to your spec file. It will prompt for the scene type and required details.
sceneweaver scene add my_video.yaml
-
Add a new
imagescene non-interactively with a specific ID (new_intro).sceneweaver scene add my_video.yaml:new_intro image
-
Record audio for a scene. It will prompt you to select which scene from the file.
sceneweaver scene audio my_video.yaml
-
Directly record audio for the scene with the ID
main_image.sceneweaver scene audio my_video.yaml:main_image
Managing Templates
-
List all available built-in and user-created templates.
sceneweaver template list
-
Show details about a specific template, including its parameters and a usage example.
sceneweaver template info title_and_subtitle
-
Create a new, empty user template in your local configuration directory, ready for you to customize.
sceneweaver template create my_custom_title
Development
This project uses Pixi for environment and task management.
-
Setup the environment:
pixi install -
Run the app:
pixi run sceneweaver my_template.yaml
-
Common tasks (run with
pixi run <task>):test: Run the test suite.lint: Run all linters (flake8, pyflakes, pyright).format: Format the code using Ruff.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file sceneweaver-0.5-py3-none-any.whl.
File metadata
- Download URL: sceneweaver-0.5-py3-none-any.whl
- Upload date:
- Size: 159.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
14d5a79a7ca302fe71b11c43ef427a04e27409690595958edb443324d4a4c94e
|
|
| MD5 |
21cb4639fd0b9d5c276838470ca7448e
|
|
| BLAKE2b-256 |
f36e6dc0ee807cd9d0b1ebe057f30815641ced8ff8d15394a6993efee2b1acc1
|
Provenance
The following attestation bundles were made for sceneweaver-0.5-py3-none-any.whl:
Publisher:
publish-to-pypi.yml on barebaric/sceneweaver
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
sceneweaver-0.5-py3-none-any.whl -
Subject digest:
14d5a79a7ca302fe71b11c43ef427a04e27409690595958edb443324d4a4c94e - Sigstore transparency entry: 687251305
- Sigstore integration time:
-
Permalink:
barebaric/sceneweaver@ee892f6b89abca1048bf617f3ce221ed1fe70c2d -
Branch / Tag:
refs/tags/0.5 - Owner: https://github.com/barebaric
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@ee892f6b89abca1048bf617f3ce221ed1fe70c2d -
Trigger Event:
push
-
Statement type: