mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-26 09:14:27 +03:00
Add access functions for ImagingEffectSpread with a test
This commit is contained in:
parent
8c96d38ce9
commit
bcc5305125
11
PIL/Image.py
11
PIL/Image.py
|
@ -1910,6 +1910,16 @@ class Image:
|
||||||
im = self.im.transpose(method)
|
im = self.im.transpose(method)
|
||||||
return self._new(im)
|
return self._new(im)
|
||||||
|
|
||||||
|
def effect_spread(self, distance):
|
||||||
|
"""
|
||||||
|
Randomly spread pixels in an image.
|
||||||
|
|
||||||
|
:param distance: Distance to spread pixels.
|
||||||
|
"""
|
||||||
|
self.load()
|
||||||
|
im = self.im.effect_spread(distance)
|
||||||
|
return self._new(im)
|
||||||
|
|
||||||
|
|
||||||
# --------------------------------------------------------------------
|
# --------------------------------------------------------------------
|
||||||
# Lazy operations
|
# Lazy operations
|
||||||
|
@ -2436,6 +2446,7 @@ def effect_mandelbrot(size, extent, quality):
|
||||||
"""
|
"""
|
||||||
return Image()._new(core.effect_mandelbrot(size, extent, quality))
|
return Image()._new(core.effect_mandelbrot(size, extent, quality))
|
||||||
|
|
||||||
|
|
||||||
def effect_noise(size, sigma):
|
def effect_noise(size, sigma):
|
||||||
"""
|
"""
|
||||||
Generate Gaussian noise centered around 128.
|
Generate Gaussian noise centered around 128.
|
||||||
|
|
Before Width: | Height: | Size: 13 KiB After Width: | Height: | Size: 13 KiB |
BIN
Tests/images/effect_spread.png
Normal file
BIN
Tests/images/effect_spread.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 42 KiB |
|
@ -152,7 +152,7 @@ class TestImage(PillowTestCase):
|
||||||
|
|
||||||
# Assert
|
# Assert
|
||||||
self.assertEqual(im.size, (512, 512))
|
self.assertEqual(im.size, (512, 512))
|
||||||
im2 = Image.open('Tests/images/mandelbrot.png')
|
im2 = Image.open('Tests/images/effect_mandelbrot.png')
|
||||||
self.assert_image_equal(im, im2)
|
self.assert_image_equal(im, im2)
|
||||||
|
|
||||||
@unittest.skipUnless(sys.platform.startswith('win32'),
|
@unittest.skipUnless(sys.platform.startswith('win32'),
|
||||||
|
@ -170,6 +170,19 @@ class TestImage(PillowTestCase):
|
||||||
self.assertEqual(im.getpixel((0, 0)), 60)
|
self.assertEqual(im.getpixel((0, 0)), 60)
|
||||||
self.assertEqual(im.getpixel((0, 1)), 28)
|
self.assertEqual(im.getpixel((0, 1)), 28)
|
||||||
|
|
||||||
|
def test_effect_spread(self):
|
||||||
|
# Arrange
|
||||||
|
im = lena()
|
||||||
|
distance = 10
|
||||||
|
|
||||||
|
# Act
|
||||||
|
im2 = im.effect_spread(distance)
|
||||||
|
|
||||||
|
# Assert
|
||||||
|
self.assertEqual(im.size, (128, 128))
|
||||||
|
im3 = Image.open('Tests/images/effect_spread.png')
|
||||||
|
self.assert_image_equal(im2, im3)
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
|
||||||
|
|
|
@ -124,11 +124,11 @@ ImagingEffectSpread(Imaging imIn, int distance)
|
||||||
imOut = ImagingNew(imIn->mode, imIn->xsize, imIn->ysize);
|
imOut = ImagingNew(imIn->mode, imIn->xsize, imIn->ysize);
|
||||||
|
|
||||||
if (!imOut)
|
if (!imOut)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
#define SPREAD(type, image)\
|
#define SPREAD(type, image)\
|
||||||
for (y = 0; y < imIn->ysize; y++)\
|
for (y = 0; y < imIn->ysize; y++)\
|
||||||
for (x = 0; x < imIn->xsize; x++) {\
|
for (x = 0; x < imIn->xsize; x++) {\
|
||||||
int xx = x + (rand() % distance) - distance/2;\
|
int xx = x + (rand() % distance) - distance/2;\
|
||||||
int yy = y + (rand() % distance) - distance/2;\
|
int yy = y + (rand() % distance) - distance/2;\
|
||||||
if (xx >= 0 && xx < imIn->xsize && yy >= 0 && yy < imIn->ysize) {\
|
if (xx >= 0 && xx < imIn->xsize && yy >= 0 && yy < imIn->ysize) {\
|
||||||
|
@ -139,9 +139,9 @@ ImagingEffectSpread(Imaging imIn, int distance)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (imIn->image8) {
|
if (imIn->image8) {
|
||||||
SPREAD(UINT8, image8);
|
SPREAD(UINT8, image8);
|
||||||
} else {
|
} else {
|
||||||
SPREAD(INT32, image32);
|
SPREAD(INT32, image32);
|
||||||
}
|
}
|
||||||
|
|
||||||
ImagingCopyInfo(imOut, imIn);
|
ImagingCopyInfo(imOut, imIn);
|
||||||
|
|
Loading…
Reference in New Issue
Block a user