simpler colormap lookup

This commit is contained in:
homm 2016-09-17 12:38:45 +03:00
parent 859a75ba07
commit 9453129a57
2 changed files with 8 additions and 13 deletions

View File

@ -31,15 +31,9 @@ def getrgb(color):
:param color: A color string :param color: A color string
:return: ``(red, green, blue[, alpha])`` :return: ``(red, green, blue[, alpha])``
""" """
try: color = color.lower()
rgb = colormap[color]
except KeyError: rgb = colormap.get(color, None)
try:
# fall back on case-insensitive lookup
rgb = colormap[color.lower()]
except KeyError:
rgb = None
# found color in cache
if rgb: if rgb:
if isinstance(rgb, tuple): if isinstance(rgb, tuple):
return rgb return rgb
@ -47,14 +41,14 @@ def getrgb(color):
return rgb return rgb
# check for known string formats # check for known string formats
if re.match('#[a-f0-9]{3}$', color, re.I): if re.match('#[a-f0-9]{3}$', color):
return ( return (
int(color[1]*2, 16), int(color[1]*2, 16),
int(color[2]*2, 16), int(color[2]*2, 16),
int(color[3]*2, 16), int(color[3]*2, 16),
) )
if re.match('#[a-f0-9]{4}$', color, re.I): if re.match('#[a-f0-9]{4}$', color):
return ( return (
int(color[1]*2, 16), int(color[1]*2, 16),
int(color[2]*2, 16), int(color[2]*2, 16),
@ -62,14 +56,14 @@ def getrgb(color):
int(color[4]*2, 16), int(color[4]*2, 16),
) )
if re.match('#[a-f0-9]{6}$', color, re.I): if re.match('#[a-f0-9]{6}$', color):
return ( return (
int(color[1:3], 16), int(color[1:3], 16),
int(color[3:5], 16), int(color[3:5], 16),
int(color[5:7], 16), int(color[5:7], 16),
) )
if re.match('#[a-f0-9]{8}$', color, re.I): if re.match('#[a-f0-9]{8}$', color):
return ( return (
int(color[1:3], 16), int(color[1:3], 16),
int(color[3:5], 16), int(color[3:5], 16),

View File

@ -39,6 +39,7 @@ class TestImageColor(PillowTestCase):
def test_colormap(self): def test_colormap(self):
self.assertEqual((0, 0, 0), ImageColor.getrgb("black")) self.assertEqual((0, 0, 0), ImageColor.getrgb("black"))
self.assertEqual((255, 255, 255), ImageColor.getrgb("white")) self.assertEqual((255, 255, 255), ImageColor.getrgb("white"))
self.assertEqual((255, 255, 255), ImageColor.getrgb("WHITE"))
self.assertRaises(ValueError, ImageColor.getrgb, "black0") self.assertRaises(ValueError, ImageColor.getrgb, "black0")