Have you ever wanted to turn your favorite photos into beautiful sketches? In this tutorial, we'll explore how to achieve that with Python and a few handy libraries. The following code allows you to convert an image into a sketch using grayscale transformation, Gaussian blur, and the dodge effect.
Prerequisites
To follow along, ensure you have Python installed along with these libraries:
pip install numpy imageio scipy opencv-python
Β The Code
Here is the Python code that transforms your image into a sketch:
import numpy as np
import imageio.v2 as imageio # Using v2 to avoid warnings
import scipy.ndimage
import cv2
def rgb_to_gray(rgb_image):
"""
Converts an RGB image to grayscale.
"""
return np.dot(rgb_image[..., :3], [0.2989, 0.5870, 0.1140])
def dodge(front, back):
"""
Applies the "dodge" effect to create a sketch-like appearance.
"""
result = front * 255 / (255 - back)
result[result > 255] = 255
result[back == 255] = 255
return result.astype('uint8')
def create_sketch(input_image_path, output_image_path, blur_sigma=13):
"""
Converts an image into a sketch and saves it.
Args:
input_image_path (str): Path to the input image.
output_image_path (str): Path to save the output sketch image.
blur_sigma (int, optional): Gaussian blur intensity. Default is 13.
"""
# Load the image
image = imageio.imread(input_image_path)
# Convert to grayscale
gray_image = rgb_to_gray(image)
# Invert the colors
inverted_image = 255 - gray_image
# Apply Gaussian blur
blurred_image = scipy.ndimage.gaussian_filter(inverted_image, sigma=blur_sigma)
# Create the sketch using the dodge effect
sketch = dodge(blurred_image, gray_image)
# Save the resulting sketch image
cv2.imwrite(output_image_path, sketch)
if __name__ == '__main__':
# Parameters for execution
input_image = 'test.jpeg'
output_image = 'test_coloring.png'
# Generate the sketch
create_sketch(input_image, output_image)
How It Works
The script transforms an image into a sketch using the following steps:
-
Grayscale Conversion
- The
rgb_to_gray
function converts an RGB image into a grayscale image. This is done by applying a weighted sum of the red, green, and blue channels: [ \text{Gray} = 0.2989 \times \text{Red} + 0.5870 \times \text{Green} + 0.1140 \times \text{Blue} ] - This formula accounts for the human eye's sensitivity to different colors, ensuring an accurate grayscale representation.
- The
-
Inverting Colors
- The colors of the grayscale image are inverted to create a "negative" of the image: [ \text{Inverted} = 255 - \text{Gray} ]
- This inversion is crucial for the dodge effect applied later.
-
Blurring the Image
- A Gaussian blur is applied to the inverted image using the
scipy.ndimage.gaussian_filter
function. Theblur_sigma
parameter controls the intensity of the blur. - The blur softens the details in the image, making the sketch effect more pronounced.
- A Gaussian blur is applied to the inverted image using the
-
Applying the Dodge Effect
- The
dodge
function combines the blurred inverted image and the original grayscale image to simulate a sketch: [ \text{Sketch}[i, j] = \frac{\text{Blurred}[i, j] \times 255}{255 - \text{Gray}[i, j]} ] - This technique brightens the darker areas of the grayscale image based on the blurred inverted image.
- Pixels are clamped to a maximum value of 255 to avoid overflows, ensuring the output remains visually consistent.
- The
-
Saving the Result
- The final sketch image is saved using the
cv2.imwrite
function. The output path is specified as a parameter to thecreate_sketch
function.
- The final sketch image is saved using the
By combining these steps, the script generates a visually appealing sketch of the original image, mimicking hand-drawn pencil art.
Example Usage
Place an image named test.jpeg
in the same directory as your script and run it. The output will be saved as test_coloring.png
.
You can adjust the blur_sigma
parameter to control the intensity of the sketch effect. For example:
create_sketch('test.jpeg', 'output_sketch.png', blur_sigma=20)
Possible Enhancements
Error Handling: Ensure the input file exists and is an image.
Command-Line Arguments: Use
argparse
to allow dynamic input for file paths and parameters.User Interface: Build a simple GUI using libraries like tkinter for easier interaction.
Output Example
After running the script, you should get a sketch version of your input image. Below is an example of what the output might look like:
Original Image | Sketch Output |
---|---|
Customizing the Results
-
Sharp Sketch: Reduce the
blur_sigma
value (e.g.,blur_sigma=5
) for sharper and more detailed sketches. -
Softer Sketch: Increase the
blur_sigma
value (e.g.,blur_sigma=20
) for a smoother, more artistic effect.
Try experimenting with your own images to see how the effect varies. The results can range from highly detailed to soft and dreamy sketches depending on the input and parameters.
Β Conclusion
This script is a great example of leveraging Python's ecosystem to create stunning visual effects with minimal effort. Experiment with different images and parameters to see what works best for you.
Top comments (3)
Pretty cool
Thx :D
Thanks. Gerat.