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.
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: title_card
duration: 3 # optional if audio is given
audio: my/narration.wav
title: Hello, SceneWeaver!
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
fps: 25
file: something.mp4
effects:
- type: fade-out
duration: 1
Other Commands
Managing Scenes
SceneWeaver provides interactive commands to help you build your spec file quickly.
-
Add a new scene:
# Interactively prompts for ID, type, and required info sceneweaver scene add my_video.yaml # Directly specify the new scene's ID and type sceneweaver scene add my_video.yaml:new_intro title_card
-
Record audio for a scene:
# Interactively prompts to select a scene to record for sceneweaver scene audio my_video.yaml # Directly target a scene by its ID sceneweaver scene audio my_video.yaml:main_image
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
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.2-py3-none-any.whl.
File metadata
- Download URL: sceneweaver-0.2-py3-none-any.whl
- Upload date:
- Size: 37.0 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 |
b5b4854e97d24b454af990d174451c056a41355aed42fb97d5477dd36d9b9f4f
|
|
| MD5 |
a5d82349d28b8f0b2a59aae49121dce4
|
|
| BLAKE2b-256 |
80b4514b0932b0431c8cc2098ccde6460a6e3ca60d3e18446f4e20a5029b029f
|
Provenance
The following attestation bundles were made for sceneweaver-0.2-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.2-py3-none-any.whl -
Subject digest:
b5b4854e97d24b454af990d174451c056a41355aed42fb97d5477dd36d9b9f4f - Sigstore transparency entry: 685798669
- Sigstore integration time:
-
Permalink:
barebaric/sceneweaver@167cc0b1ad9634a1d11f8fb11a346716b7d096be -
Branch / Tag:
refs/tags/0.2 - Owner: https://github.com/barebaric
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@167cc0b1ad9634a1d11f8fb11a346716b7d096be -
Trigger Event:
push
-
Statement type: