Skip to main content

A general-purpose programmatic animation tool

Project description

Morpho

A general-purpose programmatic animation tool

Features

  • Animate basic figures like Points, Paths, Polygons, Splines, Images, and Text
  • Helper functions to build more complex composite figures like grids
  • Tools for quickly creating custom figures that animate in precisely specified ways
  • Support for rendering and animating LaTeX.
    • Requires a LaTeX distribution to be preinstalled, as well as dvisvgm
  • Multiple tweening options and the ability to define custom tweens
  • Apply custom transformations to figures to create complex patterns
  • Support for multiple layers each with its own independent dynamic camera
  • Ability to use layers as masks for other layers
  • Color gradients, both as fills and as color gradients along paths
  • Some primitive 3D animation capability
  • Preview animations along with the ability to locate positions on screen with a click
  • Export animations as MP4, GIF, and PNG sequences at arbitrary framerates and resolutions
    • (Note: FFmpeg required to create MP4s, and Gifsicle required to make small size GIFs)

Gallery and Documentation

A gallery of animations made with Morpho is available here. For more, you can also take a look at the YouTube channels Morphocular and Serpentine Integral, which use Morpho to create most of the animations.

Documentation is currently limited, but there are a few guides you can look thru which will help you learn how to use Morpho and get you started making your own animations.

Installation

Morpho is a library for Python and works on Python 3.8 or higher and requires Pycairo to run. For Windows users, Morpho and all its basic dependencies, including Pycairo, should be installable via a simple pip command:

pip3 install morpholib

Installation on other platforms has not been well-tested, unfortunately, and does not appear to be as straightforward. For now, I think the best method is to first see if you can install Pycairo separately (for instructions on how to do so, see this), test that the Pycairo installation is working, and then attempt to install Morpho via the above pip command.

Softer requirements

If you want to export animations as MP4s or small-sized GIFs, you will need to install FFmpeg for MP4 and/or Gifsicle for GIF. But if that doesn't matter to you (or if you just want to try out Morpho), you can still preview animations and export them as PNG sequences and large-sized GIFs just using the base installation of Morpho.

Please note that FFmpeg and Gifsicle will need to be added to your PATH environment variable for Morpho to be able to access them by default.

For Morpho to be able to parse LaTeX code, you must have a LaTeX distribution installed along with dvisvgm. But if you're okay with not using Morpho's LaTeX features, this requirement is optional.

Testing the installation

To see if it installed correctly, try running the following Python code:

import morpholib as morpho
morpho.importAll()
morpho.sample.play()

If you see an animation of a morphing grid appear on your screen, congratulations! Morpho should be installed and working properly.

License

This project is licensed under the terms of the MIT license.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

morpholib-0.7.0.dev1.tar.gz (212.7 kB view details)

Uploaded Source

Built Distribution

morpholib-0.7.0.dev1-py3-none-any.whl (223.8 kB view details)

Uploaded Python 3

File details

Details for the file morpholib-0.7.0.dev1.tar.gz.

File metadata

  • Download URL: morpholib-0.7.0.dev1.tar.gz
  • Upload date:
  • Size: 212.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.8.1

File hashes

Hashes for morpholib-0.7.0.dev1.tar.gz
Algorithm Hash digest
SHA256 05fdd50c4bad966a95fd56196dae9e3209f08a90bfa204706ff967cef63d59ec
MD5 5af3debd8e063e75ee5c48b7bdd91b50
BLAKE2b-256 21a0252c0118bd5af707de3b0ed0fd5ce0c4bae3862a6d1806fbb0cf44254a7e

See more details on using hashes here.

File details

Details for the file morpholib-0.7.0.dev1-py3-none-any.whl.

File metadata

File hashes

Hashes for morpholib-0.7.0.dev1-py3-none-any.whl
Algorithm Hash digest
SHA256 1162df81b3228b179845ca08e3d339262dd1471b11dc5a68e65456365a646e52
MD5 317da5d1cb22755e06212f0f9754766a
BLAKE2b-256 a2c4334f6fb962a4c1cac62bc976bf7e5f26f6a2b8bf484502a6a1e96110598b

See more details on using hashes here.

Supported by

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