mirror of
				https://github.com/python-pillow/Pillow.git
				synced 2025-10-25 21:21:01 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			136 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			136 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| 9.4.0
 | |
| -----
 | |
| 
 | |
| API Additions
 | |
| =============
 | |
| 
 | |
| Added start position for getmask and getmask2
 | |
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| Text may render differently when starting at fractional coordinates, so
 | |
| :py:meth:`.FreeTypeFont.getmask` and :py:meth:`.FreeTypeFont.getmask2` now
 | |
| support a ``start`` argument. This tuple of horizontal and vertical offset
 | |
| will be used internally by :py:meth:`.ImageDraw.text` to more accurately place
 | |
| text at the ``xy`` coordinates.
 | |
| 
 | |
| Added the ``exact`` encoding option for WebP
 | |
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| The ``exact`` encoding option for WebP is now supported. The WebP encoder
 | |
| removes the hidden RGB values for better compression by default in libwebp 0.5
 | |
| or later. By setting this option to ``True``, the encoder will keep the hidden
 | |
| RGB values.
 | |
| 
 | |
| Added ``signed`` option when saving JPEG2000
 | |
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| If the ``signed`` keyword argument is present and true when saving JPEG2000
 | |
| images, then tell the encoder to save the image as signed.
 | |
| 
 | |
| Added IFD, Interop and LightSource ExifTags enums
 | |
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| :py:data:`~PIL.ExifTags.IFD` has been added, allowing enums to be used with
 | |
| :py:meth:`~PIL.Image.Exif.get_ifd`::
 | |
| 
 | |
|     from PIL import Image, ExifTags
 | |
|     im = Image.open("Tests/images/flower.jpg")
 | |
|     print(im.getexif().get_ifd(ExifTags.IFD.Exif))
 | |
| 
 | |
| ``IFD1`` can also be used with :py:meth:`~PIL.Image.Exif.get_ifd`, but it should
 | |
| not be used in other contexts, as the enum value is only internally meaningful.
 | |
| 
 | |
| :py:data:`~PIL.ExifTags.Interop` has been added for tags within the Interop IFD::
 | |
| 
 | |
|     from PIL import Image, ExifTags
 | |
|     im = Image.open("Tests/images/flower.jpg")
 | |
|     interop_ifd = im.getexif().get_ifd(ExifTags.IFD.Interop)
 | |
|     print(interop_ifd.get(ExifTags.Interop.InteropIndex))  # R98
 | |
| 
 | |
| :py:data:`~PIL.ExifTags.LightSource` has been added for values within the LightSource
 | |
| tag::
 | |
| 
 | |
|     from PIL import Image, ExifTags
 | |
|     im = Image.open("Tests/images/iptc.jpg")
 | |
|     exif_ifd = im.getexif().get_ifd(ExifTags.IFD.Exif)
 | |
|     print(ExifTags.LightSource(exif_ifd[0x9208]))  # LightSource.Unknown
 | |
| 
 | |
| getxmp()
 | |
| ^^^^^^^^
 | |
| 
 | |
| `XMP data <https://en.wikipedia.org/wiki/Extensible_Metadata_Platform>`_ can now be
 | |
| decoded for WEBP images through ``getxmp()``.
 | |
| 
 | |
| Writing JPEG comments
 | |
| ^^^^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| When saving a JPEG image, a comment can now be written from
 | |
| :py:attr:`~PIL.Image.Image.info`, or by using an argument when saving::
 | |
| 
 | |
|     im.save(out, comment="Test comment")
 | |
| 
 | |
| Security
 | |
| ========
 | |
| 
 | |
| Fix memory DOS in ImageFont
 | |
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| A corrupt or specially crafted TTF font could have font metrics that lead to
 | |
| unreasonably large sizes when rendering text in font. ``ImageFont.py`` did not
 | |
| check the image size before allocating memory for it. This dates to the PIL
 | |
| fork. Pillow 8.2.0 added a check for large sizes, but did not consider the
 | |
| case where one dimension is zero.
 | |
| 
 | |
| Null pointer dereference crash in ImageFont
 | |
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| Pillow attempted to dereference a null pointer in ``ImageFont``, leading to a
 | |
| crash. An error is now raised instead. This has been present since
 | |
| Pillow 8.0.0.
 | |
| 
 | |
| Other Changes
 | |
| =============
 | |
| 
 | |
| Added support for DDS L and LA images
 | |
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | |
| 
 | |
| Support has been added to read and write L and LA DDS images in the uncompressed
 | |
| format, known as "luminance" textures.
 | |
| 
 | |
| .. _restored-image-constants:
 | |
| 
 | |
| Constants
 | |
| ^^^^^^^^^
 | |
| 
 | |
| In Pillow 9.1.0, the following constants were deprecated. That has been reversed and
 | |
| these constants will now remain available.
 | |
| 
 | |
| - ``Image.NONE``
 | |
| - ``Image.NEAREST``
 | |
| - ``Image.ORDERED``
 | |
| - ``Image.RASTERIZE``
 | |
| - ``Image.FLOYDSTEINBERG``
 | |
| - ``Image.WEB``
 | |
| - ``Image.ADAPTIVE``
 | |
| - ``Image.AFFINE``
 | |
| - ``Image.EXTENT``
 | |
| - ``Image.PERSPECTIVE``
 | |
| - ``Image.QUAD``
 | |
| - ``Image.MESH``
 | |
| - ``Image.FLIP_LEFT_RIGHT``
 | |
| - ``Image.FLIP_TOP_BOTTOM``
 | |
| - ``Image.ROTATE_90``
 | |
| - ``Image.ROTATE_180``
 | |
| - ``Image.ROTATE_270``
 | |
| - ``Image.TRANSPOSE``
 | |
| - ``Image.TRANSVERSE``
 | |
| - ``Image.BOX``
 | |
| - ``Image.BILINEAR``
 | |
| - ``Image.HAMMING``
 | |
| - ``Image.BICUBIC``
 | |
| - ``Image.LANCZOS``
 | |
| - ``Image.MEDIANCUT``
 | |
| - ``Image.MAXCOVERAGE``
 | |
| - ``Image.FASTOCTREE``
 | |
| - ``Image.LIBIMAGEQUANT``
 |