Skip to main content

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 image scene 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

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sceneweaver-0.5-py3-none-any.whl (159.7 kB view details)

Uploaded Python 3

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

Hashes for sceneweaver-0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 14d5a79a7ca302fe71b11c43ef427a04e27409690595958edb443324d4a4c94e
MD5 21cb4639fd0b9d5c276838470ca7448e
BLAKE2b-256 f36e6dc0ee807cd9d0b1ebe057f30815641ced8ff8d15394a6993efee2b1acc1

See more details on using hashes here.

Provenance

The following attestation bundles were made for sceneweaver-0.5-py3-none-any.whl:

Publisher: publish-to-pypi.yml on barebaric/sceneweaver

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page