From b5af2837328a9f5a7ba1c4732058214814a772cd Mon Sep 17 00:00:00 2001 From: Andrew Murray Date: Wed, 26 Sep 2018 22:22:17 +1000 Subject: [PATCH] Added support to floodfill for non-RGB colors --- Tests/images/imagedraw_floodfill_L.png | Bin 0 -> 144 bytes ...odfill.png => imagedraw_floodfill_RGB.png} | Bin Tests/images/imagedraw_floodfill_RGBA.png | Bin 0 -> 253 bytes Tests/test_imagechops.py | 14 ++++----- Tests/test_imagedraw.py | 27 +++++++++++------- src/PIL/ImageDraw.py | 9 ++++-- 6 files changed, 30 insertions(+), 20 deletions(-) create mode 100644 Tests/images/imagedraw_floodfill_L.png rename Tests/images/{imagedraw_floodfill.png => imagedraw_floodfill_RGB.png} (100%) create mode 100644 Tests/images/imagedraw_floodfill_RGBA.png diff --git a/Tests/images/imagedraw_floodfill_L.png b/Tests/images/imagedraw_floodfill_L.png new file mode 100644 index 0000000000000000000000000000000000000000..4139e66d84e5159d161ed71025a97e987c6b32c1 GIT binary patch literal 144 zcmeAS@N?(olHy`uVBq!ia0vp^DIm-NBp52o_Rg}?3lo%Viqd;QLuiGs}XuS=^L_6w@G tO^|R*V(Fwgn5V0s%Q~loCIFcRNE`qF literal 0 HcmV?d00001 diff --git a/Tests/test_imagechops.py b/Tests/test_imagechops.py index 3714675cf..06febc6d2 100644 --- a/Tests/test_imagechops.py +++ b/Tests/test_imagechops.py @@ -48,7 +48,7 @@ class TestImageChops(PillowTestCase): def test_add(self): # Arrange im1 = Image.open("Tests/images/imagedraw_ellipse_RGB.png") - im2 = Image.open("Tests/images/imagedraw_floodfill.png") + im2 = Image.open("Tests/images/imagedraw_floodfill_RGB.png") # Act new = ImageChops.add(im1, im2) @@ -60,7 +60,7 @@ class TestImageChops(PillowTestCase): def test_add_scale_offset(self): # Arrange im1 = Image.open("Tests/images/imagedraw_ellipse_RGB.png") - im2 = Image.open("Tests/images/imagedraw_floodfill.png") + im2 = Image.open("Tests/images/imagedraw_floodfill_RGB.png") # Act new = ImageChops.add(im1, im2, scale=2.5, offset=100) @@ -82,7 +82,7 @@ class TestImageChops(PillowTestCase): def test_add_modulo(self): # Arrange im1 = Image.open("Tests/images/imagedraw_ellipse_RGB.png") - im2 = Image.open("Tests/images/imagedraw_floodfill.png") + im2 = Image.open("Tests/images/imagedraw_floodfill_RGB.png") # Act new = ImageChops.add_modulo(im1, im2) @@ -104,7 +104,7 @@ class TestImageChops(PillowTestCase): def test_blend(self): # Arrange im1 = Image.open("Tests/images/imagedraw_ellipse_RGB.png") - im2 = Image.open("Tests/images/imagedraw_floodfill.png") + im2 = Image.open("Tests/images/imagedraw_floodfill_RGB.png") # Act new = ImageChops.blend(im1, im2, 0.5) @@ -181,7 +181,7 @@ class TestImageChops(PillowTestCase): def test_invert(self): # Arrange - im = Image.open("Tests/images/imagedraw_floodfill.png") + im = Image.open("Tests/images/imagedraw_floodfill_RGB.png") # Act new = ImageChops.invert(im) @@ -228,7 +228,7 @@ class TestImageChops(PillowTestCase): def test_multiply_green(self): # Arrange - im = Image.open("Tests/images/imagedraw_floodfill.png") + im = Image.open("Tests/images/imagedraw_floodfill_RGB.png") green = Image.new("RGB", im.size, "green") # Act @@ -273,7 +273,7 @@ class TestImageChops(PillowTestCase): def test_screen(self): # Arrange im1 = Image.open("Tests/images/imagedraw_ellipse_RGB.png") - im2 = Image.open("Tests/images/imagedraw_floodfill.png") + im2 = Image.open("Tests/images/imagedraw_floodfill_RGB.png") # Act new = ImageChops.screen(im1, im2) diff --git a/Tests/test_imagedraw.py b/Tests/test_imagedraw.py index 76868cbf8..ad3e8b2cb 100644 --- a/Tests/test_imagedraw.py +++ b/Tests/test_imagedraw.py @@ -344,19 +344,26 @@ class TestImageDraw(PillowTestCase): self.assert_image_similar(im, Image.open(expected), 1) def test_floodfill(self): - # Arrange - im = Image.new("RGB", (W, H)) - draw = ImageDraw.Draw(im) - draw.rectangle(BBOX2, outline="yellow", fill="green") - centre_point = (int(W/2), int(H/2)) red = ImageColor.getrgb("red") - im_floodfill = Image.open("Tests/images/imagedraw_floodfill.png") - # Act - ImageDraw.floodfill(im, centre_point, red) + for mode, value in [ + ("L", 1), + ("RGBA", (255, 0, 0, 0)), + ("RGB", red) + ]: + # Arrange + im = Image.new(mode, (W, H)) + draw = ImageDraw.Draw(im) + draw.rectangle(BBOX2, outline="yellow", fill="green") + centre_point = (int(W/2), int(H/2)) - # Assert - self.assert_image_equal(im, im_floodfill) + # Act + ImageDraw.floodfill(im, centre_point, value) + + # Assert + expected = "Tests/images/imagedraw_floodfill_"+mode+".png" + im_floodfill = Image.open(expected) + self.assert_image_equal(im, im_floodfill) # Test that using the same colour does not change the image ImageDraw.floodfill(im, centre_point, red) diff --git a/src/PIL/ImageDraw.py b/src/PIL/ImageDraw.py index 3c4cd3d23..511bae537 100644 --- a/src/PIL/ImageDraw.py +++ b/src/PIL/ImageDraw.py @@ -430,8 +430,11 @@ def floodfill(image, xy, value, border=None, thresh=0): edge = new_edge -def _color_diff(rgb1, rgb2): +def _color_diff(color1, color2): """ - Uses 1-norm distance to calculate difference between two rgb values. + Uses 1-norm distance to calculate difference between two values. """ - return abs(rgb1[0]-rgb2[0]) + abs(rgb1[1]-rgb2[1]) + abs(rgb1[2]-rgb2[2]) + if isinstance(color2, tuple): + return sum([abs(color1[i]-color2[i]) for i in range(0, len(color2))]) + else: + return abs(color1-color2)