2012-10-16 00:26:38 +04:00
|
|
|
from tester import *
|
|
|
|
|
|
|
|
from PIL import Image
|
|
|
|
try:
|
|
|
|
from PIL import ImageCms
|
2014-04-04 03:04:29 +04:00
|
|
|
ImageCms.core.profile_open
|
2012-10-16 00:26:38 +04:00
|
|
|
except ImportError:
|
|
|
|
skip()
|
|
|
|
|
|
|
|
SRGB = "Tests/icc/sRGB.icm"
|
|
|
|
|
2014-06-02 13:41:48 +04:00
|
|
|
|
2012-10-16 00:26:38 +04:00
|
|
|
def test_sanity():
|
|
|
|
|
|
|
|
# basic smoke test.
|
|
|
|
# this mostly follows the cms_test outline.
|
|
|
|
|
2014-06-02 13:41:48 +04:00
|
|
|
v = ImageCms.versions() # should return four strings
|
2013-10-02 10:22:45 +04:00
|
|
|
assert_equal(v[0], '1.0.0 pil')
|
2012-10-16 00:26:38 +04:00
|
|
|
assert_equal(list(map(type, v)), [str, str, str, str])
|
|
|
|
|
|
|
|
# internal version number
|
|
|
|
assert_match(ImageCms.core.littlecms_version, "\d+\.\d+$")
|
|
|
|
|
|
|
|
i = ImageCms.profileToProfile(lena(), SRGB, SRGB)
|
|
|
|
assert_image(i, "RGB", (128, 128))
|
|
|
|
|
|
|
|
t = ImageCms.buildTransform(SRGB, SRGB, "RGB", "RGB")
|
|
|
|
i = ImageCms.applyTransform(lena(), t)
|
|
|
|
assert_image(i, "RGB", (128, 128))
|
|
|
|
|
|
|
|
p = ImageCms.createProfile("sRGB")
|
|
|
|
o = ImageCms.getOpenProfile(SRGB)
|
|
|
|
t = ImageCms.buildTransformFromOpenProfiles(p, o, "RGB", "RGB")
|
|
|
|
i = ImageCms.applyTransform(lena(), t)
|
|
|
|
assert_image(i, "RGB", (128, 128))
|
|
|
|
|
|
|
|
t = ImageCms.buildProofTransform(SRGB, SRGB, SRGB, "RGB", "RGB")
|
|
|
|
assert_equal(t.inputMode, "RGB")
|
|
|
|
assert_equal(t.outputMode, "RGB")
|
|
|
|
i = ImageCms.applyTransform(lena(), t)
|
|
|
|
assert_image(i, "RGB", (128, 128))
|
|
|
|
|
2013-10-11 09:16:56 +04:00
|
|
|
# test PointTransform convenience API
|
2014-06-02 13:41:48 +04:00
|
|
|
lena().point(t)
|
|
|
|
|
2013-10-11 09:16:56 +04:00
|
|
|
|
|
|
|
def test_name():
|
2012-10-16 00:26:38 +04:00
|
|
|
# get profile information for file
|
|
|
|
assert_equal(ImageCms.getProfileName(SRGB).strip(),
|
|
|
|
'IEC 61966-2.1 Default RGB colour space - sRGB')
|
2014-06-02 13:41:48 +04:00
|
|
|
|
|
|
|
|
2013-10-11 09:16:56 +04:00
|
|
|
def x_test_info():
|
2012-10-16 00:26:38 +04:00
|
|
|
assert_equal(ImageCms.getProfileInfo(SRGB).splitlines(),
|
|
|
|
['sRGB IEC61966-2.1', '',
|
|
|
|
'Copyright (c) 1998 Hewlett-Packard Company', '',
|
|
|
|
'WhitePoint : D65 (daylight)', '',
|
|
|
|
'Tests/icc/sRGB.icm'])
|
2013-10-11 09:16:56 +04:00
|
|
|
|
2014-06-02 13:41:48 +04:00
|
|
|
|
2013-10-11 09:16:56 +04:00
|
|
|
def test_intent():
|
2012-10-16 00:26:38 +04:00
|
|
|
assert_equal(ImageCms.getDefaultIntent(SRGB), 0)
|
|
|
|
assert_equal(ImageCms.isIntentSupported(
|
2014-06-02 13:41:48 +04:00
|
|
|
SRGB, ImageCms.INTENT_ABSOLUTE_COLORIMETRIC,
|
|
|
|
ImageCms.DIRECTION_INPUT), 1)
|
|
|
|
|
2012-10-16 00:26:38 +04:00
|
|
|
|
2013-10-11 09:16:56 +04:00
|
|
|
def test_profile_object():
|
2012-10-16 00:26:38 +04:00
|
|
|
# same, using profile object
|
|
|
|
p = ImageCms.createProfile("sRGB")
|
2013-10-11 09:16:56 +04:00
|
|
|
# assert_equal(ImageCms.getProfileName(p).strip(),
|
|
|
|
# 'sRGB built-in - (lcms internal)')
|
|
|
|
# assert_equal(ImageCms.getProfileInfo(p).splitlines(),
|
|
|
|
# ['sRGB built-in', '', 'WhitePoint : D65 (daylight)', '', ''])
|
2012-10-16 00:26:38 +04:00
|
|
|
assert_equal(ImageCms.getDefaultIntent(p), 0)
|
|
|
|
assert_equal(ImageCms.isIntentSupported(
|
2014-06-02 13:41:48 +04:00
|
|
|
p, ImageCms.INTENT_ABSOLUTE_COLORIMETRIC,
|
|
|
|
ImageCms.DIRECTION_INPUT), 1)
|
|
|
|
|
2012-10-16 00:26:38 +04:00
|
|
|
|
2013-10-11 09:16:56 +04:00
|
|
|
def test_extensions():
|
2012-10-16 00:26:38 +04:00
|
|
|
# extensions
|
|
|
|
i = Image.open("Tests/images/rgb.jpg")
|
|
|
|
p = ImageCms.getOpenProfile(BytesIO(i.info["icc_profile"]))
|
|
|
|
assert_equal(ImageCms.getProfileName(p).strip(),
|
|
|
|
'IEC 61966-2.1 Default RGB colour space - sRGB')
|
|
|
|
|
2014-06-02 13:41:48 +04:00
|
|
|
|
2013-10-11 09:16:56 +04:00
|
|
|
def test_exceptions():
|
2012-10-16 00:26:38 +04:00
|
|
|
# the procedural pyCMS API uses PyCMSError for all sorts of errors
|
2014-06-02 13:41:48 +04:00
|
|
|
assert_exception(
|
|
|
|
ImageCms.PyCMSError,
|
|
|
|
lambda: ImageCms.profileToProfile(lena(), "foo", "bar"))
|
|
|
|
assert_exception(
|
|
|
|
ImageCms.PyCMSError,
|
|
|
|
lambda: ImageCms.buildTransform("foo", "bar", "RGB", "RGB"))
|
|
|
|
assert_exception(
|
|
|
|
ImageCms.PyCMSError,
|
|
|
|
lambda: ImageCms.getProfileName(None))
|
|
|
|
assert_exception(
|
|
|
|
ImageCms.PyCMSError,
|
|
|
|
lambda: ImageCms.isIntentSupported(SRGB, None, None))
|
2012-10-16 00:26:38 +04:00
|
|
|
|
|
|
|
|
2013-10-11 09:16:56 +04:00
|
|
|
def test_display_profile():
|
2012-10-16 00:26:38 +04:00
|
|
|
# try fetching the profile for the current display device
|
|
|
|
assert_no_exception(lambda: ImageCms.get_display_profile())
|
2013-10-11 09:42:27 +04:00
|
|
|
|
|
|
|
|
|
|
|
def test_lab_color_profile():
|
2014-06-02 13:41:48 +04:00
|
|
|
ImageCms.createProfile("LAB", 5000)
|
|
|
|
ImageCms.createProfile("LAB", 6500)
|
|
|
|
|
2013-10-16 09:04:51 +04:00
|
|
|
|
|
|
|
def test_simple_lab():
|
2014-06-02 13:41:48 +04:00
|
|
|
i = Image.new('RGB', (10, 10), (128, 128, 128))
|
2013-10-16 09:04:51 +04:00
|
|
|
|
2014-06-02 13:41:48 +04:00
|
|
|
pLab = ImageCms.createProfile("LAB")
|
2013-10-16 09:04:51 +04:00
|
|
|
t = ImageCms.buildTransform(SRGB, pLab, "RGB", "LAB")
|
|
|
|
|
|
|
|
i_lab = ImageCms.applyTransform(i, t)
|
|
|
|
|
|
|
|
assert_equal(i_lab.mode, 'LAB')
|
|
|
|
|
2014-06-02 13:41:48 +04:00
|
|
|
k = i_lab.getpixel((0, 0))
|
|
|
|
assert_equal(k, (137, 128, 128)) # not a linear luminance map. so L != 128
|
2013-10-16 09:04:51 +04:00
|
|
|
|
2014-06-02 13:41:48 +04:00
|
|
|
L = i_lab.getdata(0)
|
2013-10-16 09:04:51 +04:00
|
|
|
a = i_lab.getdata(1)
|
|
|
|
b = i_lab.getdata(2)
|
|
|
|
|
2014-06-02 13:41:48 +04:00
|
|
|
assert_equal(list(L), [137] * 100)
|
|
|
|
assert_equal(list(a), [128] * 100)
|
|
|
|
assert_equal(list(b), [128] * 100)
|
|
|
|
|
2013-10-16 09:04:51 +04:00
|
|
|
|
2013-10-11 09:42:27 +04:00
|
|
|
def test_lab_color():
|
2014-06-02 13:41:48 +04:00
|
|
|
pLab = ImageCms.createProfile("LAB")
|
2013-10-11 10:27:34 +04:00
|
|
|
t = ImageCms.buildTransform(SRGB, pLab, "RGB", "LAB")
|
2014-06-02 13:41:48 +04:00
|
|
|
# Need to add a type mapping for some PIL type to TYPE_Lab_8 in
|
|
|
|
# findLCMSType, and have that mapping work back to a PIL mode (likely RGB).
|
2013-10-11 09:42:27 +04:00
|
|
|
i = ImageCms.applyTransform(lena(), t)
|
2013-10-11 10:27:34 +04:00
|
|
|
assert_image(i, "LAB", (128, 128))
|
2014-06-02 13:41:48 +04:00
|
|
|
|
|
|
|
# i.save('temp.lab.tif') # visually verified vs PS.
|
2013-10-11 09:42:27 +04:00
|
|
|
|
|
|
|
target = Image.open('Tests/images/lena.Lab.tif')
|
|
|
|
|
2013-10-16 09:04:51 +04:00
|
|
|
assert_image_similar(i, target, 30)
|
2013-10-12 10:39:16 +04:00
|
|
|
|
2014-06-02 13:41:48 +04:00
|
|
|
|
2013-10-12 10:39:16 +04:00
|
|
|
def test_lab_srgb():
|
2014-06-02 13:41:48 +04:00
|
|
|
pLab = ImageCms.createProfile("LAB")
|
2013-10-12 10:39:16 +04:00
|
|
|
t = ImageCms.buildTransform(pLab, SRGB, "LAB", "RGB")
|
|
|
|
|
|
|
|
img = Image.open('Tests/images/lena.Lab.tif')
|
|
|
|
|
|
|
|
img_srgb = ImageCms.applyTransform(img, t)
|
|
|
|
|
2014-06-02 13:41:48 +04:00
|
|
|
# img_srgb.save('temp.srgb.tif') # visually verified vs ps.
|
|
|
|
|
2013-10-16 09:04:51 +04:00
|
|
|
assert_image_similar(lena(), img_srgb, 30)
|
2013-10-12 10:39:16 +04:00
|
|
|
|
2014-06-02 13:41:48 +04:00
|
|
|
|
2013-10-12 10:39:16 +04:00
|
|
|
def test_lab_roundtrip():
|
2014-06-02 13:41:48 +04:00
|
|
|
# check to see if we're at least internally consistent.
|
|
|
|
pLab = ImageCms.createProfile("LAB")
|
2013-10-12 10:39:16 +04:00
|
|
|
t = ImageCms.buildTransform(SRGB, pLab, "RGB", "LAB")
|
|
|
|
|
|
|
|
t2 = ImageCms.buildTransform(pLab, SRGB, "LAB", "RGB")
|
|
|
|
|
|
|
|
i = ImageCms.applyTransform(lena(), t)
|
|
|
|
out = ImageCms.applyTransform(i, t2)
|
|
|
|
|
|
|
|
assert_image_similar(lena(), out, 2)
|