Skip to main content

Yummy Optimizer for Gorgeous Assets

Project description

Github Discord PYPI Version Build Status Black License

YOGA is a command-line tool and a library that can:

  • convert and optimize images from various format to JPEG, PNG and WEBP,

  • convert and optimize 3D models from various formats to glTF and GLB.

Images are opened using Pillow and optimized using Guetzli (for JPEGs), Zopflipng (for PNGs) and libwebp (for WEBPs).

3D Models are converted and optimized using assimp. If models contain or reference images, they are processed by YOGA’s image optimizer.

EXAMPLE: Converting and optimizing an image from CLI:

yoga  image  input.png  output.png
yoga  image  --output-format=jpeg  --jpeg-quality=84  input.png  output.jpg
yoga  image  --help

EXAMPLE: Converting and optimizing a 3D model from CLI:

yoga  model  input.fbx  output.glb
yoga  model  --no-graph-optimization  --no-meshes-optimization  --image-output-format=jpeg  --image-jpeg-quality=84  input.fbx  output.glb
yoga  model  --help

Install

Documentation

Changelog

  • [NEXT] (changes on master that have not been released yet):

    • nothing yet

  • 1.1.0:

    • JPEG Optimization:

      • Honor the JPEG orientation EXIF tag

      • JPEG optimization has been improved by using some optimizations from MozJPEG after the Guetzli encoding (from 2.4 % to 7.3 % of additional size reduction)

    • PNG Optimization:

      • PNG -> PNG optimization: YOGA cannot output PNGs larger than the input ones

      • YOGA can no more output a PNG larger than the input one when performing a PNG to PNG optimization

    • CLI:

      • Allow to cancel an optimization using Ctrl+C (NOTE: may not work on Windows)

      • Add a --version option to get YOGA’s version

      • Improve yoga --help usage

    • Python versions:

      • Python 2.7 support dropped

    • NOTE for packagers:

  • 1.0.0:

    • WEBP (lossy and lossless) images supported as output format

    • PNG default optimization preset changed to a 10× faster preset (old preset stil available with --png-slow-optimization flag)

    • New model flag --no-fix-infacing-normals to disable Assimp’s “fix infacing normals” postprocess (#32, #33)

    • Show CLI usage when no parameter given

    • Developer documentation improved (#31)

    • ASSIMP library updated

    • WARNING: This is the last version to actively support Python 2.7!

  • 0.11.1:

    • Automated workflow for deploying the PyPI packages

    • Wheel are now distributed on PyPI

  • 0.11.0:

    • Allows to build YOGA on Windows

    • Scripts and workflow to build Windows standalone versions

  • 0.10.2:

    • Updates assimp and python libraries

  • 0.10.1:

    • Fixes an issue that occures when output file does not already exist

  • 0.10.0:

    • Prevent overwriting of the output file when an error occurs (#17)

    • Unicode path support (#16)

  • 0.10.0b1:

    • Verbose and quiet modes,

    • Allows to pass textures from memory instead of looking on the filesystem,

    • Allows to pass a fallback texture instead of raising an error.

  • 0.9.1b1:

    • Automatic selection of the output format (png or jpeg),

    • Prevent duplication of textures that are shared between materials,

    • Fixes Windows paths of textures.

  • 0.9.0b1: First release (only GLB output for models, no image auto output format)

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

yoga-1.1.0.tar.gz (2.9 MB view hashes)

Uploaded Source

Built Distributions

yoga-1.1.0-cp39-cp39-win_amd64.whl (2.2 MB view hashes)

Uploaded CPython 3.9 Windows x86-64

yoga-1.1.0-cp39-cp39-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (6.5 MB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.12+ x86-64

yoga-1.1.0-cp39-cp39-manylinux_2_12_i686.manylinux2010_i686.whl (6.7 MB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.12+ i686

yoga-1.1.0-cp39-cp39-macosx_10_14_x86_64.whl (5.5 MB view hashes)

Uploaded CPython 3.9 macOS 10.14+ x86-64

yoga-1.1.0-cp38-cp38-win_amd64.whl (2.2 MB view hashes)

Uploaded CPython 3.8 Windows x86-64

yoga-1.1.0-cp38-cp38-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (6.5 MB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.12+ x86-64

yoga-1.1.0-cp38-cp38-manylinux_2_12_i686.manylinux2010_i686.whl (6.7 MB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.12+ i686

yoga-1.1.0-cp38-cp38-macosx_10_14_x86_64.whl (5.5 MB view hashes)

Uploaded CPython 3.8 macOS 10.14+ x86-64

yoga-1.1.0-cp37-cp37m-win_amd64.whl (2.2 MB view hashes)

Uploaded CPython 3.7m Windows x86-64

yoga-1.1.0-cp37-cp37m-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (6.5 MB view hashes)

Uploaded CPython 3.7m manylinux: glibc 2.12+ x86-64

yoga-1.1.0-cp37-cp37m-manylinux_2_12_i686.manylinux2010_i686.whl (6.7 MB view hashes)

Uploaded CPython 3.7m manylinux: glibc 2.12+ i686

yoga-1.1.0-cp37-cp37m-macosx_10_14_x86_64.whl (5.5 MB view hashes)

Uploaded CPython 3.7m macOS 10.14+ x86-64

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