mirror of
				https://github.com/python-pillow/Pillow.git
				synced 2025-10-20 18:54:31 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			278 lines
		
	
	
		
			7.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			278 lines
		
	
	
		
			7.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from __future__ import annotations
 | |
| 
 | |
| import pytest
 | |
| 
 | |
| from PIL import Image, ImageFilter
 | |
| 
 | |
| sample = Image.new("L", (7, 5))
 | |
| # fmt: off
 | |
| sample.putdata(sum([
 | |
|     [210, 50,  20,  10,  220, 230, 80],
 | |
|     [190, 210, 20,  180, 170, 40,  110],
 | |
|     [120, 210, 250, 60,  220, 0,   220],
 | |
|     [220, 40,  230, 80,  130, 250, 40],
 | |
|     [250, 0,   80,  30,  60,  20,  110],
 | |
| ], []))
 | |
| # fmt: on
 | |
| 
 | |
| 
 | |
| def test_imageops_box_blur() -> None:
 | |
|     i = sample.filter(ImageFilter.BoxBlur(1))
 | |
|     assert i.mode == sample.mode
 | |
|     assert i.size == sample.size
 | |
|     assert isinstance(i, Image.Image)
 | |
| 
 | |
| 
 | |
| def box_blur(image: Image.Image, radius: float = 1, n: int = 1) -> Image.Image:
 | |
|     return image._new(image.im.box_blur((radius, radius), n))
 | |
| 
 | |
| 
 | |
| def assert_image(im: Image.Image, data: list[list[int]], delta: int = 0) -> None:
 | |
|     it = iter(im.getdata())
 | |
|     for data_row in data:
 | |
|         im_row = [next(it) for _ in range(im.size[0])]
 | |
|         if any(abs(data_v - im_v) > delta for data_v, im_v in zip(data_row, im_row)):
 | |
|             assert im_row == data_row
 | |
|     with pytest.raises(StopIteration):
 | |
|         next(it)
 | |
| 
 | |
| 
 | |
| def assert_blur(
 | |
|     im: Image.Image,
 | |
|     radius: float,
 | |
|     data: list[list[int]],
 | |
|     passes: int = 1,
 | |
|     delta: int = 0,
 | |
| ) -> None:
 | |
|     # check grayscale image
 | |
|     assert_image(box_blur(im, radius, passes), data, delta)
 | |
|     rgba = Image.merge("RGBA", (im, im, im, im))
 | |
|     for band in box_blur(rgba, radius, passes).split():
 | |
|         assert_image(band, data, delta)
 | |
| 
 | |
| 
 | |
| def test_color_modes() -> None:
 | |
|     with pytest.raises(ValueError):
 | |
|         box_blur(sample.convert("1"))
 | |
|     with pytest.raises(ValueError):
 | |
|         box_blur(sample.convert("P"))
 | |
|     box_blur(sample.convert("L"))
 | |
|     box_blur(sample.convert("LA"))
 | |
|     box_blur(sample.convert("LA").convert("La"))
 | |
|     with pytest.raises(ValueError):
 | |
|         box_blur(sample.convert("I"))
 | |
|     with pytest.raises(ValueError):
 | |
|         box_blur(sample.convert("F"))
 | |
|     box_blur(sample.convert("RGB"))
 | |
|     box_blur(sample.convert("RGBA"))
 | |
|     box_blur(sample.convert("RGBA").convert("RGBa"))
 | |
|     box_blur(sample.convert("CMYK"))
 | |
|     with pytest.raises(ValueError):
 | |
|         box_blur(sample.convert("YCbCr"))
 | |
| 
 | |
| 
 | |
| @pytest.mark.parametrize("size", ((0, 1), (1, 0)))
 | |
| def test_zero_dimension(size: tuple[int, int]) -> None:
 | |
|     assert box_blur(Image.new("L", size)).size == size
 | |
| 
 | |
| 
 | |
| def test_radius_0() -> None:
 | |
