Pillow

Форк
0
/
test_mode_i16.py 
100 строк · 2.5 Кб
1
from __future__ import annotations
2

3
from pathlib import Path
4

5
import pytest
6

7
from PIL import Image
8

9
from .helper import hopper
10

11
original = hopper().resize((32, 32)).convert("I")
12

13

14
def verify(im1: Image.Image) -> None:
15
    im2 = original.copy()
16
    assert im1.size == im2.size
17
    pix1 = im1.load()
18
    pix2 = im2.load()
19
    assert pix1 is not None
20
    assert pix2 is not None
21
    for y in range(im1.size[1]):
22
        for x in range(im1.size[0]):
23
            xy = x, y
24
            p1 = pix1[xy]
25
            p2 = pix2[xy]
26
            assert (
27
                p1 == p2
28
            ), f"got {repr(p1)} from mode {im1.mode} at {xy}, expected {repr(p2)}"
29

30

31
@pytest.mark.parametrize("mode", ("L", "I;16", "I;16B", "I;16L", "I"))
32
def test_basic(tmp_path: Path, mode: str) -> None:
33
    # PIL 1.1 has limited support for 16-bit image data.  Check that
34
    # create/copy/transform and save works as expected.
35

36
    im_in = original.convert(mode)
37
    verify(im_in)
38

39
    w, h = im_in.size
40

41
    im_out = im_in.copy()
42
    verify(im_out)  # copy
43

44
    im_out = im_in.transform((w, h), Image.Transform.EXTENT, (0, 0, w, h))
45
    verify(im_out)  # transform
46

47
    filename = str(tmp_path / "temp.im")
48
    im_in.save(filename)
49

50
    with Image.open(filename) as im_out:
51
        verify(im_in)
52
        verify(im_out)
53

54
    im_out = im_in.crop((0, 0, w, h))
55
    verify(im_out)
56

57
    im_out = Image.new(mode, (w, h), None)
58
    im_out.paste(im_in.crop((0, 0, w // 2, h)), (0, 0))
59
    im_out.paste(im_in.crop((w // 2, 0, w, h)), (w // 2, 0))
60

61
    verify(im_in)
62
    verify(im_out)
63

64
    im_in = Image.new(mode, (1, 1), 1)
65
    assert im_in.getpixel((0, 0)) == 1
66

67
    im_in.putpixel((0, 0), 2)
68
    assert im_in.getpixel((0, 0)) == 2
69

70
    if mode == "L":
71
        maximum = 255
72
    else:
73
        maximum = 32767
74

75
    im_in = Image.new(mode, (1, 1), 256)
76
    assert im_in.getpixel((0, 0)) == min(256, maximum)
77

78
    im_in.putpixel((0, 0), 512)
79
    assert im_in.getpixel((0, 0)) == min(512, maximum)
80

81

82
def test_tobytes() -> None:
83
    def tobytes(mode: str) -> bytes:
84
        return Image.new(mode, (1, 1), 1).tobytes()
85

86
    order = 1 if Image._ENDIAN == "<" else -1
87

88
    assert tobytes("L") == b"\x01"
89
    assert tobytes("I;16") == b"\x01\x00"
90
    assert tobytes("I;16B") == b"\x00\x01"
91
    assert tobytes("I") == b"\x01\x00\x00\x00"[::order]
92

93

94
def test_convert() -> None:
95
    im = original.copy()
96

97
    for mode in ("I;16", "I;16B", "I;16N"):
98
        verify(im.convert(mode))
99
        verify(im.convert(mode).convert("L"))
100
        verify(im.convert(mode).convert("I"))
101

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.