2019-02-03 18:34:53 +03:00
|
|
|
from .helper import PillowTestCase, hopper
|
2012-10-16 00:26:38 +04:00
|
|
|
|
2014-08-27 01:16:01 +04:00
|
|
|
from PIL import Image, ImageSequence, TiffImagePlugin
|
2012-10-16 00:26:38 +04:00
|
|
|
|
|
|
|
|
2014-06-10 13:10:47 +04:00
|
|
|
class TestImageSequence(PillowTestCase):
|
2012-10-16 00:26:38 +04:00
|
|
|
|
2014-06-10 13:10:47 +04:00
|
|
|
def test_sanity(self):
|
2013-07-01 02:42:19 +04:00
|
|
|
|
2015-04-24 11:24:52 +03:00
|
|
|
test_file = self.tempfile("temp.im")
|
2013-07-01 02:42:19 +04:00
|
|
|
|
2014-09-05 14:03:56 +04:00
|
|
|
im = hopper("RGB")
|
2015-04-24 11:24:52 +03:00
|
|
|
im.save(test_file)
|
2012-10-16 00:26:38 +04:00
|
|
|
|
2014-06-10 13:10:47 +04:00
|
|
|
seq = ImageSequence.Iterator(im)
|
2012-10-16 00:26:38 +04:00
|
|
|
|
2014-06-10 13:10:47 +04:00
|
|
|
index = 0
|
|
|
|
for frame in seq:
|
|
|
|
self.assert_image_equal(im, frame)
|
|
|
|
self.assertEqual(im.tell(), index)
|
2014-06-23 14:39:27 +04:00
|
|
|
index += 1
|
2014-06-10 13:10:47 +04:00
|
|
|
|
|
|
|
self.assertEqual(index, 1)
|
|
|
|
|
2017-09-01 14:05:40 +03:00
|
|
|
self.assertRaises(AttributeError, ImageSequence.Iterator, 0)
|
2015-07-03 08:03:25 +03:00
|
|
|
|
2016-01-06 13:09:40 +03:00
|
|
|
def test_iterator(self):
|
|
|
|
im = Image.open('Tests/images/multipage.tiff')
|
|
|
|
i = ImageSequence.Iterator(im)
|
|
|
|
for index in range(0, im.n_frames):
|
|
|
|
self.assertEqual(i[index], next(i))
|
|
|
|
self.assertRaises(IndexError, lambda: i[index+1])
|
2017-09-01 14:05:40 +03:00
|
|
|
self.assertRaises(StopIteration, next, i)
|
2016-01-06 13:09:40 +03:00
|
|
|
|
2019-06-12 13:11:51 +03:00
|
|
|
def test_iterator_min_frame(self):
|
|
|
|
im = Image.open('Tests/images/hopper.psd')
|
|
|
|
i = ImageSequence.Iterator(im)
|
|
|
|
for index in range(1, im.n_frames):
|
|
|
|
self.assertEqual(i[index], next(i))
|
|
|
|
|
2015-12-02 08:55:50 +03:00
|
|
|
def _test_multipage_tiff(self):
|
2014-08-27 01:16:01 +04:00
|
|
|
im = Image.open('Tests/images/multipage.tiff')
|
|
|
|
for index, frame in enumerate(ImageSequence.Iterator(im)):
|
|
|
|
frame.load()
|
|
|
|
self.assertEqual(index, im.tell())
|
|
|
|
frame.convert('RGB')
|
2014-09-05 14:03:56 +04:00
|
|
|
|
2014-08-27 01:16:01 +04:00
|
|
|
def test_tiff(self):
|
2015-12-02 08:55:50 +03:00
|
|
|
self._test_multipage_tiff()
|
2014-08-27 01:16:01 +04:00
|
|
|
|
|
|
|
def test_libtiff(self):
|
|
|
|
codecs = dir(Image.core)
|
2014-09-05 14:03:56 +04:00
|
|
|
|
2014-08-27 01:16:01 +04:00
|
|
|
if "libtiff_encoder" not in codecs or "libtiff_decoder" not in codecs:
|
|
|
|
self.skipTest("tiff support not available")
|
|
|
|
|
|
|
|
TiffImagePlugin.READ_LIBTIFF = True
|
2015-12-02 08:55:50 +03:00
|
|
|
self._test_multipage_tiff()
|
2014-08-27 01:16:01 +04:00
|
|
|
TiffImagePlugin.READ_LIBTIFF = False
|
2014-09-05 14:03:56 +04:00
|
|
|
|
2016-01-27 06:04:05 +03:00
|
|
|
def test_consecutive(self):
|
|
|
|
im = Image.open('Tests/images/multipage.tiff')
|
|
|
|
firstFrame = None
|
|
|
|
for frame in ImageSequence.Iterator(im):
|
2016-08-04 09:40:12 +03:00
|
|
|
if firstFrame is None:
|
2016-01-27 06:04:05 +03:00
|
|
|
firstFrame = frame.copy()
|
|
|
|
for frame in ImageSequence.Iterator(im):
|
|
|
|
self.assert_image_equal(frame, firstFrame)
|
|
|
|
break
|
|
|
|
|
2016-09-29 15:54:25 +03:00
|
|
|
def test_palette_mmap(self):
|
|
|
|
# Using mmap in ImageFile can require to reload the palette.
|
|
|
|
im = Image.open('Tests/images/multipage-mmap.tiff')
|
|
|
|
color1 = im.getpalette()[0:3]
|
|
|
|
im.seek(0)
|
|
|
|
color2 = im.getpalette()[0:3]
|
|
|
|
self.assertEqual(color1, color2)
|