Tree @develop-0.5 (Download .tar.gz)
kinoje
Version 0.5. Subject to backwards-incompatible changes without notice.
kinoje is a templating-based animation tool. A provided template is filled out once for each frame of the animation; the result of the template expansion is used to create a still image; and the resulting sequence of images is compiled into the finished movie.
Quick Start
The following are required:
- Python 2.7 or 3.x — to run the script
- PyYAML and Jinja2 — to fill out the templates
- something to create images from filled-out templates — typically POV-Ray or rsvg
- ffmpeg or ImageMagick — to compile the images into a movie file
You might also find VLC useful, for viewing the final movie file.
On Ubuntu 16.04, you can install these with:
pip install --user Jinja2 PyYAML
sudo apt install povray povray-includes librsvg2 ffmpeg imagemagick vlc
(Or, if you use Docker, you can use the Docker image from this dockerhub repository following the instructions given on that page.)
Once installed, you can run the tool from the repository directory like so:
bin/kinoje eg/moebius.yaml
Since no output filename was given, kinoje assumes MP4 format and automatically picks a reasonable
filename, in this case moebius.mp4
.
You can also ask it to create a GIF by specifying an output filename with that as its file extension:
bin/kinoje eg/squares.yaml -o squares.gif
Theory of Operation
The kinoje
executable actually calls 3 other executables:
kinoje-expand
fills out the template multiple times, once for each frame of the movie, and saves the expanded templates (which we call "instants") into a directory.kinoje-render
takes a directory of instants and creates a set of images, one for each instant, in another directory. It calls a rendering command specified in the config to do this.kinoje-compile
takes a directory of images and turns them into a movie file (.mp4
or.gif
).
These executables can also be called directly, if you e.g. already have a directory of instants you want to render and compile into a final movie.
File Format
The input config file must contain, at the minimum, a key called template
containing the template,
and a key duration
which specifies the duration in seconds of the movie. It may also contain
the following keys, or if not, the following defaults will be used:
start
: 0.0stop
: 1.0fps
: 25.0width
: 320height
: 200
The template is typically a multi-line string in Jinja2 syntax, which will be filled out once for each frame. The context with which it will be filled out is constructed as follows:
-
t
is a floating point value which will vary from 0.0 on the first frame to 1.0 on the last frame. It is this value which will typically drive the animation. For example, if the animation consists of moving a circle from x=0 to x=10, the part of the template which gives the x co-ordinate of the circle would be written as{{ t * 10.0 }}
.And actually this is not 100% true.
t
would be 1.0 on the frame after the last frame which, by definition, is never rendered. On the last frame, it is 1.0 less a small value, which we could call the t-delta, and which varies based on the duration and the frame rate. -
math
, which is Python's math module, and which can be used to access functions such assin
. -
tween
, which is a function which is currently undocumented. -
fmod
, which is a function which is currently undocumented.
Other configuration options:
duration
gives the duration, in seconds, to make the movie. If omitted, it needs to be supplied on the command-line with the--duration
option.
No further documentation on how to use the tool will be given, as it is all very subject to change right now.
Commit History
@develop-0.5
git clone https://git.catseye.tc/kinoje/
- Prefer rsvg-convert over inkscape. Chris Pressey 5 years ago
- After some experimentation, we have this. Chris Pressey 5 years ago
- Merge branch 'docker-experiment' into develop-0.5 Chris Pressey 5 years ago
- Update dependencies. Chris Pressey 5 years ago
- First pass at a Dockerfile. Chris Pressey 5 years ago
- Bump version number. Chris Pressey 6 years ago
- Fix bug with libdir when the yaml file is in the current directory. Chris Pressey 6 years ago
- Bump version number. Chris Pressey 6 years ago
- Merge pull request #2 from catseye/develop-0.3 Chris Pressey (commit: GitHub) 6 years ago
- Can't resist defining a base class and inheriting from it. Chris Pressey 6 years ago