LiberTEM/LiberTEM

View on GitHub
src/libertem/common/viz.py

Summary

Maintainability
A
0 mins
Test Coverage
from io import BytesIO
from typing import Optional

from PIL import Image


def encode_image(result, save_kwargs: Optional[dict] = None) -> BytesIO:
    """
    Save the RGBA data in ``result`` to an image with parameters ``save_kwargs``
    passed to ``PIL.Image.save``.

    Parameters
    ----------
    result : numpy.ndarray
        Array of RGB values; shape (height, width, 3)

    save_kwargs : dict or None
        dict of kwargs passed to Pillow when saving the image, can be used to set
        the file format, quality, ...

    Returns
    -------

    BytesIO
        a buffer containing the result image (as PNG/JPG/... depending on save_kwargs)
    """
    if save_kwargs is None:
        save_kwargs = {'format': 'png'}
    # see also: https://stackoverflow.com/a/10967471/540644
    im = Image.fromarray(result)
    buf = BytesIO()
    im = im.convert(mode="RGB")
    im.save(buf, **save_kwargs)
    buf.seek(0)
    return buf