ImageOps Module

The ImageOps module contains a number of ‘ready-made’ imageprocessing operations. This module is somewhat experimental, and most operatorsonly work on L and RGB images.

New in version 1.1.3.

  • PIL.ImageOps.autocontrast(image, cutoff=0, ignore=None)[source]
  • Maximize (normalize) image contrast. This function calculates ahistogram of the input image, removes cutoff percent of thelightest and darkest pixels from the histogram, and remaps the imageso that the darkest pixel becomes black (0), and the lightestbecomes white (255).

Parameters:

  • image – The image to process.
  • cutoff – How many percent to cut off from the histogram.
  • ignore – The background pixel value (use None for no background).Returns:
    An image.
  • PIL.ImageOps.colorize(image, black, white, mid=None, blackpoint=0, whitepoint=255, midpoint=127)[source]
  • Colorize grayscale image.This function calculates a color wedge which maps all black pixels inthe source image to the first color and all white pixels to thesecond color. If mid is specified, it uses three-color mapping.The black and white arguments should be RGB tuples or color names;optionally you can use three-color mapping by also specifying mid.Mapping positions for any of the colors can be specified(e.g. blackpoint), where these parameters are the integervalue corresponding to where the corresponding color should be mapped.These parameters must have logical order, such thatblackpoint <= midpoint <= whitepoint (if mid is specified).

Parameters:

  • image – The image to colorize.
  • black – The color to use for black input pixels.
  • white – The color to use for white input pixels.
  • mid – The color to use for midtone input pixels.
  • blackpoint – an int value [0, 255] for the black mapping.
  • whitepoint – an int value [0, 255] for the white mapping.
  • midpoint – an int value [0, 255] for the midtone mapping.Returns:
    An image.
  • PIL.ImageOps.pad(image, size, method=3, color=None, centering=(0.5, 0.5))[source]
  • Returns a sized and padded version of the image, expanded to fill therequested aspect ratio and size.

Parameters:

  • image – The image to size and crop.
  • size – The requested output size in pixels, given as a(width, height) tuple.
  • method – What resampling method to use. Default isPIL.Image.BICUBIC. See Filters.
  • color – The background color of the padded image.
  • centering
    Control the position of the original image within thepadded version.

(0.5, 0.5) will keep the image centered
(0, 0) will keep the image aligned to the top left
(1, 1) will keep the image aligned to the bottom
right

Returns:
An image.

  • PIL.ImageOps.crop(image, border=0)[source]
  • Remove border from image. The same amount of pixels are removedfrom all four sides. This function works on all image modes.

See also

crop()

Parameters:

  • image – The image to crop.
  • border – The number of pixels to remove.Returns:
    An image.
  • PIL.ImageOps.scale(image, factor, resample=3)[source]
  • Returns a rescaled image by a specific factor given in parameter.A factor greater than 1 expands the image, between 0 and 1 contracts theimage.

Parameters:

  • image – The image to rescale.
  • factor – The expansion factor, as a float.
  • resample – What resampling method to use. Default isPIL.Image.BICUBIC. See Filters.Returns:
    An Image object.
  • PIL.ImageOps.deform(image, deformer, resample=2)[source]
  • Deform the image.

Parameters:

  • image – The image to deform.
  • deformer – A deformer object. Any object that implements agetmesh method can be used.
  • resample – An optional resampling filter. Same values possible asin the PIL.Image.transform function.Returns:
    An image.
  • PIL.ImageOps.equalize(image, mask=None)[source]
  • Equalize the image histogram. This function applies a non-linearmapping to the input image, in order to create a uniformdistribution of grayscale values in the output image.

Parameters:

  • image – The image to equalize.
  • mask – An optional mask. If given, only the pixels selected bythe mask are included in the analysis.Returns:
    An image.
  • PIL.ImageOps.expand(image, border=0, fill=0)[source]
  • Add border to the image

Parameters:

  • image – The image to expand.
  • border – Border width, in pixels.
  • fill – Pixel fill value (a color value). Default is 0 (black).Returns:
    An image.
  • PIL.ImageOps.fit(image, size, method=3, bleed=0.0, centering=(0.5, 0.5))[source]
  • Returns a sized and cropped version of the image, cropped to therequested aspect ratio and size.

This function was contributed by Kevin Cazabon.

Parameters:

  • image – The image to size and crop.
  • size – The requested output size in pixels, given as a(width, height) tuple.
  • method – What resampling method to use. Default isPIL.Image.BICUBIC. See Filters.
  • bleed – Remove a border around the outside of the image from allfour edges. The value is a decimal percentage (use 0.01 forone percent). The default value is 0 (no border).Cannot be greater than or equal to 0.5.
  • centering – Control the cropping position. Use (0.5, 0.5) forcenter cropping (e.g. if cropping the width, take 50% offof the left side, and therefore 50% off the right side).(0.0, 0.0) will crop from the top left corner (i.e. ifcropping the width, take all of the crop off of the rightside, and if cropping the height, take all of it off thebottom). (1.0, 0.0) will crop from the bottom leftcorner, etc. (i.e. if cropping the width, take all of thecrop off the left side, and if cropping the height takenone from the top, and therefore all off the bottom).Returns:
    An image.
  • PIL.ImageOps.flip(image)[source]
  • Flip the image vertically (top to bottom).

Parameters:image – The image to flip.Returns:An image.

  • PIL.ImageOps.grayscale(image)[source]
  • Convert the image to grayscale.

Parameters:image – The image to convert.Returns:An image.

  • PIL.ImageOps.invert(image)[source]
  • Invert (negate) the image.

Parameters:image – The image to invert.Returns:An image.

  • PIL.ImageOps.mirror(image)[source]
  • Flip image horizontally (left to right).

Parameters:image – The image to mirror.Returns:An image.

  • PIL.ImageOps.posterize(image, bits)[source]
  • Reduce the number of bits for each color channel.

Parameters:

  • image – The image to posterize.
  • bits – The number of bits to keep for each channel (1-8).Returns:
    An image.
  • PIL.ImageOps.solarize(image, threshold=128)[source]
  • Invert all pixel values above a threshold.

Parameters:

  • image – The image to solarize.
  • threshold – All pixels above this greyscale level are inverted.Returns:
    An image.
  • PIL.ImageOps.exiftranspose(_image)[source]
  • If an image has an EXIF Orientation tag, return a new image that istransposed accordingly. Otherwise, return a copy of the image.

Parameters:image – The image to transpose.Returns:An image.