【OpenCV进阶】图像中添加中文字幕

OpenCV中的putText函数可以在图像上添加一些你想要的信息,但是该函数只能添加英文字母或数字,无法添加中文字幕。函数原型如下:

cpp 复制代码
CV_EXPORTS_W void putText( InputOutputArray img, const String& text, Point org,
                         int fontFace, double fontScale, Scalar color,
                         int thickness = 1, int lineType = LINE_8,
                         bool bottomLeftOrigin = false );

当你设置第二个参数const String& text为中文字体时,最终显示在图像上的是会是一串乱码(大概率是一串问号)。

OpenCV自3.2版本后,在OpenCV_contrib模块中添加了freeType模块,将OpenCV_contrib模块编译后可以使用freeType模块并方便的在图像中添加中文字体(如果是3.1之前的OpenCV版本,那就需要你自己下载freeType库,然后编译成动态库再使用了,相信大家应该不会在用那么老的版本了吧)。好了,不废话了,上干货吧。

使用freeType需要添加预编译头文件:

cpp 复制代码
#include "opencv2/freetype.hpp"

创建FreeType2对象,并加载字体类型,比如是楷体类型,宋体类型或者中文简体类型。

cpp 复制代码
cv::Ptr<cv::freetype::FreeType2> ft2;
ft2 = cv::freetype::createFreeType2();
ft2->loadFontData("./Font.ttf",0);

如上代码中Font.ttf是字库,需要自己到网上下载的,网上很多,我下了楷体的中文字体类型(如果大家需要可以私信或者评论,我私发你)

在FreeType2类中也定义了putText成员函数,函数原型如下:

cpp 复制代码
void putText(
        InputOutputArray img, const String& text, Point org,
        int fontHeight, Scalar color,
        int thickness, int line_type, bool bottomLeftOrigin
    )

可以看到使用方式同一般的putText类似,大家需要看函数定义可以自行到freetype.cpp文件中去查询。

如在图像中显示中文字幕"我爱计算机视觉",代码片段如下:

cpp 复制代码
ft2->putText(image, "我爱计算机视觉", Point(100, 100), 60, Scalar(0, 0, 255), 
-1, 8, true);
imwrite(saveImagePath, image);

运行完这段代码后,大家可以查看下保存的图像是否成功显示了中文字幕。

如有问题,可以留言或私信,欢迎大家一起交流学习,共同进步。

相关推荐
kay_5458 小时前
YOLO26改进| 特征融合 | 小波变换的多尺度特征融合
人工智能·目标检测·计算机视觉·目标跟踪·论文·yolo26·yolo26改进
OpenBayes贝式计算13 小时前
流式 3D 重建新突破!LingBot-Map 融合 Trajectory Memory 与几何上下文;12.6 万 QA 样本!
计算机视觉·开源·agent
sali-tec13 小时前
C# 基于OpenCv的视觉工作流-章62-线线距离
图像处理·人工智能·opencv·算法·计算机视觉
ComputerInBook15 小时前
数字图像处理(4版)——第 11 章——特征提取(上)(Rafael C.Gonzalez&Richard E. Woods)
人工智能·深度学习·计算机视觉·特征提取
这张生成的图像能检测吗15 小时前
(论文速读)HAFNet:用于红外小目标检测的分层注意力融合网络
人工智能·神经网络·目标检测·计算机视觉·图像分割
测绘第一深情16 小时前
在vscode中使用codex教程(个人安装经验)
数据结构·ide·vscode·python·算法·计算机视觉·编辑器
机器人图像处理18 小时前
6-自动白平衡(灰度世界算法)
opencv·算法·相机
TENSORTEC腾视科技19 小时前
算力驱动智慧零售|腾视科技AI边缘算力盒子 —— 无人商超全场景解决方案重磅发布
人工智能·科技·计算机视觉·ai·零售·无人零售·无人叉车及智能调度系统解决方案
这张生成的图像能检测吗21 小时前
(论文速读)基于优化的YOLO-BFP和RIoU度量学习的动态尺度感知车辆再识别
人工智能·计算机视觉·目标跟踪
SylarXillee21 小时前
paddledetection进行目标检测的系列文章
人工智能·目标检测·计算机视觉