|     assert_blur(
 | |
|         sample,
 | |
|         0,
 | |
|         [
 | |
|             # fmt: off
 | |
|             [210, 50,  20,  10,  220, 230, 80],
 | |
|             [190, 210, 20,  180, 170, 40,  110],
 | |
|             [120, 210, 250, 60,  220, 0,   220],
 | |
|             [220, 40,  230, 80,  130, 250, 40],
 | |
|             [250, 0,   80,  30,  60,  20,  110],
 | |
|             # fmt: on
 | |
|         ],
 | |
|     )
 | |
| 
 | |
| 
 | |
| def test_radius_0_02() -> None:
 | |
|     assert_blur(
 | |
|         sample,
 | |
|         0.02,
 | |
|         [
 | |
|             # fmt: off
 | |
|             [206, 55,  20,  17,  215, 223, 83],
 | |
|             [189, 203, 31,  171, 169, 46,  110],
 | |
|             [125, 206, 241, 69,  210, 13,  210],
 | |
|             [215, 49,  221, 82,  131, 235, 48],
 | |
|             [244, 7,   80,  32,  60,  27,  107],
 | |
|             # fmt: on
 | |
|         ],
 | |
|         delta=2,
 | |
|     )
 | |
| 
 | |
| 
 | |
| def test_radius_0_05() -> None:
 | |
|     assert_blur(
 | |
|         sample,
 | |
|         0.05,
 | |
|         [
 | |
|             # fmt: off
 | |
|             [202, 62,  22,  27,  209, 215, 88],
 | |
|             [188, 194, 44,  161, 168, 56,  111],
 | |
|             [131, 201, 229, 81,  198, 31,  198],
 | |
|             [209, 62,  209, 86,  133, 216, 59],
 | |
|             [237, 17,  80,  36,  60,  35,  103],
 | |
|             # fmt: on
 | |
|         ],
 | |
|         delta=2,
 | |
|     )
 | |
| 
 | |
| 
 | |
| def test_radius_0_1() -> None:
 | |
|     assert_blur(
 | |
|         sample,
 | |
|         0.1,
 | |
|         [
 | |
|             # fmt: off
 | |
|             [196, 72,  24,  40,  200, 203, 93],
 | |
|             [187, 183, 62,  148, 166, 68,  111],
 | |
|             [139, 193, 213, 96,  182, 54,  182],
 | |
|             [201, 78,  193, 91,  133, 191, 73],
 | |
|             [227, 31,  80,  42,  61,  47,  99],
 | |
|             # fmt: on
 | |
|         ],
 | |
|         delta=1,
 | |
|     )
 | |
| 
 | |
| 
 | |
| def test_radius_0_5() -> None:
 | |
|     assert_blur(
 | |
|         sample,
 | |
|         0.5,
 | |
|         [
 | |
|             # fmt: off
 | |
|             [176, 101, 46,  83,  163, 165, 111],
 | |
|             [176, 149, 108, 122, 144, 120, 117],
 | |
|             [164, 171, 159, 141, 134, 119, 129],
 | |
|             [170, 136, 133, 114, 116, 124, 109],
 | |
|             [184, 95,  72,  70,  69,  81,  89],
 | |
|             # fmt: on
 | |
|         ],
 | |
|         delta=1,
 | |
|     )
 | |
| 
 | |
| 
 | |
| def test_radius_1() -> None:
 | |
|     assert_blur(
 | |
|         sample,
 | |
|         1,
 | |
|         [
 | |
|             # fmt: off
 | |
|             [170, 109, 63,  97,  146, 153, 116],
 | |
|             [168, 142, 112, 128, 126, 143, 121],
 | |
|             [169, 166, 142, 149, 126, 131, 114],
 | |
|             [159, 156, 109, 127, 94,  117, 112],
 | |
|             [164, 128, 63,  87,  76,  89,  90],
 | |
|             # fmt: on
 | |
|         ],
 | |
|         delta=1,
 | |
|     )
 | |
| 
 | |
| 
 | |
