| # | 
| # 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.sgi.com/grafica/interp/index.html | 
| # | 
| # 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. | 
| # | 
|   | 
| import Image, ImageFilter, ImageStat | 
|   | 
| class _Enhance: | 
|   | 
|     ## | 
|     # Returns an enhanced image. The enhancement factor is a floating | 
|     # point value controlling the enhancement. Factor 1.0 always | 
|     # returns a copy of the original image, lower factors mean less | 
|     # colour (brightness, contrast, etc), and higher values more. | 
|     # There are no restrictions on this value. | 
|     # | 
|     # @param factor Enhancement factor. | 
|     # @return An enhanced image. | 
|   | 
|     def enhance(self, factor): | 
|         return Image.blend(self.degenerate, self.image, factor) | 
|   | 
| ## | 
| # Color enhancement object. | 
| # <p> | 
| # 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. | 
|   | 
| class Color(_Enhance): | 
|     "Adjust image colour balance" | 
|     def __init__(self, image): | 
|         self.image = image | 
|         self.degenerate = image.convert("L").convert(image.mode) | 
|   | 
| ## | 
| # Contrast enhancement object. | 
| # <p> | 
| # 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 grey image, factor 1.0 gives the original image. | 
|   | 
| class Contrast(_Enhance): | 
|     "Adjust image contrast" | 
|     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) | 
|   | 
| ## | 
| # Brightness enhancement object. | 
| # <p> | 
| # This class can be used to control the brighntess of an image.  An | 
| # enhancement factor of 0.0 gives a black image, factor 1.0 gives the | 
| # original image. | 
|   | 
| class Brightness(_Enhance): | 
|     "Adjust image brightness" | 
|     def __init__(self, image): | 
|         self.image = image | 
|         self.degenerate = Image.new(image.mode, image.size, 0) | 
|   | 
| ## | 
| # Sharpness enhancement object. | 
| # <p> | 
| # This class can be used to adjust the sharpness of an image.  The | 
| # enhancement factor 0.0 gives a blurred image, 1.0 gives the original | 
| # image, and a factor of 2.0 gives a sharpened image. | 
|   | 
| class Sharpness(_Enhance): | 
|     "Adjust image sharpness" | 
|     def __init__(self, image): | 
|         self.image = image | 
|         self.degenerate = image.filter(ImageFilter.SMOOTH) |