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): def _save_all(im, fp, filename):
encoderinfo = im.encoderinfo.copy() 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 # If total frame count is 1, then save using the legacy API, which
# will preserve non-alpha modes # will preserve non-alpha modes

View File

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