| def test_radius_1_5() -> None:
 | |
|     assert_blur(
 | |
|         sample,
 | |
|         1.5,
 | |
|         [
 | |
|             # fmt: off
 | |
|             [155, 120, 105, 112, 124, 137, 130],
 | |
|             [160, 136, 124, 125, 127, 134, 130],
 | |
|             [166, 147, 130, 125, 120, 121, 119],
 | |
|             [168, 145, 119, 109, 103, 105, 110],
 | |
|             [168, 134, 96,  85,  85,  89,  97],
 | |
|             # fmt: on
 | |
|         ],
 | |
|         delta=1,
 | |
|     )
 | |
| 
 | |
| 
 | |
| def test_radius_bigger_then_half() -> None:
 | |
|     assert_blur(
 | |
|         sample,
 | |
|         3,
 | |
|         [
 | |
|             # fmt: off
 | |
|             [144, 145, 142, 128, 114, 115, 117],
 | |
|             [148, 145, 137, 122, 109, 111, 112],
 | |
|             [152, 145, 131, 117, 103, 107, 108],
 | |
|             [156, 144, 126, 111, 97,  102, 103],
 | |
|             [160, 144, 121, 106, 92,  98,  99],
 | |
|             # fmt: on
 | |
|         ],
 | |
|         delta=1,
 | |
|     )
 | |
| 
 | |
| 
 | |
| def test_radius_bigger_then_width() -> None:
 | |
|     assert_blur(
 | |
|         sample,
 | |
|         10,
 | |
|         [
 | |
|             [158, 153, 147, 141, 135, 129, 123],
 | |
|             [159, 153, 147, 141, 136, 130, 124],
 | |
|             [159, 154, 148, 142, 136, 130, 124],
 | |
|             [160, 154, 148, 142, 137, 131, 125],
 | |
|             [160, 155, 149, 143, 137, 131, 125],
 | |
|         ],
 | |
|         delta=0,
 | |
|     )
 | |
| 
 | |
| 
 | |
| def test_extreme_large_radius() -> None:
 | |
|     assert_blur(
 | |
|         sample,
 | |
|         600,
 | |
|         [
 | |
|             [162, 162, 162, 162, 162, 162, 162],
 | |
|             [162, 162, 162, 162, 162, 162, 162],
 | |
|             [162, 162, 162, 162, 162, 162, 162],
 | |
|             [162, 162, 162, 162, 162, 162, 162],
 | |
|             [162, 162, 162, 162, 162, 162, 162],
 | |
|         ],
 | |
|         delta=1,
 | |
|     )
 | |
| 
 | |
| 
 | |
| def test_two_passes() -> None:
 | |
|     assert_blur(
 | |
|         sample,
 | |
|         1,
 | |
|         [
 | |
|             # fmt: off
 | |
|             [153, 123, 102, 109, 132, 135, 129],
 | |
|             [159, 138, 123, 121, 133, 131, 126],
 | |
|             [162, 147, 136, 124, 127, 121, 121],
 | |
|             [159, 140, 125, 108, 111, 106, 108],
 | |
|             [154, 126, 105, 87,  94,  93,  97],
 | |
|             # fmt: on
 | |
|         ],
 | |
|         passes=2,
 | |
|         delta=1,
 | |
|     )
 | |
| 
 | |
| 
 | |
| def test_three_passes() -> None:
 | |
|     assert_blur(
 | |
|         sample,
 | |
|         1,
 | |
|         [
 | |
|             # fmt: off
 | |
|             [146, 131, 116, 118, 126, 131, 130],
 | |
|             [151, 138, 125, 123, 126, 128, 127],
 | |
|             [154, 143, 129, 123, 120, 120, 119],
 | |
|             [152, 139, 122, 113, 108, 108, 108],
 | |
|             [148, 132, 112, 102, 97,  99,  100],
 | |
|             # fmt: on
 | |
|         ],
 | |
|         passes=3,
 | |
|         delta=1,
 | |
|     )
 |