mirror of
https://github.com/python-pillow/Pillow.git
synced 2024-12-26 01:46:18 +03:00
Note that the fill behaviour only affects libwebp >= 0.5
This commit is contained in:
parent
96a4d98abc
commit
7e5e843d5c
|
@ -97,38 +97,33 @@ def test_write_rgba(tmp_path):
|
||||||
assert_image_similar(image, pil_image, 1.0)
|
assert_image_similar(image, pil_image, 1.0)
|
||||||
|
|
||||||
|
|
||||||
def test_write_rgba_keep_transparent(tmp_path):
|
def test_keep_rgb_values_when_transparent(tmp_path):
|
||||||
"""
|
"""
|
||||||
Can we write a RGBA mode file to WebP while preserving
|
Saving transparent pixels should retain their original RGB values
|
||||||
the transparent RGB without error.
|
when using the "exact" parameter.
|
||||||
Does it have the bits we expect?
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
temp_output_file = str(tmp_path / "temp.webp")
|
image = hopper("RGB")
|
||||||
|
|
||||||
input_image = hopper("RGB")
|
# create a copy of the image
|
||||||
# make a copy of the image
|
# with the left half transparent
|
||||||
output_image = input_image.copy()
|
half_transparent_image = image.copy()
|
||||||
# make a single channel image with the same size as input_image
|
new_alpha = Image.new("L", (128, 128), 255)
|
||||||
new_alpha = Image.new("L", input_image.size, 255)
|
new_alpha.paste(0, (0, 0, 64, 128))
|
||||||
# make the left half transparent
|
half_transparent_image.putalpha(new_alpha)
|
||||||
new_alpha.paste((0,), (0, 0, new_alpha.size[0] // 2, new_alpha.size[1]))
|
|
||||||
# putalpha on output_image
|
|
||||||
output_image.putalpha(new_alpha)
|
|
||||||
|
|
||||||
# now save with transparent area preserved.
|
# save with transparent area preserved
|
||||||
output_image.save(temp_output_file, "WEBP", exact=True, lossless=True)
|
temp_file = str(tmp_path / "temp.webp")
|
||||||
# even though it is lossless, if we don't put exact=True, the transparent
|
half_transparent_image.save(temp_file, exact=True, lossless=True)
|
||||||
# area will be filled with black (or something more conducive to compression)
|
|
||||||
|
|
||||||
with Image.open(temp_output_file) as image:
|
with Image.open(temp_file) as reloaded:
|
||||||
image.load()
|
assert reloaded.mode == "RGBA"
|
||||||
|
assert reloaded.format == "WEBP"
|
||||||
|
|
||||||
assert image.mode == "RGBA"
|
# even though it is lossless, if we don't use exact=True
|
||||||
assert image.format == "WEBP"
|
# in libwebp >= 0.5, the transparent area will be filled with black
|
||||||
image.load()
|
# (or something more conducive to compression)
|
||||||
image = image.convert("RGB")
|
assert_image_similar(reloaded.convert("RGB"), image, 1)
|
||||||
assert_image_similar(image, input_image, 1.0)
|
|
||||||
|
|
||||||
|
|
||||||
def test_write_unsupported_mode_PA(tmp_path):
|
def test_write_unsupported_mode_PA(tmp_path):
|
||||||
|
|
Loading…
Reference in New Issue
Block a user