mirror of
https://github.com/python-pillow/Pillow.git
synced 2024-11-11 04:07:21 +03:00
Merge pull request #4471 from radarhere/exif_imagemagick
Added reading of earlier ImageMagick PNG EXIF data
This commit is contained in:
commit
3970db0535
BIN
Tests/images/exif_imagemagick.png
Normal file
BIN
Tests/images/exif_imagemagick.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 175 KiB |
|
@ -592,8 +592,15 @@ class TestFilePng:
|
|||
with Image.open("Tests/images/hopper_idat_after_image_end.png") as im:
|
||||
assert im.text == {"TXT": "VALUE", "ZIP": "VALUE"}
|
||||
|
||||
def test_exif(self):
|
||||
with Image.open("Tests/images/exif.png") as im:
|
||||
@pytest.mark.parametrize(
|
||||
"test_file",
|
||||
[
|
||||
"Tests/images/exif.png", # With an EXIF chunk
|
||||
"Tests/images/exif_imagemagick.png", # With an ImageMagick zTXt chunk
|
||||
],
|
||||
)
|
||||
def test_exif(self, test_file):
|
||||
with Image.open(test_file) as im:
|
||||
exif = im._getexif()
|
||||
assert exif[274] == 1
|
||||
|
||||
|
|
|
@ -694,14 +694,24 @@ class PngImageFile(ImageFile.ImageFile):
|
|||
def _getexif(self):
|
||||
if "exif" not in self.info:
|
||||
self.load()
|
||||
if "exif" not in self.info:
|
||||
if "exif" not in self.info and "Raw profile type exif" not in self.info:
|
||||
return None
|
||||
return dict(self.getexif())
|
||||
|
||||
def getexif(self):
|
||||
if "exif" not in self.info:
|
||||
self.load()
|
||||
return ImageFile.ImageFile.getexif(self)
|
||||
|
||||
if self._exif is None:
|
||||
self._exif = Image.Exif()
|
||||
|
||||
exif_info = self.info.get("exif")
|
||||
if exif_info is None and "Raw profile type exif" in self.info:
|
||||
exif_info = bytes.fromhex(
|
||||
"".join(self.info["Raw profile type exif"].split("\n")[3:])
|
||||
)
|
||||
self._exif.load(exif_info)
|
||||
return self._exif
|
||||
|
||||
|
||||
# --------------------------------------------------------------------
|
||||
|
|
Loading…
Reference in New Issue
Block a user