使用 OpenCV 在图像中添加文字

在图像处理任务中,我们经常需要将文本添加到图像中。OpenCV 提供了 cv2.putText() 函数,可以很方便地在图像上绘制文本,支持多种字体、颜色、大小和位置等参数。

本文将详细介绍如何使用 OpenCV 在图像中添加文字,介绍 cv2.putText() 的语法、参数及使用示例。

1. cv2.putText() 函数简介

cv2.putText() 是 OpenCV 中的一个函数,用于在图像上绘制文本。通过该函数,我们可以指定文本的内容、位置、字体、大小、颜色等属性。

函数语法:

cv2.putText(image, text, org, fontFace, fontScale, color, thickness, lineType=cv2.LINE_AA)

参数说明:

  • image:输入图像,文本将被添加到该图像上。
  • text:要绘制的文本字符串。
  • org:文本的左下角坐标 (x, y),即文本起始点的位置。
  • fontFace:字体类型。OpenCV 提供了几种字体类型,常用的有 cv2.FONT_HERSHEY_SIMPLEX
  • fontScale:字体大小,通常为浮动值,值越大字体越大。
  • color:文本颜色,指定为 BGR 格式的颜色元组(例如 (255, 0, 0) 表示蓝色)。
  • thickness:文本的粗细程度。值越大,文本的边缘就越粗。
  • lineType:线型,通常设置为 cv2.LINE_AA,表示抗锯齿线条,效果更加平滑。

2. 基本示例:在图像中写文字

我们将通过一个简单的示例,展示如何在图像上添加文本。

示例代码:

import cv2
import numpy as np

# 创建一个白色背景的图像
image = np.ones((400, 600, 3), dtype=np.uint8) * 255

# 要写入的文本
text = "Hello, OpenCV!"

# 设置文本的位置(左下角)
org = (50, 200)

# 设置字体、大小、颜色和粗细
font = cv2.FONT_HERSHEY_SIMPLEX
font_scale = 1.5
color = (0, 0, 255)  # 红色
thickness = 2

# 在图像上添加文本
cv2.putText(image, text, org, font, font_scale, color, thickness)

# 显示图像
cv2.imshow("Text on Image", image)
cv2.waitKey(0)
cv2.destroyAllWindows()

代码解析:

  1. 创建图像:我们创建了一幅 400x600 的白色背景图像(np.ones((400, 600, 3), dtype=np.uint8) * 255)。
  2. 定义文本:定义要写入的文本为 "Hello, OpenCV!"
  3. 设置文本属性
    • org:指定文本的起始位置 (50, 200),即文本的左下角位置。
    • font:设置字体为 cv2.FONT_HERSHEY_SIMPLEX,这是一种简单的字体。
    • font_scale:设置字体大小为 1.5
    • color:设置文本颜色为红色((0, 0, 255),BGR 格式)。
    • thickness:设置文本的粗细为 2
  4. 绘制文本:调用 cv2.putText() 在图像上绘制文本。
  5. 显示图像:使用 cv2.imshow() 显示图像,并在按下任意键后关闭窗口。

3. 更改字体类型和大小

OpenCV 支持几种常用的字体类型,常见的包括:

  • cv2.FONT_HERSHEY_SIMPLEX:无衬线字体(最常用的字体)。
  • cv2.FONT_HERSHEY_PLAIN:简单无衬线字体。
  • cv2.FONT_HERSHEY_DUPLEX:较粗的无衬线字体。
  • cv2.FONT_HERSHEY_COMPLEX:复杂的无衬线字体。
  • cv2.FONT_HERSHEY_TRIPLEX:较粗的复杂无衬线字体。
  • cv2.FONT_HERSHEY_COMPLEX_SMALL:复杂的小无衬线字体。
  • cv2.FONT_HERSHEY_SCRIPT_SIMPLEX:简单的手写字体。
  • cv2.FONT_HERSHEY_SCRIPT_COMPLEX:复杂的手写字体。

示例:使用不同的字体

import cv2
import numpy as np

# 创建一个白色背景的图像
image = np.ones((400, 600, 3), dtype=np.uint8) * 255

# 要写入的文本
text = "Font Example!"

# 设置文本的位置(左下角)
org = (50, 200)

# 设置字体、大小、颜色和粗细
font = cv2.FONT_HERSHEY_DUPLEX
font_scale = 2
color = (0, 255, 0)  # 绿色
thickness = 3

