mirror of
				https://github.com/python-pillow/Pillow.git
				synced 2025-10-26 05:31:02 +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: |         with Image.open("Tests/images/effect_spread.png") as im3: | ||||||
|             assert_image_similar(im2, im3, 110) |             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): |     def test_check_size(self): | ||||||
|         # Checking that the _check_size function throws value errors when we want it to |         # Checking that the _check_size function throws value errors when we want it to | ||||||
|         with pytest.raises(ValueError): |         with pytest.raises(ValueError): | ||||||
|  |  | ||||||
|  | @ -131,6 +131,13 @@ ImagingEffectSpread(Imaging imIn, int distance) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| #define SPREAD(type, image)\ | #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 (y = 0; y < imOut->ysize; y++) {\ | ||||||
|             for (x = 0; x < imOut->xsize; x++) {\ |             for (x = 0; x < imOut->xsize; x++) {\ | ||||||
|                 int xx = x + (rand() % distance) - distance/2;\ |                 int xx = x + (rand() % distance) - distance/2;\ | ||||||
|  | @ -142,6 +149,7 @@ ImagingEffectSpread(Imaging imIn, int distance) | ||||||
|                     imOut->image[y][x]   = imIn->image[y][x];\ |                     imOut->image[y][x]   = imIn->image[y][x];\ | ||||||
|                 }\ |                 }\ | ||||||
|             }\ |             }\ | ||||||
|  |         }\ | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (imIn->image8) { |     if (imIn->image8) { | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user