Added support for generators when using append_images for WEBP

This commit is contained in:
Andrew Murray 2017-11-06 20:06:50 +11:00
parent 6c6f95f1d6
commit bfaa0a1f07
2 changed files with 26 additions and 14 deletions

View File

@ -167,7 +167,7 @@ class WebPImageFile(ImageFile.ImageFile):
def _save_all(im, fp, filename):
encoderinfo = im.encoderinfo.copy()
append_images = encoderinfo.get("append_images", [])
append_images = list(encoderinfo.get("append_images", []))
# If total frame count is 1, then save using the legacy API, which
# will preserve non-alpha modes

View File

@ -65,23 +65,35 @@ class TestFileWebpAnimation(PillowTestCase):
are visually similar to the originals.
"""
temp_file = self.tempfile("temp.webp")
def check(temp_file):
im = Image.open(temp_file)
self.assertEqual(im.n_frames, 2)
# Compare first frame to original
im.load()
self.assert_image_equal(im, frame1.convert("RGBA"))
# Compare second frame to original
im.seek(1)
im.load()
self.assert_image_equal(im, frame2.convert("RGBA"))
frame1 = Image.open('Tests/images/anim_frame1.webp')
frame2 = Image.open('Tests/images/anim_frame2.webp')
frame1.save(temp_file,
temp_file1 = self.tempfile("temp.webp")
frame1.copy().save(temp_file1,
save_all=True, append_images=[frame2], lossless=True)
check(temp_file1)
im = Image.open(temp_file)
self.assertEqual(im.n_frames, 2)
# Compare first frame to original
im.load()
self.assert_image_equal(im, frame1.convert("RGBA"))
# Compare second frame to original
im.seek(1)
im.load()
self.assert_image_equal(im, frame2.convert("RGBA"))
# Tests appending using a generator
def imGenerator(ims):
for im in ims:
yield im
temp_file2 = self.tempfile("temp_generator.webp")
frame1.copy().save(temp_file2,
save_all=True, append_images=imGenerator([frame2]), lossless=True)
check(temp_file2)
def test_timestamp_and_duration(self):
"""