Metadata-Version: 2.3
Name: time-lapse
Version: 9.0
Summary: Time-lapse movie assembly
Keywords: ffmpeg,photography,time-lapse
Author-email: Arne de Laat <arne@delaat.net>
Maintainer-email: Arne de Laat <arne@delaat.net>
Requires-Python: >=3.13
Description-Content-Type: text/markdown
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Other Audience
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Topic :: Multimedia :: Video :: Conversion
Requires-Dist: ffmpeg-python==0.2.0
Requires-Dist: pillow==11.0.0
Requires-Dist: coverage==7.6.10 ; extra == "dev"
Requires-Dist: mypy==1.14.1 ; extra == "dev"
Requires-Dist: graphviz ; extra == "graph"
Requires-Dist: flit==3.10.1 ; extra == "publish"
Project-URL: Homepage, https://arne.delaat.net/timelapse.html
Project-URL: Repository, https://github.com/153957/time-lapse
Provides-Extra: dev
Provides-Extra: graph
Provides-Extra: publish

# Time-Lapse assembling

[![PyPI](https://img.shields.io/pypi/v/time-lapse)](https://pypi.org/project/time-lapse/)
[![License](https://img.shields.io/github/license/153957/time-lapse)](https://github.com/153957/time-lapse/blob/main/LICENSE)
[![Build](https://img.shields.io/github/actions/workflow/status/153957/time-lapse/tests.yml?branch=main)](https://github.com/153957/time-lapse/actions)

This repo contains tools used to compile Time-lapse movies using
ffmpeg. The ffmpeg utility is controlled via the ffmpeg-python wrapper.

Example usage of this package can be found in the
[time-lapse scripts](https://github.com/153957/time-lapse-scripts) repository.

## Convert movie

Using time-lapse to find tif files, and create a movie called 'test_movie'
with 24 fps and deflickered:

    from time_lapse import output, source

    source_input = source.get_input(['*.tif'], fps=24, deflicker=7, filters=None)
    output.create_outputs(source_input, 'test_movie', verbose=False)

This can also be done via the CLI:

    timelapse --name test_movie --pattern "*.tif" --fps 24 --deflicker 7

### Inspection

By passing `verbose=True` to create outputs the following ffmpeg-python
inspection methods will be performed.

Show the ffmpeg command options ffmpeg-python would use:

    .get_args()

By using graphviz the graph from input to output can be shown using:

    .view()

## Installation

This package requires the `ffmpeg` tool to be installed.

    brew install ffmpeg

Then install this package:

    pip install time-lapse

Additionally, when using the verbose output option a graph will be
rendered using `graphviz`, this requires the Graphviz library and the
related Python package:

    brew install graphviz
    pip install time-lapse[graph]

## Codec

For near-universal compatibility the H.264 codec is used. The following
section describe some of the choices for specific configuration options.

See the ffmpeg wiki for additional information:
<https://trac.ffmpeg.org/wiki/Encode/H.264>

### Constant Rate Factor

This uses `-crf 20` to set a constant rate factor, which means the overall
quality of the movie should be constant. So bitrate varies to ensure
this. Higher value is lower quality. The quality and bit rates at this
value seem reasonable.

### Preset

`-preset slower` is used to improve the compression ratio for the selected
quality (crf), without taking too much time.

### Faststart

`-movflags +faststart` is used to allow the movie to quickly start playing,
while it is still loading or buffering.

### Quicktime support

The codec defaults to YUV 444, which is not supported by Quicktime. So
add `pix_fmt yuv420p` to fix Quicktime support.

## Input

### Select input frames

Use frames as input by giving a glob pattern which matches the desired
images. Usually these will be tiff images so use
`-pattern_type glob -i "*.tiff"`.

### Framerate

When using image sequences as input the framerate of the desired output
should be given using `-framerate 30`.

## Filters

Commonly used filters:

- Deflicker <https://ffmpeg.org/ffmpeg-filters.html#toc-deflicker>
- Scale <https://ffmpeg.org/ffmpeg-filters.html#scale>
- Crop <https://ffmpeg.org/ffmpeg-filters.html#crop>
- Drawtext <https://ffmpeg.org/ffmpeg-filters.html#drawtext-1>
- Video sizes <https://ffmpeg.org/ffmpeg-utils.html#video-size-syntax>

### Steps

The optimal order for applying deflicker/scale/watermarking is the following:

- First deflicker the video to ensure it is equally deflickered for
  all outputs
- Then scale and crop the videos to fit the desired final resolutions
- Then add the watermark (which should not be deflickered and a constant size)

### Scale video

Add scaling to ensure it fits in given dimensions. Negative values for
width or height make the encoder figure out the size by itself, keeping
the aspect ratio of the source. The integer of the negative value, i.e.
4 for -4, means that the size should be devisble by that value. TODO:
does it just scale/squish the video or crop?:

    -vf scale=1920:-2
    -vf scale=960:540:aspect..

