| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | from __future__ import annotations |
| |
|
| | from . import Image, ImageFilter, ImageStat |
| |
|
| |
|
| | class _Enhance: |
| | image: Image.Image |
| | degenerate: Image.Image |
| |
|
| | def enhance(self, factor: float) -> Image.Image: |
| | """ |
| | Returns an enhanced image. |
| | |
| | :param factor: A floating point value controlling the enhancement. |
| | Factor 1.0 always returns a copy of the original image, |
| | lower factors mean less color (brightness, contrast, |
| | etc), and higher values more. There are no restrictions |
| | on this value. |
| | :rtype: :py:class:`~PIL.Image.Image` |
| | """ |
| | return Image.blend(self.degenerate, self.image, factor) |
| |
|
| |
|
| | class Color(_Enhance): |
| | """Adjust image color balance. |
| | |
| | This class can be used to adjust the colour balance of an image, in |
| | a manner similar to the controls on a colour TV set. An enhancement |
| | factor of 0.0 gives a black and white image. A factor of 1.0 gives |
| | the original image. |
| | """ |
| |
|
| | def __init__(self, image: Image.Image) -> None: |
| | self.image = image |
| | self.intermediate_mode = "L" |
| | if "A" in image.getbands(): |
| | self.intermediate_mode = "LA" |
| |
|
| | if self.intermediate_mode != image.mode: |
| | image = image.convert(self.intermediate_mode).convert(image.mode) |
| | self.degenerate = image |
| |
|
| |
|
| | class Contrast(_Enhance): |
| | """Adjust image contrast. |
| | |
| | This class can be used to control the contrast of an image, similar |
| | to the contrast control on a TV set. An enhancement factor of 0.0 |
| | gives a solid gray image. A factor of 1.0 gives the original image. |
| | """ |
| |
|
| | def __init__(self, image: Image.Image) -> None: |
| | self.image = image |
| | if image.mode != "L": |
| | image = image.convert("L") |
| | mean = int(ImageStat.Stat(image).mean[0] + 0.5) |
| | self.degenerate = Image.new("L", image.size, mean) |
| | if self.degenerate.mode != self.image.mode: |
| | self.degenerate = self.degenerate.convert(self.image.mode) |
| |
|
| | if "A" in self.image.getbands(): |
| | self.degenerate.putalpha(self.image.getchannel("A")) |
| |
|
| |
|
| | class Brightness(_Enhance): |
| | """Adjust image brightness. |
| | |
| | This class can be used to control the brightness of an image. An |
| | enhancement factor of 0.0 gives a black image. A factor of 1.0 gives the |
| | original image. |
| | """ |
| |
|
| | def __init__(self, image: Image.Image) -> None: |
| | self.image = image |
| | self.degenerate = Image.new(image.mode, image.size, 0) |
| |
|
| | if "A" in image.getbands(): |
| | self.degenerate.putalpha(image.getchannel("A")) |
| |
|
| |
|
| | class Sharpness(_Enhance): |
| | """Adjust image sharpness. |
| | |
| | This class can be used to adjust the sharpness of an image. An |
| | enhancement factor of 0.0 gives a blurred image, a factor of 1.0 gives the |
| | original image, and a factor of 2.0 gives a sharpened image. |
| | """ |
| |
|
| | def __init__(self, image: Image.Image) -> None: |
| | self.image = image |
| | self.degenerate = image.filter(ImageFilter.SMOOTH) |
| |
|
| | if "A" in image.getbands(): |
| | self.degenerate.putalpha(image.getchannel("A")) |
| |
|