Pillow/src/PIL/ImageEnhance.py

104 lines
3.1 KiB
Python
Raw Normal View History

2010-07-31 06:52:47 +04:00
#
# The Python Imaging Library.
# $Id$
#
# image enhancement classes
#
# For a background, see "Image Processing By Interpolation and
# Extrapolation", Paul Haeberli and Douglas Voorhies. Available
# at http://www.graficaobscura.com/interp/index.html
2010-07-31 06:52:47 +04:00
#
# History:
# 1996-03-23 fl Created
# 2009-06-16 fl Fixed mean calculation
#
# Copyright (c) Secret Labs AB 1997.
# Copyright (c) Fredrik Lundh 1996.
#
# See the README file for information on usage and redistribution.
#
from . import Image, ImageFilter, ImageStat
2010-07-31 06:52:47 +04:00
class _Enhance:
2010-07-31 06:52:47 +04:00
def enhance(self, factor):
2013-10-13 00:48:34 +04:00
"""
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`
"""
2010-07-31 06:52:47 +04:00
return Image.blend(self.degenerate, self.image, factor)
class Color(_Enhance):
2013-10-13 00:48:34 +04:00
"""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.
"""
2019-03-21 16:28:20 +03:00
2010-07-31 06:52:47 +04:00
def __init__(self, image):
self.image = image
2019-03-21 16:28:20 +03:00
self.intermediate_mode = "L"
if "A" in image.getbands():
self.intermediate_mode = "LA"
2010-07-31 06:52:47 +04:00
2019-03-21 16:28:20 +03:00
self.degenerate = image.convert(self.intermediate_mode).convert(image.mode)
2010-07-31 06:52:47 +04:00
2015-04-24 02:26:52 +03:00
2010-07-31 06:52:47 +04:00
class Contrast(_Enhance):
2013-10-13 00:48:34 +04:00
"""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
2023-10-19 11:12:01 +03:00
gives a solid gray image. A factor of 1.0 gives the original image.
2013-10-13 00:48:34 +04:00
"""
2019-03-21 16:28:20 +03:00
2010-07-31 06:52:47 +04:00
def __init__(self, image):
self.image = image
mean = int(ImageStat.Stat(image.convert("L")).mean[0] + 0.5)
self.degenerate = Image.new("L", image.size, mean).convert(image.mode)
2019-03-21 16:28:20 +03:00
if "A" in image.getbands():
self.degenerate.putalpha(image.getchannel("A"))
2010-07-31 06:52:47 +04:00
class Brightness(_Enhance):
2013-10-13 00:48:34 +04:00
"""Adjust image brightness.
2015-05-28 10:20:33 +03:00
This class can be used to control the brightness of an image. An
2013-10-13 00:48:34 +04:00
enhancement factor of 0.0 gives a black image. A factor of 1.0 gives the
original image.
"""
2019-03-21 16:28:20 +03:00
2010-07-31 06:52:47 +04:00
def __init__(self, image):
self.image = image
self.degenerate = Image.new(image.mode, image.size, 0)
2019-03-21 16:28:20 +03:00
if "A" in image.getbands():
self.degenerate.putalpha(image.getchannel("A"))
2010-07-31 06:52:47 +04:00
class Sharpness(_Enhance):
2013-10-13 00:48:34 +04:00
"""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.
"""
2019-03-21 16:28:20 +03:00
2010-07-31 06:52:47 +04:00
def __init__(self, image):
self.image = image
self.degenerate = image.filter(ImageFilter.SMOOTH)
2019-03-21 16:28:20 +03:00
if "A" in image.getbands():
self.degenerate.putalpha(image.getchannel("A"))