add hardlight and softlight chops

This commit is contained in:
Dag Wästberg 2019-11-22 14:03:59 +01:00 committed by Andrew Murray
parent 319f5409fe
commit 705140cc2c
3 changed files with 31 additions and 23 deletions

View File

@ -363,7 +363,7 @@ def test_subtract_modulo_no_clip():
new = ImageChops.subtract_modulo(im1, im2) new = ImageChops.subtract_modulo(im1, im2)
# Assert # Assert
assert new.getpixel((50, 50)) == (241, 167, 127) self.assertEqual(new.getpixel((50, 50)), (241, 167, 127))
def test_softlight(self): def test_softlight(self):
@ -392,19 +392,6 @@ def test_hardlight(self):
self.assertEqual(new.getpixel((15, 100)), (1, 1, 2)) self.assertEqual(new.getpixel((15, 100)), (1, 1, 2))
def test_overlay(self):
# Arrange
im1 = Image.open("Tests/images/hopper.png")
im2 = Image.open("Tests/images/hopper-XYZ.png")
# Act
new = ImageChops.overlay(im1, im2)
# Assert
self.assertEqual(new.getpixel((64, 64)), (159, 50, 27))
self.assertEqual(new.getpixel((15, 100)), (1, 1, 2))
def test_logical(): def test_logical():
def table(op, a, b): def table(op, a, b):
out = [] out = []

View File

@ -138,6 +138,27 @@ def screen(image1, image2):
image2.load() image2.load()
return image1._new(image1.im.chop_screen(image2.im)) return image1._new(image1.im.chop_screen(image2.im))
def softlight(image1, image2):
"""
Superimposes two images on top of each other using the Soft Light algorithm
:rtype: :py:class:`~PIL.Image.Image`
"""
image1.load()
image2.load()
return image1._new(image1.im.chop_softlight(image2.im))
def hardlight(image1, image2):
"""
Superimposes two images on top of each other using the Hard Light algorithm
:rtype: :py:class:`~PIL.Image.Image`
"""
image1.load()
image2.load()
return image1._new(image1.im.chop_hardlight(image2.im))
def softlight(image1, image2): def softlight(image1, image2):
""" """

View File

@ -148,27 +148,27 @@ ImagingChopSubtractModulo(Imaging imIn1, Imaging imIn2)
} }
Imaging Imaging
ImagingChopSoftLight(Imaging imIn1, Imaging imIn2) ImagingChopSoftLight(Imaging imIn1, Imaging imIn2)
{ {
// CHOP2( ( ( (255-in1[x]) * (in1[x]*in2[x]) ) / 65536) + // CHOP2( ( ( (255-in1[x]) * (in1[x]*in2[x]) ) / 65536) +
// ((in1[x] * (255 - ((255 - in1[1]) * (255 - in2[x]) / 255 ) )) / 255), NULL ); // ((in1[x] * (255 - ((255 - in1[1]) * (255 - in2[x]) / 255 ) )) / 255), NULL );
CHOP2( (((255-in1[x]) * (in1[x]*in2[x]) ) / 65536) + CHOP2( (((255-in1[x]) * (in1[x]*in2[x]) ) / 65536) +
(in1[x] * ( 255 - ( (255 - in1[x]) * (255 - in2[x] ) / 255) )) / 255 (in1[x] * ( 255 - ( (255 - in1[x]) * (255 - in2[x] ) / 255) )) / 255
, NULL ); , NULL );
} }
Imaging Imaging
ImagingChopHardLight(Imaging imIn1, Imaging imIn2) ImagingChopHardLight(Imaging imIn1, Imaging imIn2)
{ {
CHOP2( (in2[x]<128) ? ( (in1[x]*in2[x])/127) CHOP2( (in2[x]<128) ? ( (in1[x]*in2[x])/127)
: 255 - ( ((255-in2[x]) * (255-in1[x])) / 127) : 255 - ( ((255-in2[x]) * (255-in1[x])) / 127)
, NULL); , NULL);
} }
Imaging Imaging
ImagingOverlay(Imaging imIn1, Imaging imIn2) ImagingOverlay(Imaging imIn1, Imaging imIn2)
{ {
CHOP2( (in1[x]<128) ? ( (in1[x]*in2[x])/127) CHOP2( (in1[x]<128) ? ( (in1[x]*in2[x])/127)
: 255 - ( ((255-in1[x]) * (255-in2[x])) / 127) : 255 - ( ((255-in1[x]) * (255-in2[x])) / 127)
, NULL); , NULL);
} }