# 在图像上添加文本
cv2.putText(image, text, org, font, font_scale, color, thickness)

# 显示图像
cv2.imshow("Text with Different Font", image)
cv2.waitKey(0)
cv2.destroyAllWindows()

4. 文本对齐

在 OpenCV 中,文本的位置通常是从文本的左下角开始指定的(即 (x, y) 坐标)。如果你需要更精确的文本对齐(例如居中、右对齐),你需要根据文本的大小进行计算。可以使用 cv2.getTextSize() 函数来获取文本的大小,然后进行适当的调整。

示例:文本居中对齐

import cv2
import numpy as np

# 创建一个白色背景的图像
image = np.ones((400, 600, 3), dtype=np.uint8) * 255

# 要写入的文本
text = "Centered Text"

# 获取文本大小
(font_width, font_height), baseline = cv2.getTextSize(text, cv2.FONT_HERSHEY_SIMPLEX, 1, 2)

# 计算文本的起始位置,使其居中
org = ((image.shape[1] - font_width) // 2, (image.shape[0] + font_height) // 2)

# 在图像上添加文本
cv2.putText(image, text, org, cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 0, 255), 2)

# 显示图像
cv2.imshow("Centered Text", image)
cv2.waitKey(0)
cv2.destroyAllWindows()

代码解析:

  1. 获取文本大小cv2.getTextSize() 函数返回一个元组 (font_width, font_height),表示文本的宽度和高度,以及 baseline(基线的偏移量)。
  2. 计算居中位置:通过 (image.shape[1] - font_width) // 2 计算文本水平居中的位置,通过 (image.shape[0] + font_height) // 2 计算文本垂直居中的位置。
  3. 绘制文本:将计算好的坐标传入 cv2.putText()

5. 总结

在 OpenCV 中,使用 cv2.putText() 函数,我们可以轻松地在图像上添加各种文本。可以通过调整字体类型、大小、颜色、粗细等属性,来满足不同的需求。同时,通过计算文本的尺寸,还可以实现文本的精确对齐(如居中、右对齐等)。这些操作在图像标注、生成图表、图像处理和计算机视觉任务中都非常有用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/942952.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

接口测试Day-02-安装postman项目推送Gitee仓库

postman安装 下载 Postman(已提供安装包,此步可以跳过) https://www.postman.com/downloads/安装 Postman 安装Postman插件newman 要想给 postman 安装 newman 插件,必须 先 安装 node.js。 这是前提! 安装node.js 可能…

MySQL索引为什么是B+树

MySQL索引为什么是B树 索引是帮助MySQL高效获取数据的数据结构,在数据之外,数据库还维护着满足特定查找算法的数据结构B树,这些数据结果以某种特定的方式引用数据,这样就可以在这些数据结构上实现高级查找算法,提升数据…

C#实现图像骨架化(ZhangSuen细化算法)

