2014-06-04 11:11:22 +04:00
|
|
|
from helper import unittest, PillowTestCase, lena
|
2014-06-04 10:09:23 +04:00
|
|
|
|
|
|
|
from PIL import Image
|
|
|
|
|
|
|
|
im = lena().resize((128, 100))
|
|
|
|
|
|
|
|
|
|
|
|
class TestImageCrop(PillowTestCase):
|
|
|
|
|
|
|
|
def test_toarray(self):
|
|
|
|
def test(mode):
|
|
|
|
ai = im.convert(mode).__array_interface__
|
|
|
|
return ai["shape"], ai["typestr"], len(ai["data"])
|
|
|
|
# self.assertEqual(test("1"), ((100, 128), '|b1', 1600))
|
|
|
|
self.assertEqual(test("L"), ((100, 128), '|u1', 12800))
|
|
|
|
|
|
|
|
# FIXME: wrong?
|
|
|
|
self.assertEqual(test("I"), ((100, 128), Image._ENDIAN + 'i4', 51200))
|
|
|
|
# FIXME: wrong?
|
|
|
|
self.assertEqual(test("F"), ((100, 128), Image._ENDIAN + 'f4', 51200))
|
|
|
|
|
|
|
|
self.assertEqual(test("RGB"), ((100, 128, 3), '|u1', 38400))
|
|
|
|
self.assertEqual(test("RGBA"), ((100, 128, 4), '|u1', 51200))
|
|
|
|
self.assertEqual(test("RGBX"), ((100, 128, 4), '|u1', 51200))
|
|
|
|
|
|
|
|
def test_fromarray(self):
|
|
|
|
def test(mode):
|
|
|
|
i = im.convert(mode)
|
|
|
|
a = i.__array_interface__
|
|
|
|
a["strides"] = 1 # pretend it's non-contigous
|
|
|
|
i.__array_interface__ = a # patch in new version of attribute
|
|
|
|
out = Image.fromarray(i)
|
|
|
|
return out.mode, out.size, list(i.getdata()) == list(out.getdata())
|
|
|
|
# self.assertEqual(test("1"), ("1", (128, 100), True))
|
|
|
|
self.assertEqual(test("L"), ("L", (128, 100), True))
|
|
|
|
self.assertEqual(test("I"), ("I", (128, 100), True))
|
|
|
|
self.assertEqual(test("F"), ("F", (128, 100), True))
|
|
|
|
self.assertEqual(test("RGB"), ("RGB", (128, 100), True))
|
|
|
|
self.assertEqual(test("RGBA"), ("RGBA", (128, 100), True))
|
|
|
|
self.assertEqual(test("RGBX"), ("RGBA", (128, 100), True))
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|
|
|
|
|
|
|
|
# End of file
|