Add tutorial images
BIN
docs/handbook/contrasted_hopper.jpg
Normal file
After Width: | Height: | Size: 5.4 KiB |
BIN
docs/handbook/cropped_hopper.jpg
Normal file
After Width: | Height: | Size: 2.0 KiB |
BIN
docs/handbook/enhanced_hopper.jpg
Normal file
After Width: | Height: | Size: 5.6 KiB |
BIN
docs/handbook/flip_left_right_hopper.jpg
Normal file
After Width: | Height: | Size: 4.5 KiB |
BIN
docs/handbook/flip_top_bottom_hopper.jpg
Normal file
After Width: | Height: | Size: 4.5 KiB |
BIN
docs/handbook/masked_hopper.jpg
Normal file
After Width: | Height: | Size: 4.8 KiB |
BIN
docs/handbook/merged_hopper.png
Normal file
After Width: | Height: | Size: 35 KiB |
BIN
docs/handbook/pasted_hopper.jpg
Normal file
After Width: | Height: | Size: 4.5 KiB |
BIN
docs/handbook/rebanded_hopper.jpg
Normal file
After Width: | Height: | Size: 4.6 KiB |
BIN
docs/handbook/rolled_hopper.jpg
Normal file
After Width: | Height: | Size: 4.5 KiB |
BIN
docs/handbook/rotated_hopper.jpg
Normal file
After Width: | Height: | Size: 4.8 KiB |
BIN
docs/handbook/rotated_hopper_180.jpg
Normal file
After Width: | Height: | Size: 4.5 KiB |
BIN
docs/handbook/rotated_hopper_270.jpg
Normal file
After Width: | Height: | Size: 4.8 KiB |
BIN
docs/handbook/rotated_hopper_90.jpg
Normal file
After Width: | Height: | Size: 4.8 KiB |
BIN
docs/handbook/show_hopper.png
Normal file
After Width: | Height: | Size: 55 KiB |
BIN
docs/handbook/thumbnail_hopper.jpg
Normal file
After Width: | Height: | Size: 1.9 KiB |
BIN
docs/handbook/transformed_hopper.jpg
Normal file
After Width: | Height: | Size: 3.5 KiB |
|
@ -37,6 +37,9 @@ example, let’s display the image we just loaded::
|
||||||
|
|
||||||
>>> im.show()
|
>>> im.show()
|
||||||
|
|
||||||
|
.. image:: show_hopper.png
|
||||||
|
:align: center
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
|
|
||||||
The standard version of :py:meth:`~PIL.Image.Image.show` is not very
|
The standard version of :py:meth:`~PIL.Image.Image.show` is not very
|
||||||
|
@ -79,6 +82,9 @@ Convert files to JPEG
|
||||||
except OSError:
|
except OSError:
|
||||||
print("cannot convert", infile)
|
print("cannot convert", infile)
|
||||||
|
|
||||||
|
.. image:: ../../Tests/images/hopper.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
A second argument can be supplied to the :py:meth:`~PIL.Image.Image.save`
|
A second argument can be supplied to the :py:meth:`~PIL.Image.Image.save`
|
||||||
method which explicitly specifies a file format. If you use a non-standard
|
method which explicitly specifies a file format. If you use a non-standard
|
||||||
extension, you must always specify the format this way:
|
extension, you must always specify the format this way:
|
||||||
|
@ -103,6 +109,9 @@ Create JPEG thumbnails
|
||||||
except OSError:
|
except OSError:
|
||||||
print("cannot create thumbnail for", infile)
|
print("cannot create thumbnail for", infile)
|
||||||
|
|
||||||
|
.. image:: thumbnail_hopper.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
It is important to note that the library doesn’t decode or load the raster data
|
It is important to note that the library doesn’t decode or load the raster data
|
||||||
unless it really has to. When you open a file, the file header is read to
|
unless it really has to. When you open a file, the file header is read to
|
||||||
determine the file format and extract things like mode, size, and other
|
determine the file format and extract things like mode, size, and other
|
||||||
|
@ -150,6 +159,9 @@ pixels, so the region in the above example is exactly 300x300 pixels.
|
||||||
|
|
||||||
The region could now be processed in a certain manner and pasted back.
|
The region could now be processed in a certain manner and pasted back.
|
||||||
|
|
||||||
|
.. image:: cropped_hopper.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
Processing a subrectangle, and pasting it back
|
Processing a subrectangle, and pasting it back
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
@ -164,6 +176,9 @@ modes of the original image and the region do not need to match. If they don’t
|
||||||
the region is automatically converted before being pasted (see the section on
|
the region is automatically converted before being pasted (see the section on
|
||||||
:ref:`color-transforms` below for details).
|
:ref:`color-transforms` below for details).
|
||||||
|
|
||||||
|
.. image:: pasted_hopper.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
Here’s an additional example:
|
Here’s an additional example:
|
||||||
|
|
||||||
Rolling an image
|
Rolling an image
|
||||||
|
@ -186,6 +201,9 @@ Rolling an image
|
||||||
|
|
||||||
return im
|
return im
|
||||||
|
|
||||||
|
.. image:: rolled_hopper.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
Or if you would like to merge two images into a wider image:
|
Or if you would like to merge two images into a wider image:
|
||||||
|
|
||||||
Merging images
|
Merging images
|
||||||
|
@ -203,6 +221,9 @@ Merging images
|
||||||
|
|
||||||
return im
|
return im
|
||||||
|
|
||||||
|
.. image:: merged_hopper.png
|
||||||
|
:align: center
|
||||||
|
|
||||||
For more advanced tricks, the paste method can also take a transparency mask as
|
For more advanced tricks, the paste method can also take a transparency mask as
|
||||||
an optional argument. In this mask, the value 255 indicates that the pasted
|
an optional argument. In this mask, the value 255 indicates that the pasted
|
||||||
image is opaque in that position (that is, the pasted image should be used as
|
image is opaque in that position (that is, the pasted image should be used as
|
||||||
|
@ -229,6 +250,9 @@ Note that for a single-band image, :py:meth:`~PIL.Image.Image.split` returns
|
||||||
the image itself. To work with individual color bands, you may want to convert
|
the image itself. To work with individual color bands, you may want to convert
|
||||||
the image to “RGB” first.
|
the image to “RGB” first.
|
||||||
|
|
||||||
|
.. image:: rebanded_hopper.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
Geometrical transforms
|
Geometrical transforms
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
|
@ -245,6 +269,9 @@ Simple geometry transforms
|
||||||
out = im.resize((128, 128))
|
out = im.resize((128, 128))
|
||||||
out = im.rotate(45) # degrees counter-clockwise
|
out = im.rotate(45) # degrees counter-clockwise
|
||||||
|
|
||||||
|
.. image:: rotated_hopper_90.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
To rotate the image in 90 degree steps, you can either use the
|
To rotate the image in 90 degree steps, you can either use the
|
||||||
:py:meth:`~PIL.Image.Image.rotate` method or the
|
:py:meth:`~PIL.Image.Image.rotate` method or the
|
||||||
:py:meth:`~PIL.Image.Image.transpose` method. The latter can also be used to
|
:py:meth:`~PIL.Image.Image.transpose` method. The latter can also be used to
|
||||||
|
@ -256,11 +283,38 @@ Transposing an image
|
||||||
::
|
::
|
||||||
|
|
||||||
out = im.transpose(Image.Transpose.FLIP_LEFT_RIGHT)
|
out = im.transpose(Image.Transpose.FLIP_LEFT_RIGHT)
|
||||||
|
|
||||||
|
.. image:: flip_left_right_hopper.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
out = im.transpose(Image.Transpose.FLIP_TOP_BOTTOM)
|
out = im.transpose(Image.Transpose.FLIP_TOP_BOTTOM)
|
||||||
|
|
||||||
|
.. image:: flip_top_bottom_hopper.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
out = im.transpose(Image.Transpose.ROTATE_90)
|
out = im.transpose(Image.Transpose.ROTATE_90)
|
||||||
|
|
||||||
|
.. image:: rotated_hopper_90.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
out = im.transpose(Image.Transpose.ROTATE_180)
|
out = im.transpose(Image.Transpose.ROTATE_180)
|
||||||
|
|
||||||
|
.. image:: rotated_hopper_180.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
out = im.transpose(Image.Transpose.ROTATE_270)
|
out = im.transpose(Image.Transpose.ROTATE_270)
|
||||||
|
|
||||||
|
.. image:: rotated_hopper_270.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
``transpose(ROTATE)`` operations can also be performed identically with
|
``transpose(ROTATE)`` operations can also be performed identically with
|
||||||
:py:meth:`~PIL.Image.Image.rotate` operations, provided the ``expand`` flag is
|
:py:meth:`~PIL.Image.Image.rotate` operations, provided the ``expand`` flag is
|
||||||
true, to provide for the same changes to the image's size.
|
true, to provide for the same changes to the image's size.
|
||||||
|
@ -342,6 +396,9 @@ Applying filters
|
||||||
from PIL import ImageFilter
|
from PIL import ImageFilter
|
||||||
out = im.filter(ImageFilter.DETAIL)
|
out = im.filter(ImageFilter.DETAIL)
|
||||||
|
|
||||||
|
.. image:: enhanced_hopper.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
Point Operations
|
Point Operations
|
||||||
^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
@ -358,6 +415,9 @@ Applying point transforms
|
||||||
# multiply each pixel by 1.2
|
# multiply each pixel by 1.2
|
||||||
out = im.point(lambda i: i * 1.2)
|
out = im.point(lambda i: i * 1.2)
|
||||||
|
|
||||||
|
.. image:: transformed_hopper.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
Using the above technique, you can quickly apply any simple expression to an
|
Using the above technique, you can quickly apply any simple expression to an
|
||||||
image. You can also combine the :py:meth:`~PIL.Image.Image.point` and
|
image. You can also combine the :py:meth:`~PIL.Image.Image.point` and
|
||||||
:py:meth:`~PIL.Image.Image.paste` methods to selectively modify an image:
|
:py:meth:`~PIL.Image.Image.paste` methods to selectively modify an image:
|
||||||
|
@ -388,6 +448,9 @@ Note the syntax used to create the mask::
|
||||||
|
|
||||||
imout = im.point(lambda i: expression and 255)
|
imout = im.point(lambda i: expression and 255)
|
||||||
|
|
||||||
|
.. image:: masked_hopper.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
Python only evaluates the portion of a logical expression as is necessary to
|
Python only evaluates the portion of a logical expression as is necessary to
|
||||||
determine the outcome, and returns the last value examined as the result of the
|
determine the outcome, and returns the last value examined as the result of the
|
||||||
expression. So if the expression above is false (0), Python does not look at
|
expression. So if the expression above is false (0), Python does not look at
|
||||||
|
@ -412,6 +475,10 @@ Enhancing images
|
||||||
enh = ImageEnhance.Contrast(im)
|
enh = ImageEnhance.Contrast(im)
|
||||||
enh.enhance(1.3).show("30% more contrast")
|
enh.enhance(1.3).show("30% more contrast")
|
||||||
|
|
||||||
|
|
||||||
|
.. image:: contrasted_hopper.jpg
|
||||||
|
:align: center
|
||||||
|
|
||||||
Image sequences
|
Image sequences
|
||||||
---------------
|
---------------
|
||||||
|
|
||||||
|
|