


Python image processing: Pillow library implements automatic line wrapping text annotation
Python has become the leading programming language in the field of image processing with its rich open source libraries. Pillow is one of the commonly used image processing libraries. It is simple, easy to use and has complete documentation. It is often used for operations such as image scaling, cropping, brightness adjustment and annotation.
However, Pillow has a problem with text annotation: when the text exceeds the width of the text box, it will not wrap automatically. The Pillow library itself does not provide this function, and we need to write the logic implementation ourselves.
This tutorial will demonstrate how to use the Pillow library to add a word-wrap text box in Python to achieve correct image text annotation. The final effect is as follows:
The picture above is a screenshot of my Dev.to profile, we will use this as an example to explain. The green text box is the text annotation we added.
Preparation
This tutorial requires you to have basic Python programming knowledge, such as conditional statements (if, else), for loops, etc. You'll also need the following tools and software:
- Python3 : Interpreter for running Python scripts.
- Pillow: Python image processing library.
- Code editor: such as Pycharm, VScode, etc.
Create new project
Follow these steps to create a new project:
A. Create a new folder using terminal/command line:
mkdir image_annotation
B. Use pip to install virtualenv (skip this step if you have already installed it):
pip install virtualenv
C. Switch the working directory to the image_annotation folder:
cd image_annotation
D. Create a new virtual environment:
virtualenv env
E. Activate virtual environment (use command prompt for Windows):
Windows:
.\env\Scripts\activate
Linux/macOS:
source env/bin/activate
F. Use pip to install the Pillow library:
pip install pillow
Open the project in the code editor and create a new Python file named script.py
in the project folder.
Prepare base image
The image you want to annotate is the base image. Open and prepare the image using Pillow's ImageDraw
module. Write the following code in the script.py
file:
from PIL import Image, ImageDraw, ImageFont image_file = "path_to_image" # 请替换为您的图片路径 # 打开图像 image = Image.open(image_file) # 初始化ImageDraw draw = ImageDraw.Draw(image)
Add image annotation
Pillow can add plain text and text boxes with background filling. The text can be single line or multiple lines. This tutorial focuses on how to add a multi-line text box.
TheImageDraw.multiline_text()
method can add multiple lines of plain text, but no background padding. ImageDraw.rectangle()
method can add a text box with background fill.
Add the following code in the script.py
file:
mkdir image_annotation
This code sets the text, font, and text box width. The x
and y
variables represent the starting point of the drawing, and end_x
and end_y
represent the coordinates of the lower right corner of the text box. The width and height of the text box are 200 and 50 respectively.
ImageDraw.rectangle()
and ImageDraw.multiline_text()
methods are used to draw text boxes and multi-line text respectively. The image.show()
method is used to display the processed image. You can save the image using image.save("new_image.png")
. The results are as follows:
There is still a problem with the annotation in the picture above, and the multi-line text does not wrap automatically. The next section explains how to solve this problem.
Realize automatic line wrapping
Line break character n
is used to specify the line break position. In the previous example, the content after the newline character n
will wrap. But in practical applications, the text length is usually dynamic and it is difficult to determine the position of the newline character.
attribute of ImageDraw
Pillow's .textlength()
module can calculate the text length and compare it with the text box width to determine the line break position.
Create a new function named script.py
at the top of the wrap_text()
file (after the import statement), containing the word-wrap logic:
pip install virtualenv
Add the following code after the text
, font
, max_width
variables:
cd image_annotation
Replace the draw.multiline_text()
method with the following code:
virtualenv env
Remove newlines from the text n
and run the code:
.\env\Scripts\activate
The running result shows that the text still exceeds the height of the text box. While the text automatically adjusts to the text box width, the text box height is fixed, causing the text to overflow.
Set dynamic text box height
The height of the dynamic text box is determined based on the number of text lines. The first step is to change the text box's end_y
variable to a dynamic value:
source env/bin/activate
This formula was arrived at after many experiments and it seems to be the best solution for getting dynamic textbox height in this use case. wrapped_lines
The list contains all the lines to be added to the text box, so the length of the list is equal to the total number of lines of the text box.
The results are as follows:
You may need to multiply the total number of rows by different values to get the perfect solution for your use case.
Add text padding
The text is too close to the edge of the text box, affecting readability and style. You can solve this problem by adding padding inside the text box. Add a new script.py
variable in the padding
file and change the text box size:
pip install pillow
This code allows for spacing between the text and the edges of the text box.
Add pointer
The pointer can conveniently indicate the part of the image that the annotation/label refers to. The pointer should be before the label. This means that the pointer will be drawn at the current position of the text box, and the text box will move to the right.
Therefore, the x-axis of the text box will be associated with the new box_x
variable. This change must also be reflected in other variables using the textbox x-axis. Here is the updated code:
mkdir image_annotation
In the above code, the ImageDraw.circle()
method (where 10 is the radius) is used to draw the pointer at the specified point. box_x
The variable is the new value of the x-axis of the text box.
Full code
The following is the complete code of the script.py
file:
pip install virtualenv
Conclusion
Image processing is not always as difficult as it seems. Although some image processing libraries cannot directly solve your problem with their modules, you can use existing modules to implement a specific solution for your use case. That’s the beauty of coding – being able to solve problems with custom and specific solutions.
In this tutorial, you learned how to use Python’s Pillow library to annotate images, add word-wrapped multi-line text boxes, and more. You also learned how to write mathematical formulas that can help you with image processing.
Please refer to the Pillow documentation for details on the modules used.
The above is the detailed content of Wrap and Render Multiline Text on Images Using Pythons Pillow Library. For more information, please follow other related articles on the PHP Chinese website!

