Pillow/docs/releasenotes/2.7.0.rst

175 lines
7.3 KiB
ReStructuredText
Raw Normal View History

2015-03-28 14:22:14 +03:00
2.7.0
=====
2014-11-29 03:58:52 +03:00
2015-01-03 01:46:35 +03:00
Sane Plugin
-----------
2015-10-11 13:24:35 +03:00
The Sane plugin has now been split into its own repo:
https://github.com/python-pillow/Sane .
2015-01-03 01:46:35 +03:00
Png text chunk size limits
--------------------------
To prevent potential denial of service attacks using compressed text
chunks, there are now limits to the decompressed size of text chunks
decoded from PNG images. If the limits are exceeded when opening a PNG
2015-10-11 13:24:35 +03:00
image a ``ValueError`` will be raised.
Individual text chunks are limited to
:py:attr:`PIL.PngImagePlugin.MAX_TEXT_CHUNK`, set to 1MB by
default. The total decompressed size of all text chunks is limited to
:py:attr:`PIL.PngImagePlugin.MAX_TEXT_MEMORY`, which defaults to
64MB. These values can be changed prior to opening PNG images if you
know that there are large text blocks that are desired.
2014-11-29 03:58:52 +03:00
Image resizing filters
----------------------
Image resizing methods :py:meth:`~PIL.Image.Image.resize` and
:py:meth:`~PIL.Image.Image.thumbnail` take a ``resample`` argument, which tells
2014-12-04 12:04:22 +03:00
which filter should be used for resampling. Possible values are:
2020-06-22 09:45:18 +03:00
:py:data:`PIL.Image.NEAREST`, :py:data:`PIL.Image.BILINEAR`,
:py:data:`PIL.Image.BICUBIC` and :py:data:`PIL.Image.ANTIALIAS`.
2014-12-04 12:04:22 +03:00
Almost all of them were changed in this version.
2014-12-04 12:04:22 +03:00
Bicubic and bilinear downscaling
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
2014-11-29 03:58:52 +03:00
2020-06-22 09:45:18 +03:00
From the beginning :py:data:`~PIL.Image.BILINEAR` and
:py:data:`~PIL.Image.BICUBIC` filters were based on affine transformations
2014-12-04 12:04:22 +03:00
and used a fixed number of pixels from the source image for every destination
2020-06-22 09:45:18 +03:00
pixel (2x2 pixels for :py:data:`~PIL.Image.BILINEAR` and 4x4 for
:py:data:`~PIL.Image.BICUBIC`). This gave an unsatisfactory result for
2014-12-04 12:04:22 +03:00
downscaling. At the same time, a high quality convolutions-based algorithm with
2020-06-22 09:45:18 +03:00
flexible kernel was used for :py:data:`~PIL.Image.ANTIALIAS` filter.
2014-12-04 12:04:22 +03:00
Starting from Pillow 2.7.0, a high quality convolutions-based algorithm is used
for all of these three filters.
If you have previously used any tricks to maintain quality when downscaling with
2020-06-22 09:45:18 +03:00
:py:data:`~PIL.Image.BILINEAR` and :py:data:`~PIL.Image.BICUBIC` filters
2014-12-04 12:04:22 +03:00
(for example, reducing within several steps), they are unnecessary now.
2014-11-29 03:58:52 +03:00
Antialias renamed to Lanczos
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
2020-06-22 09:45:18 +03:00
A new :py:data:`PIL.Image.LANCZOS` constant was added instead of
:py:data:`~PIL.Image.ANTIALIAS`.
2020-06-22 09:45:18 +03:00
When :py:data:`~PIL.Image.ANTIALIAS` was initially added, it was the only
2014-12-01 02:23:31 +03:00
high-quality filter based on convolutions. It's name was supposed to reflect
2014-12-04 12:04:22 +03:00
this. Starting from Pillow 2.7.0 all resize method are based on convolutions.
All of them are antialias from now on. And the real name of the
2020-06-22 09:45:18 +03:00
:py:data:`~PIL.Image.ANTIALIAS` filter is Lanczos filter.
2020-06-22 09:45:18 +03:00
The :py:data:`~PIL.Image.ANTIALIAS` constant is left for backward compatibility
and is an alias for :py:data:`~PIL.Image.LANCZOS`.
2014-11-29 03:58:52 +03:00
Lanczos upscaling quality
^^^^^^^^^^^^^^^^^^^^^^^^^
2020-06-22 09:45:18 +03:00
The image upscaling quality with :py:data:`~PIL.Image.LANCZOS` filter was
almost the same as :py:data:`~PIL.Image.BILINEAR` due to bug. This has been fixed.
2014-11-29 03:58:52 +03:00
Bicubic upscaling quality
^^^^^^^^^^^^^^^^^^^^^^^^^
2020-06-22 09:45:18 +03:00
The :py:data:`~PIL.Image.BICUBIC` filter for affine transformations produced
sharp, slightly pixelated image for upscaling. Bicubic for convolutions is
more soft.
2014-11-29 03:58:52 +03:00
Resize performance
^^^^^^^^^^^^^^^^^^
2014-12-04 12:04:22 +03:00
In most cases, convolution is more a expensive algorithm for downscaling
because it takes into account all the pixels of source image. Therefore
2020-06-22 09:45:18 +03:00
:py:data:`~PIL.Image.BILINEAR` and :py:data:`~PIL.Image.BICUBIC` filters'
2014-12-04 12:04:22 +03:00
performance can be lower than before. On the other hand the quality of
2020-06-22 09:45:18 +03:00
:py:data:`~PIL.Image.BILINEAR` and :py:data:`~PIL.Image.BICUBIC` was close to
:py:data:`~PIL.Image.NEAREST`. So if such quality is suitable for your tasks
you can switch to :py:data:`~PIL.Image.NEAREST` filter for downscaling,
2014-12-04 12:04:22 +03:00
which will give a huge improvement in performance.
2014-11-30 20:31:33 +03:00
2014-12-04 12:04:22 +03:00
At the same time performance of convolution resampling for downscaling has been
improved by around a factor of two compared to the previous version.
2020-06-22 09:45:18 +03:00
The upscaling performance of the :py:data:`~PIL.Image.LANCZOS` filter has
remained the same. For :py:data:`~PIL.Image.BILINEAR` filter it has improved by
1.5 times and for :py:data:`~PIL.Image.BICUBIC` by four times.
2014-11-30 20:31:33 +03:00
2014-11-29 03:58:52 +03:00
Default filter for thumbnails
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
2014-12-04 12:04:22 +03:00
In Pillow 2.5 the default filter for :py:meth:`~PIL.Image.Image.thumbnail` was
2020-06-22 09:45:18 +03:00
changed from :py:data:`~PIL.Image.NEAREST` to :py:data:`~PIL.Image.ANTIALIAS`.
2014-12-04 12:04:22 +03:00
Antialias was chosen because all the other filters gave poor quality for
2020-06-22 09:45:18 +03:00
reduction. Starting from Pillow 2.7.0, :py:data:`~PIL.Image.ANTIALIAS` has been
replaced with :py:data:`~PIL.Image.BICUBIC`, because it's faster and
:py:data:`~PIL.Image.ANTIALIAS` doesn't give any advantages after
2014-12-04 12:04:22 +03:00
downscaling with libjpeg, which uses supersampling internally, not convolutions.
2014-12-04 12:04:22 +03:00
Image transposition
-------------------
2014-11-29 03:58:52 +03:00
2020-06-22 09:45:18 +03:00
A new method :py:data:`PIL.Image.TRANSPOSE` has been added for the
:py:meth:`~PIL.Image.Image.transpose` operation in addition to
2020-06-22 09:45:18 +03:00
:py:data:`~PIL.Image.FLIP_LEFT_RIGHT`, :py:data:`~PIL.Image.FLIP_TOP_BOTTOM`,
:py:data:`~PIL.Image.ROTATE_90`, :py:data:`~PIL.Image.ROTATE_180`,
:py:data:`~PIL.Image.ROTATE_270`. :py:data:`~PIL.Image.TRANSPOSE` is an algebra
2014-12-04 12:04:22 +03:00
transpose, with an image reflected across its main diagonal.
2020-06-22 09:45:18 +03:00
The speed of :py:data:`~PIL.Image.ROTATE_90`, :py:data:`~PIL.Image.ROTATE_270`
and :py:data:`~PIL.Image.TRANSPOSE` has been significantly improved for large
2014-12-04 12:04:22 +03:00
images which don't fit in the processor cache.
2014-11-29 03:58:52 +03:00
Gaussian blur and unsharp mask
------------------------------
2014-12-04 12:04:22 +03:00
The :py:meth:`~PIL.ImageFilter.GaussianBlur` implementation has been replaced
with a sequential application of box filters. The new implementation is based on
"Theoretical foundations of Gaussian convolution by extended box filtering" from
2014-12-04 12:04:22 +03:00
the Mathematical Image Analysis Group. As :py:meth:`~PIL.ImageFilter.UnsharpMask`
implementations use Gaussian blur internally, all changes from this chapter
are also applicable to it.
2014-11-29 03:58:52 +03:00
Blur radius
^^^^^^^^^^^
2014-12-04 12:04:22 +03:00
There was an error in the previous version of Pillow, where blur radius (the
standard deviation of Gaussian) actually meant blur diameter. For example, to
blur an image with actual radius 5 you were forced to use value 10. This has
been fixed. Now the meaning of the radius is the same as in other software.
2014-12-01 02:23:31 +03:00
If you used a Gaussian blur with some radius value, you need to divide this
value by two.
2014-12-04 12:04:22 +03:00
Blur performance
2014-11-29 03:58:52 +03:00
^^^^^^^^^^^^^^^^
Box filter computation time is constant relative to the radius and depends
2014-12-04 12:04:22 +03:00
on source image size only. Because the new Gaussian blur implementation
2017-05-29 12:42:06 +03:00
is based on box filter, its computation time also doesn't depend on the blur
radius.
2014-12-04 12:04:22 +03:00
For example, previously, if the execution time for a given test image was 1
second for radius 1, 3.6 seconds for radius 10 and 17 seconds for 50, now blur
with any radius on same image is executed for 0.2 seconds.
2014-11-29 03:58:52 +03:00
Blur quality
^^^^^^^^^^^^
2014-12-04 12:04:22 +03:00
The previous implementation takes into account only source pixels within
2014-12-01 02:23:31 +03:00
2 * standard deviation radius for every destination pixel. This was not enough,
2014-12-04 12:04:22 +03:00
so the quality was worse compared to other Gaussian blur software.
The new implementation does not have this drawback.
2015-01-02 00:06:39 +03:00
TIFF Parameter Changes
----------------------
Several kwarg parameters for saving TIFF images were previously
specified as strings with included spaces (e.g. 'x resolution'). This
was difficult to use as kwargs without constructing and passing a
dictionary. These parameters now use the underscore character instead
of space. (e.g. 'x_resolution')