原始图像: 骨架化后图像: 需要安装一个NuGet包:System.Drawing.Common 代码如下: using System.Drawing; using System.Drawing.Imaging;public class Image {public int Width { get; }public int Height { get; }private bool[,] pixels;// 构造函数,初始化图像的宽度…

【无标题】学生信息管理系统界面

网页是vue框架,后端直接python写的没使用框架

Flow Field——流场寻路算法

目的 一群物体到达某个目的地时,需要对这些海量单位做寻路和避障,类似塔防类游戏的怪物步行到终点的过程。 参考视频:https://www.bilibili.com/video/BV12bzZY2EfA 演示动画:https://howtorts.github.io/examples/4-basic-flow-f…

Bash 脚本教程

注:本文为 “Bash 脚本编写” 相关文章合辑。 BASH 脚本编写教程 as good as well于 2017-08-04 22:04:28 发布 这里有个老 American 写的 BASH 脚本编写教程,非常不错,至少没接触过 BASH 的也能看懂! 建立一个脚本 Linux 中有…

区块链期末复习3.2:比特币脚本

目录 一、输入输出脚本的执行 二、简单脚本实例及压栈过程 1.P2PK(pay to public key hash) 2、P2PH(pay to public key hash) 3.多重签名 4.比特币脚本的应用: 三、其他常见指令 1.OP_EQUAL与OP_EQ…

2024大模型在软件开发中的具体应用有哪些?(附实践资料合集)

大模型在软件开发中的具体应用非常广泛,以下是一些主要的应用领域: 自动化代码生成与智能编程助手: AI大模型能够根据开发者的自然语言描述自动生成代码,减少手动编写代码的工作量。例如,GitHub Copilot工具就是利用AI…

【数据可视化复习方向】

1.数据可视化就是数据中信息的可视化 2.数据可视化主要从数据中寻找三个方面的信息:模式、关系和异常 3.大数据可视化分类:科学可视化、信息可视化、可视分析学 4.大数据可视化作用:记录信息、分析推理、信息传播与协同 5.可视化流程&…

Python 多进程编程详解

目录 一、多进程编程简介 1. 什么是多进程 2. 多进程与多线程的区别 二、Python 中的多进程编程 1. 创建进程 2. 进程间通信 3. 进程池 4. 进程同步 5. 注意事项 三、实际应用案例 四、总结 在 Python 中,多进程编程是一种提高程序运行效率的有效手段。相…

Redis篇--应用篇1--会话存储(session共享)

1、概述 实现Session共享是构建分布式Web应用时的一个重要需求,尤其是在水平扩展和高可用性要求较高的场景下。 在分布式服务或集群服务中往往会出现这样一个问题:用户登录A服务后可以正常访问A服务中的接口。但是我们知道,分布式服务通常都…

ip-协议

文章目录 1. 网络层2. ip协议2.1 ip协议格式2.2 网段划分基本概念网段划分的两种方式为什么要网段划分?特殊的IP地址IP地址数量不足 2.3 私有IP与公网IP2.4 路由 3. IP的分片与组装为什么要分片与组装?如何分片?如何组装? 1. 网络…

ECharts散点图-气泡图,附视频讲解与代码下载

引言: ECharts散点图是一种常见的数据可视化图表类型,它通过在二维坐标系或其它坐标系中绘制散乱的点来展示数据之间的关系。本文将详细介绍如何使用ECharts库实现一个散点图,包括图表效果预览、视频讲解及代码下载,让你轻松掌握…

Jmeter录制https请求

jmeter 5.5版本,chrome浏览器 1、首先添加Test Plan-Thread Group-HTTP(S) Test Script Recorder 2、设置HTTP(S) Test Script Recorder界面的Port(监听端口,设置浏览器代理时需要与这里保持一致)、HTPS Domains(录制…

【Git 常用操作:pull push】

Git 基本概念 Git 是一个先进的开源的分布式版本控制系统,常用于管理工作内容、项目代码等功能。 Git 工作流程 图片来源:https://www.runoob.com/git/git-basic-operations.html 说明: workspace:工作区staging area&#xff…

LLaMA-Factory GLM4-9B-CHAT LoRA 指令微调实战

🤩LLaMA-Factory GLM LoRA 微调 安装llama-factory包 git clone --depth 1 https://github.com/hiyouga/LLaMA-Factory.git进入下载好的llama-factory,安装依赖包 cd LLaMA-Factory pip install -e ".[torch,metrics]" #上面这步操作会完成…

基于kraft部署kafka集群

kafka介绍 Apache Kafka 是一个开源的分布式事件流平台,被数千家公司用于高性能数据管道、流分析、数据集成和关键任务应用。 Kafka是一个拥有高吞吐、可持久化、可水平扩展,支持流式数据处理等多种特性的分布式消息流处理中间件,采用分布式…

Day13 苍穹外卖项目 工作台功能实现、Apache POI、导出数据到Excel表格

目录 1.工作台 1.1 需求分析和设计 1.1.1 产品原型 1.1.2 接口设计 1.2 代码导入 1.2.1 Controller层 1.2.2 Service层接口 1.2.3 Service层实现类 1.2.4 Mapper层 1.3 功能测试 1.4 代码提交 2.Apache POI 2.1 介绍 2.2 入门案例 2.2.1 将数据写入Excel文件 2.2.2 读取Excel文…

Web前端基础知识(三)

表单的应用非常丰富&#xff0c;可以说&#xff0c;每个网站都会用到表单。下面首先介绍表单中的form标签。 --------------------------------------------------------------------------------------------------------------------------------- <form></form&g…

NLP中的神经网络基础

一&#xff1a;多层感知器模型 1&#xff1a;感知器 解释一下&#xff0c;为什么写成 wxb>0 &#xff0c;其实原本是 wx > t ,t就是阈值&#xff0c;超过这个阈值fx就为1&#xff0c;现在把t放在左边。 在感知器里面涉及到两个问题&#xff1a; 第一个&#xff0c;特征提…