Python is easier to learn and use, while C is more powerful but complex. 1. Python syntax is concise and suitable for beginners. Dynamic typing and automatic memory management make it easy to use, but may cause runtime errors. 2.C provides low-level control and advanced features, suitable for high-performance applications, but has a high learning threshold and requires manual memory and type safety management.

Python and C have significant differences in memory management and control. 1. Python uses automatic memory management, based on reference counting and garbage collection, simplifying the work of programmers. 2.C requires manual management of memory, providing more control but increasing complexity and error risk. Which language to choose should be based on project requirements and team technology stack.

Python's applications in scientific computing include data analysis, machine learning, numerical simulation and visualization. 1.Numpy provides efficient multi-dimensional arrays and mathematical functions. 2. SciPy extends Numpy functionality and provides optimization and linear algebra tools. 3. Pandas is used for data processing and analysis. 4.Matplotlib is used to generate various graphs and visual results.

Whether to choose Python or C depends on project requirements: 1) Python is suitable for rapid development, data science, and scripting because of its concise syntax and rich libraries; 2) C is suitable for scenarios that require high performance and underlying control, such as system programming and game development, because of its compilation and manual memory management.

Python is widely used in data science and machine learning, mainly relying on its simplicity and a powerful library ecosystem. 1) Pandas is used for data processing and analysis, 2) Numpy provides efficient numerical calculations, and 3) Scikit-learn is used for machine learning model construction and optimization, these libraries make Python an ideal tool for data science and machine learning.

Is it enough to learn Python for two hours a day? It depends on your goals and learning methods. 1) Develop a clear learning plan, 2) Select appropriate learning resources and methods, 3) Practice and review and consolidate hands-on practice and review and consolidate, and you can gradually master the basic knowledge and advanced functions of Python during this period.

Key applications of Python in web development include the use of Django and Flask frameworks, API development, data analysis and visualization, machine learning and AI, and performance optimization. 1. Django and Flask framework: Django is suitable for rapid development of complex applications, and Flask is suitable for small or highly customized projects. 2. API development: Use Flask or DjangoRESTFramework to build RESTfulAPI. 3. Data analysis and visualization: Use Python to process data and display it through the web interface. 4. Machine Learning and AI: Python is used to build intelligent web applications. 5. Performance optimization: optimized through asynchronous programming, caching and code

Python is better than C in development efficiency, but C is higher in execution performance. 1. Python's concise syntax and rich libraries improve development efficiency. 2.C's compilation-type characteristics and hardware control improve execution performance. When making a choice, you need to weigh the development speed and execution efficiency based on project needs.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

Zend Studio 13.0.1
Powerful PHP integrated development environment

SublimeText3 Mac version
God-level code editing software (SublimeText3)

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool