2019-01-20 23:07:22 +03:00
|
|
|
6.0.0
|
|
|
|
-----
|
|
|
|
|
|
|
|
Backwards Incompatible Changes
|
|
|
|
==============================
|
|
|
|
|
|
|
|
Python 3.4 dropped
|
|
|
|
^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
Python 3.4 is EOL since 2019-03-16 and no longer supported. We will not be creating
|
|
|
|
binaries, testing, or retaining compatibility with this version. The final version of
|
|
|
|
Pillow for Python 3.4 is 5.4.1.
|
|
|
|
|
|
|
|
Removed deprecated PIL.OleFileIO
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
PIL.OleFileIO was removed as a vendored file and in Pillow 4.0.0 (2017-01) in favour of
|
|
|
|
the upstream olefile Python package, and replaced with an ``ImportError``. The
|
|
|
|
deprecated file has now been removed from Pillow. If needed, install from PyPI (eg.
|
|
|
|
``pip install olefile``).
|
|
|
|
|
|
|
|
Removed deprecated ImageOps functions
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
2019-01-21 21:55:04 +03:00
|
|
|
Several undocumented functions in ``ImageOps`` were deprecated in Pillow 4.3.0 (2017-10)
|
2019-01-20 23:07:22 +03:00
|
|
|
and have now been removed: ``gaussian_blur``, ``gblur``, ``unsharp_mask``, ``usm`` and
|
|
|
|
``box_blur``. Use the equivalent operations in ``ImageFilter`` instead.
|
|
|
|
|
2019-03-02 10:22:34 +03:00
|
|
|
Removed deprecated VERSION
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
``VERSION`` (the old PIL version, always 1.1.7) has been removed. Use ``__version__``
|
|
|
|
instead.
|
|
|
|
|
2019-01-20 23:07:22 +03:00
|
|
|
API Changes
|
|
|
|
===========
|
|
|
|
|
2019-02-03 04:35:40 +03:00
|
|
|
Deprecations
|
|
|
|
^^^^^^^^^^^^
|
|
|
|
|
2019-03-02 21:18:52 +03:00
|
|
|
Python 2.7
|
|
|
|
~~~~~~~~~~
|
|
|
|
|
|
|
|
Python 2.7 reaches end-of-life on 2020-01-01.
|
|
|
|
|
|
|
|
Pillow 7.0.0 will be released on 2020-01-01 and will drop support for Python 2.7, making
|
|
|
|
Pillow 6.x the last series to support Python 2.
|
|
|
|
|
2019-02-15 00:44:07 +03:00
|
|
|
PyQt4 and PySide
|
|
|
|
~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
Qt 4 reached end-of-life on 2015-12-19. Its Python bindings are also EOL: PyQt4 since
|
|
|
|
2018-08-31 and PySide since 2015-10-14.
|
|
|
|
|
|
|
|
Support for PyQt4 and PySide has been deprecated from ``ImageQt`` and will be removed in
|
|
|
|
a future version. Please upgrade to PyQt5 or PySide2.
|
|
|
|
|
|
|
|
PIL.*ImagePlugin.__version__ attributes
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2019-02-03 04:35:40 +03:00
|
|
|
These version constants have been deprecated and will be removed in a future
|
|
|
|
version.
|
|
|
|
|
|
|
|
* ``BmpImagePlugin.__version__``
|
|
|
|
* ``CurImagePlugin.__version__``
|
|
|
|
* ``DcxImagePlugin.__version__``
|
|
|
|
* ``EpsImagePlugin.__version__``
|
|
|
|
* ``FliImagePlugin.__version__``
|
|
|
|
* ``FpxImagePlugin.__version__``
|
|
|
|
* ``GdImageFile.__version__``
|
|
|
|
* ``GifImagePlugin.__version__``
|
|
|
|
* ``IcoImagePlugin.__version__``
|
|
|
|
* ``ImImagePlugin.__version__``
|
|
|
|
* ``ImtImagePlugin.__version__``
|
|
|
|
* ``IptcImagePlugin.__version__``
|
|
|
|
* ``Jpeg2KImagePlugin.__version__``
|
|
|
|
* ``JpegImagePlugin.__version__``
|
|
|
|
* ``McIdasImagePlugin.__version__``
|
|
|
|
* ``MicImagePlugin.__version__``
|
|
|
|
* ``MpegImagePlugin.__version__``
|
|
|
|
* ``MpoImagePlugin.__version__``
|
|
|
|
* ``MspImagePlugin.__version__``
|
|
|
|
* ``PalmImagePlugin.__version__``
|
|
|
|
* ``PcdImagePlugin.__version__``
|
|
|
|
* ``PcxImagePlugin.__version__``
|
|
|
|
* ``PdfImagePlugin.__version__``
|
|
|
|
* ``PixarImagePlugin.__version__``
|
|
|
|
* ``PngImagePlugin.__version__``
|
|
|
|
* ``PpmImagePlugin.__version__``
|
|
|
|
* ``PsdImagePlugin.__version__``
|
|
|
|
* ``SgiImagePlugin.__version__``
|
|
|
|
* ``SunImagePlugin.__version__``
|
|
|
|
* ``TgaImagePlugin.__version__``
|
|
|
|
* ``TiffImagePlugin.__version__``
|
|
|
|
* ``WmfImagePlugin.__version__``
|
|
|
|
* ``XbmImagePlugin.__version__``
|
|
|
|
* ``XpmImagePlugin.__version__``
|
|
|
|
* ``XVThumbImagePlugin.__version__``
|
|
|
|
|
|
|
|
Use ``PIL.__version__`` instead.
|
2019-01-20 23:07:22 +03:00
|
|
|
|
2019-03-23 06:48:17 +03:00
|
|
|
MIME type improvements
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
Previously, all JPEG2000 images had the MIME type "image/jpx". This has now been
|
|
|
|
corrected. After the file format drivers have been loaded, ``Image.MIME["JPEG2000"]``
|
|
|
|
will return "image/jp2". ``ImageFile.get_format_mimetype`` will return "image/jpx" if
|
|
|
|
a JPX profile is present, or "image/jp2" otherwise.
|
|
|
|
|
|
|
|
Previously, all SGI images had the MIME type "image/rgb". This has now been
|
|
|
|
corrected. After the file format drivers have been loaded, ``Image.MIME["SGI"]``
|
|
|
|
will return "image/sgi". ``ImageFile.get_format_mimetype`` will return "image/rgb" if
|
|
|
|
RGB image data is present, or "image/sgi" otherwise.
|
|
|
|
|
|
|
|
MIME types have been added to the PPM format. After the file format drivers have been
|
|
|
|
loaded, ``Image.MIME["PPM"]`` will now return the generic "image/x-portable-anymap".
|
|
|
|
``ImageFile.get_format_mimetype`` will return a MIME type specific to the color type.
|
|
|
|
|
|
|
|
The TGA, PCX and ICO formats also now have MIME types: "image/x-tga", "image/x-pcx" and
|
|
|
|
"image/x-icon" respectively.
|
|
|
|
|
2019-01-20 23:07:22 +03:00
|
|
|
API Additions
|
|
|
|
=============
|
|
|
|
|
2019-03-12 12:12:19 +03:00
|
|
|
DIB file format
|
2019-03-08 13:04:01 +03:00
|
|
|
^^^^^^^^^^^^^^^
|
2019-01-20 23:07:22 +03:00
|
|
|
|
2019-03-12 12:12:19 +03:00
|
|
|
Pillow now supports reading and writing the Device Independent Bitmap file format.
|
2019-01-20 23:07:22 +03:00
|
|
|
|
2019-03-09 02:36:13 +03:00
|
|
|
Image.quantize
|
|
|
|
^^^^^^^^^^^^^^
|
|
|
|
|
2019-03-23 06:48:17 +03:00
|
|
|
The ``dither`` option is now a customisable parameter (was previously hardcoded to ``1``).
|
2019-03-12 12:12:19 +03:00
|
|
|
This parameter takes the same values used in ``Image.convert``.
|
|
|
|
|
|
|
|
New language parameter
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
2019-03-23 06:48:17 +03:00
|
|
|
These text-rendering functions now accept a ``language`` parameter to request
|
2019-03-12 12:12:19 +03:00
|
|
|
language-specific glyphs and ligatures from the font:
|
|
|
|
|
|
|
|
* ``ImageDraw.ImageDraw.multiline_text()``
|
|
|
|
* ``ImageDraw.ImageDraw.multiline_textsize()``
|
|
|
|
* ``ImageDraw.ImageDraw.text()``
|
|
|
|
* ``ImageDraw.ImageDraw.textsize()``
|
|
|
|
* ``ImageFont.ImageFont.getmask()``
|
|
|
|
* ``ImageFont.ImageFont.getsize_multiline()``
|
|
|
|
* ``ImageFont.ImageFont.getsize()``
|
2019-03-09 02:36:13 +03:00
|
|
|
|
2019-03-12 12:12:19 +03:00
|
|
|
PNG EXIF data
|
2019-03-11 13:18:36 +03:00
|
|
|
^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
EXIF data can now be read from and saved to PNG images. However, unlike other image
|
|
|
|
formats, EXIF data is not guaranteed to have been read until
|
|
|
|
:py:meth:`~PIL.Image.Image.load` has been called.
|
|
|
|
|
2019-01-20 23:07:22 +03:00
|
|
|
Other Changes
|
|
|
|
=============
|
|
|
|
|
2019-02-22 22:44:06 +03:00
|
|
|
Reading new DDS image format
|
2019-03-11 22:11:37 +03:00
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
2019-01-20 23:07:22 +03:00
|
|
|
|
2019-02-22 22:44:06 +03:00
|
|
|
Pillow can now read uncompressed RGB data from DDS images.
|
2019-03-11 20:44:55 +03:00
|
|
|
|
|
|
|
Reading TIFF with old-style JPEG compression
|
2019-03-11 22:11:37 +03:00
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
2019-03-11 20:44:55 +03:00
|
|
|
|
2019-03-23 06:48:17 +03:00
|
|
|
Added support reading TIFF files with old-style JPEG compression through LibTIFF. All
|
|
|
|
YCbCr TIFF images are now always read as RGB.
|
2019-03-23 06:51:24 +03:00
|
|
|
|
|
|
|
TIFF compression codecs
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
Support has been added for the LZMA, Zstd and WebP TIFF compression codecs.
|