Skip to main content

Convert image to High Efficiency Image (HEIC/AVIF) and back with ease.

Project description

Heiya

A one line solution for photographers who are looking to replace their JPEGs with High Efficiency Images(HEIs).

Introduction

High Efficiency Image (HEI) - Ya!

Get it?

It is unbelieveable that JPEG is from... last century. And the majority of cameras in the current age shoot JPG. Some can encode using HEIC (iPhone, Fujifilm X-H2S, ...), but that codec is inside a paywall. Most cameras do not support AVIF, but it is the future for image codec and many operating system already support AV1 (and therefore AVIF).

HEIC and AVIF are what is called "High Efficiency Images", and can result in file size 10x less than traditional JPEGs. However, there is no easy solution to simply convert JPEG/TIFF to HEIC/AVIF and preserve all the metadata.

Heiya is an open source wrapper for easy High Efficiency Image (AVIF/HEIC) to and from JPG conversion. It is developed for photographers to build a more automatic and space saving pipeline.

Install Heiya

Install from PIP

pip install heiya

System Requirements

Due to some of the current dependencies of Heiya only runs on macOS, some features might not be available in Windows. Heiya is developed on macOS and isn't tested on Linux or other OS.

Examples

Getting Started

import heiya

Define Source Directory

# Option 1: Define it by yourself
source_dir = ""

# Option 2: Get the directory directly from the clipboard
import pyperclip as clip

if source_dir == "":
    source_dir = clip.paste()

Batch JPG/TIF -> HEI in directory

heiya.to_hei.convert_image_in_dir(source_dir, source_tif=False, source_jpg=True, 
                                  target_hif=False, target_avif=True)

Batch IMG -> HEI in directory using depth

Example: 
    /Photos/2022/01/20220105/img1.jpg, ...
    Then with source_dir = "/Photos":
        depth = 0 -> "/Photos"
        depth = 1 -> "/Photos/2022"
        depth = 2 -> "/Photos/2022/01"
        depth = 3 -> "/Photos/2022/01/20220105"
heiya.to_hei.convert_all_sub_folders_to_hei(source_dir, source_tif=False, source_jpg=False, 
                                            target_hif=False, target_avif=False, depth=2)

Batch HEI -> JPG in directory

heiya.from_hei.convert_hei_in_dir_to_jpg(source_dir, source_hif=False, 
                                         source_avif=False, fix_rotation=True)

Batch JPG -> HEI -> JPG in directory

heiya.tools.convert_jpg_to_he_jpg(source_dir, use_hif=False, 
                                  use_avif=True, preserve_original_jpg=True)

Delete files with a specific extension in directory

heiya.tools.delete_image_in_dir(source_dir, tif=False, jpg=False, hif=False, avif=False)

Change log

NOTE: Not production ready yet.

[0.0.6] - 2022-10-02

  • Added extensions and tools to __init__.py to fix referencing issue.

[0.0.5] - 2022-10-02

  • Removed the requirement for glob.

[0.0.4] - 2022-10-02

  • Removed the requirement for os.

[0.0.3] - 2022-10-02

  • Code cleanup.

[0.0.2] - 2022-10-02

  • Initial upload.

[0.0.1] - 2022-10-01

  • Created the project.

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

heiya-0.0.6.tar.gz (11.5 kB view details)

Uploaded Source

Built Distribution

heiya-0.0.6-py3-none-any.whl (12.5 kB view details)

Uploaded Python 3

File details

Details for the file heiya-0.0.6.tar.gz.

File metadata

  • Download URL: heiya-0.0.6.tar.gz
  • Upload date:
  • Size: 11.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.8.13

File hashes

Hashes for heiya-0.0.6.tar.gz
Algorithm Hash digest
SHA256 931904f5c3e4ee52b7ab44006c6ce7bddc9c67fd594dd53dd0c20e353c685333
MD5 4e33e73a5593f078f19a10fd082ab8d2
BLAKE2b-256 6e7db231696ebd70eb3b33d829202308855564c4eb3e73db7bb1f1b642a02e16

See more details on using hashes here.

File details

Details for the file heiya-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: heiya-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 12.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.8.13

File hashes

Hashes for heiya-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 1b55b291caf3ad8d8182e1919f902a2e84e0598534316e5140504f8e43bd8070
MD5 d90301d305e3adb3613b888becbb6b37
BLAKE2b-256 1d7ce618ac9974b44237a6f70659e7f9530be44add1261f46270ea2e9a6152a4

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