https://blog.csdn.net/guduruyu/article/details/68491211

opencv中除了提供绘制各种图形的函数外,还提供了一个特殊的绘制函数——在图像上绘制文字。这个函数即是cv::putText()。

具体形式如下:

void cv::putText(
        cv::Mat& img, // 待绘制的图像
        const string& text, // 待绘制的文字
        cv::Point origin, // 文本框的左下角
        int fontFace, // 字体 (如cv::FONT_HERSHEY_PLAIN)
        double fontScale, // 尺寸因子,值越大文字越大
        cv::Scalar color, // 线条的颜色(RGB)
        int thickness = 1, // 线条宽度
        int lineType = 8, // 线型(4邻域或8邻域,默认8邻域)
        bool bottomLeftOrigin = false // true='origin at lower left'
    );

opencv支持的文字字体有以下几种:

另外,我们在实际绘制文字之前,还可以使用cv::getTextSize()接口先获取待绘制文本框的大小,以方便放置文本框。具体调用形式如下:

cv::Size cv::getTextSize(
        const string& text,
        cv::Point origin,
        int fontFace,
        double fontScale,
        int thickness,
        int* baseLine
    );

下面就通过一个示例,来看看cv::getTextSize()与cv::putText()相结合的妙用:

//创建空白图用于绘制文字
    cv::Mat image = cv::Mat::zeros(cv::Size(640, 480), CV_8UC3);
    //设置蓝色背景
    image.setTo(cv::Scalar(100, 0, 0));
 
    //设置绘制文本的相关参数
    std::string text = "Hello World!";
    int font_face = cv::FONT_HERSHEY_COMPLEX; 
    double font_scale = 2;
    int thickness = 2;
    int baseline;
    //获取文本框的长宽
    cv::Size text_size = cv::getTextSize(text, font_face, font_scale, thickness, &baseline);
 
    //将文本框居中绘制
    cv::Point origin; 
    origin.x = image.cols / 2 - text_size.width / 2;
    origin.y = image.rows / 2 + text_size.height / 2;
    cv::putText(image, text, origin, font_face, font_scale, cv::Scalar(0, 255, 255), thickness, 8, 0);
 
    //显示绘制解果
    cv::imshow("image", image);
    cv::waitKey(0);
    return 0;

cv::putText详解相关推荐

  1. [转] OpenCV 文字绘制cv::putText详解

    ref:[OpenCV3]文字绘制--cv::putText详解_cv.puttext_PHILOS_THU的博客-CSDN博客 opencv学习(十三)之文本文字插入_opencv视频添加文本并保存 ...

  2. OpenCV 文字绘制cv::putText详解

    ref:https://blog.csdn.net/guduruyu/article/details/68491211 https://blog.csdn.net/keith_bb/article/d ...

  3. 【OpenCV3】文字绘制——cv::putText详解

    opencv中除了提供绘制各种图形的函数外,还提供了一个特殊的绘制函数--在图像上绘制文字.这个函数即是cv::putText(). 具体形式如下: void cv::putText(cv::Mat& ...

  4. OpenCV 文字绘制----cv::putText详解

    opencv中除了提供绘制各种图形的函数外,还提供了一个特殊的绘制函数--在图像上绘制文字.这个函数cv::putText(). 具体形式如下: void cv::putText( cv::Mat&a ...

  5. 【OpenCV3】棋盘格角点检测与绘制——cv::findChessboardCorners()与cv::drawChessboardCorners()详解

    棋盘格法是摄像机标定中常用的一种方法,在使用该方法时需要对棋盘格的角点进行检测.opencv中封装了一个专门用于棋盘格角点检测的函数即cv::findChessboardCorners(),同时,也提 ...

  6. 【OpenCV3】模板匹配——cv::matchTemplate()详解

    模板匹配通常被用于目标检测.相似度分析中,opencv2和opencv3中提供了一个专门用于模板匹配的函数--cv::matchTemplate(),下面就对该函数进行详细的介绍. 先从一个实际的例子 ...

  7. 文字绘制——putText详解

    opencv中除了提供绘制各种图形的函数外,还提供了一个特殊的绘制函数--在图像上绘制文字.这个函数即是cv::putText(). 具体形式如下: void cv::putText(cv::Mat& ...

  8. 【OpenCV3】透视变换——cv::getPerspectiveTransform()与cv::warpPerspective()详解

    透视变换(Perspective Transformation)是将成像投影到一个新的视平面(Viewing Plane),也称作投影映射(Projective Mapping).如图1,通过透视变换 ...

  9. 【OpenCV3】图像通道分离与合并——cv::split()与cv::merge()详解

    在图像处理中,尤其是处理多通道图像时,有时需要对各个通道进行分离,分别处理:有时还需要对分离处理后的各个通道进行合并,重新合并成一个多通道的图像.opencv2和opencv3中实现图像通道的合并与分 ...

最新文章

  1. C++11 unordered_map详细介绍
  2. XPath实例教程四、[]的作用
  3. TriggerMesh开源用于多云环境的Knative Event Sources
  4. mysql分库分表事务控制_数据库分库分表之后,你是如何解决事务问题?
  5. halcon彩色图像颜色处理算子,持续更新
  6. HDU 1114 Piggy-Bank 简单DP
  7. mysql 索引未命中_联合索引命中率问题导致SQL查询效率慢的问题
  8. 前端小白,如何快速提升自己?了解3点,找工作不用愁
  9. 20 个实例玩转 Java 8 Stream,写的太好了!
  10. Echarts2的使用——绘制中国地图
  11. 性能退化评估 matlab,LED驱动电源性能退化参数监测及寿命预测方法研究
  12. SpringCloud-Netflix-04-Eureka 注册中心
  13. 20金融学431考研应该注意些什么
  14. 数据库系统的结构和组成
  15. 动手学深度学习:6.3 语言模型数据集(周杰伦专辑歌词)
  16. 数论学习笔记1之积性函数与线性筛求积性函数
  17. 四级恋练有词课程 (10课时-朱伟)1.Unit1A单词识记(上)
  18. 不用远程软件,校园网电脑之间如何远程连接
  19. Qt图形化界面—迷宫最短路径问题
  20. 方便易拆信封设计制作

热门文章

  1. SAP产品成本计算流程 (修订版)
  2. 小赢:催收科技化合规“有温度”
  3. 怎么用python画房子_如何用Python画一颗小树?
  4. 收集路由器的默认密码
  5. 【观察】操作系统产业峰会2021:立足新起点,迈上新征程
  6. 如何使用notepad++查看和替换回车换行符
  7. 【python】送给女神的AI聊天软件(内附源码)
  8. MySQL 教程---菜鸟教程
  9. 北京黑马JavaEE就业32期(20160717面授)
  10. 分析恶意Windows程序