mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-26 09:14:27 +03:00
Merge pull request #4908 from radarhere/effect_spread
Fixed effect_spread bug for zero distance
This commit is contained in:
commit
6a630fd3c8
|
@ -454,6 +454,17 @@ class TestImage:
|
|||
with Image.open("Tests/images/effect_spread.png") as im3:
|
||||
assert_image_similar(im2, im3, 110)
|
||||
|
||||
def test_effect_spread_zero(self):
|
||||
# Arrange
|
||||
im = hopper()
|
||||
distance = 0
|
||||
|
||||
# Act
|
||||
im2 = im.effect_spread(distance)
|
||||
|
||||
# Assert
|
||||
assert_image_equal(im, im2)
|
||||
|
||||
def test_check_size(self):
|
||||
# Checking that the _check_size function throws value errors when we want it to
|
||||
with pytest.raises(ValueError):
|
||||
|
|
|
@ -131,6 +131,13 @@ ImagingEffectSpread(Imaging imIn, int distance)
|
|||
}
|
||||
|
||||
#define SPREAD(type, image)\
|
||||
if (distance == 0) {\
|
||||
for (y = 0; y < imOut->ysize; y++) {\
|
||||
for (x = 0; x < imOut->xsize; x++) {\
|
||||
imOut->image[y][x] = imIn->image[y][x];\
|
||||
}\
|
||||
}\
|
||||
} else {\
|
||||
for (y = 0; y < imOut->ysize; y++) {\
|
||||
for (x = 0; x < imOut->xsize; x++) {\
|
||||
int xx = x + (rand() % distance) - distance/2;\
|
||||
|
@ -142,6 +149,7 @@ ImagingEffectSpread(Imaging imIn, int distance)
|
|||
imOut->image[y][x] = imIn->image[y][x];\
|
||||
}\
|
||||
}\
|
||||
}\
|
||||
}
|
||||
|
||||
if (imIn->image8) {
|
||||
|
|
Loading…
Reference in New Issue
Block a user