Merge pull request #5584 from radarhere/exif_transpose

Handle removing orientation from alternate types of EXIF data
This commit is contained in:
Hugo van Kemenade 2021-07-06 09:03:49 +03:00 committed by GitHub
commit 340adc5f0e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 37 additions and 2 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 175 KiB

View File

@ -335,6 +335,28 @@ def test_exif_transpose():
) as orientation_im: ) as orientation_im:
check(orientation_im) check(orientation_im)
# Orientation from "XML:com.adobe.xmp" info key
with Image.open("Tests/images/xmp_tags_orientation.png") as im:
assert im.getexif()[0x0112] == 3
transposed_im = ImageOps.exif_transpose(im)
assert 0x0112 not in transposed_im.getexif()
# Orientation from "Raw profile type exif" info key
# This test image has been manually hexedited from exif_imagemagick.png
# to have a different orientation
with Image.open("Tests/images/exif_imagemagick_orientation.png") as im:
assert im.getexif()[0x0112] == 3
transposed_im = ImageOps.exif_transpose(im)
assert 0x0112 not in transposed_im.getexif()
# Orientation set directly on Image.Exif
im = hopper()
im.getexif()[0x0112] = 3
transposed_im = ImageOps.exif_transpose(im)
assert 0x0112 not in transposed_im.getexif()
def test_autocontrast_cutoff(): def test_autocontrast_cutoff():
# Test the cutoff argument of autocontrast # Test the cutoff argument of autocontrast

View File

@ -19,6 +19,7 @@
import functools import functools
import operator import operator
import re
from . import Image, ImageDraw from . import Image, ImageDraw
@ -588,7 +589,19 @@ def exif_transpose(image):
if method is not None: if method is not None:
transposed_image = image.transpose(method) transposed_image = image.transpose(method)
transposed_exif = transposed_image.getexif() transposed_exif = transposed_image.getexif()
del transposed_exif[0x0112] if 0x0112 in transposed_exif:
transposed_image.info["exif"] = transposed_exif.tobytes() del transposed_exif[0x0112]
if "exif" in transposed_image.info:
transposed_image.info["exif"] = transposed_exif.tobytes()
elif "Raw profile type exif" in transposed_image.info:
transposed_image.info[
"Raw profile type exif"
] = transposed_exif.tobytes().hex()
elif "XML:com.adobe.xmp" in transposed_image.info:
transposed_image.info["XML:com.adobe.xmp"] = re.sub(
r'tiff:Orientation="([0-9])"',
"",
transposed_image.info["XML:com.adobe.xmp"],
)
return transposed_image return transposed_image
return image.copy() return image.copy()