当前位置: 首页 > article >正文

python学opencv|读取图像(二十四)使用cv2.putText()绘制文字进阶-倾斜文字

【1】引言

前述学习进程中,我们已经掌握了python+opencv绘制文字的基本技能,相关链接为:

python学opencv|读取图像(二十三)使用cv2.putText()绘制文字-CSDN博客

在这里,我们使用不同的字体、线条颜色和线条宽度生成了不同的文字效果。在此基础上,我们继续探索,尝试绘制倾斜文字。

【2】核心技巧

倾斜文字的绘制的核心技巧是:字体样式+FONT_ITALIC。

【3】代码测试

【3.1】常规文字

在绘制常规文字的案例中,我们已经测试了一部分字体样式代码:

canvas = cv.putText(canvas,'mimiao',(285,285),cv.FONT_HERSHEY_TRIPLEX,2,(150,225,100),5) #输出text
canvas = cv.putText(canvas,'hellomimiao',(185,185),cv.FONT_HERSHEY_SCRIPT_SIMPLEX,2,(200,155,180),5) #输出text
canvas = cv.putText(canvas,'helloGUOGUOmiao',(58,358),cv.FONT_ITALIC,1.5,(100,55,180),5) #输出text

并且这里还调用了 cv.FONT_ITALIC字体,此时获得的输出图像为:

图1

 【3.2】斜体文字

在上述的基础上,我们尝试进行组合:

canvas = cv.putText(canvas,'hellomimiao',(28,500),cv.FONT_HERSHEY_TRIPLEX+cv.FONT_ITALIC,1.8,(150,155,180),5) #输出text
canvas = cv.putText(canvas,'mimiao',(28,58),cv.FONT_ITALIC+cv.FONT_ITALIC,1.8,(150,155,180),5) #输出text
canvas = cv.putText(canvas,'mimiao',(258,58),cv.FONT_HERSHEY_TRIPLEX+cv.FONT_ITALIC,1.8,(150,155,180),5) #输出text

在这里,增加了三种形式:

canvas = cv.putText(canvas,'hellomimiao',(28,500),cv.FONT_HERSHEY_TRIPLEX+cv.FONT_ITALIC,1.8,(150,155,180),5) #输出text
canvas = cv.putText(canvas,'mimiao',(28,58),cv.FONT_ITALIC+cv.FONT_ITALIC,1.8,(150,155,180),5) #输出text
canvas = cv.putText(canvas,'mimiao',(258,58),cv.FONT_HERSHEY_TRIPLEX+cv.FONT_ITALIC,1.8,(150,155,180),5) #输出text

其中设置了一个cv.FONT_ITALIC+cv.FONT_ITALIC的特例,并且在同一高度增加了一个cv.FONT_HERSHEY_TRIPLEX+cv.FONT_ITALIC进行效果对比。

运行后的输出图像为:

图2

由图2可见:

【a】第五排(最底下)的“hellomimiao”是斜体;但需要注意,第二排的“hellomimiao”是手写体。

【b】第一排的两个“mimiao”,左侧的是cv.FONT_ITALIC+cv.FONT_ITALIC效果,他们恢复为常规的文字形式;右侧的是cv.FONT_HERSHEY_TRIPLEX+cv.FONT_ITALIC效果,他们是预期的斜体形式。

此时的完整代码为:

import numpy as np  # 引入numpy模块
import cv2 as cv  # 引入cv模块

canvas = np.ones((580, 580, 3), np.uint8) * 225  # 绘制一个580*580大小的画布,3代表有3个通道,unit8为图像存储格式
#canvasa = np.ones((580, 580, 3), np.uint8) * 25  # 绘制一个580*580大小的画布,3代表有3个通道,unit8为图像存储格式

# 第一个通道值
# for i in range(0, 580, 1):
# for j in range(0, 580, 1):
# canvas[i, j, 0] = 0.2 * (i + j)  # 第一个通道值

# 第二个通道值
# for i in range(0, 580, 1):
# for j in range(0, 580, 1):
# canvas[i, j, 1] = 50 * np.cos(i ^ j) + 55 * np.sin(j ^ i) + 150 * np.sin(j - i)  # 第二个通道值

# 第三个通道值
#for i in range(0, 580, 1):
    #for j in range(0, 580, 1):
        #canvas[i, j, 2] = 100 * np.tanh(i + j) + 100 * np.tanh(i - j) + 50 * np.cos(j - i)  # 第三个通道值

canvas = cv.putText(canvas,'mimiao',(285,285),cv.FONT_HERSHEY_TRIPLEX,2,(150,225,100),5) #输出text
canvas = cv.putText(canvas,'hellomimiao',(185,185),cv.FONT_HERSHEY_SCRIPT_SIMPLEX,2,(200,155,180),5) #输出text
canvas = cv.putText(canvas,'helloGUOGUOmiao',(58,358),cv.FONT_ITALIC,1.5,(100,55,180),5) #输出text
canvas = cv.putText(canvas,'hellomimiao',(28,500),cv.FONT_HERSHEY_TRIPLEX+cv.FONT_ITALIC,1.8,(150,155,180),5) #输出text
canvas = cv.putText(canvas,'mimiao',(28,58),cv.FONT_ITALIC+cv.FONT_ITALIC,1.8,(150,155,180),5) #输出text
canvas = cv.putText(canvas,'mimiao',(258,58),cv.FONT_HERSHEY_TRIPLEX+cv.FONT_ITALIC,1.8,(150,155,180),5) #输出text

#pts0 = np.array([[100, 50], [200, 50], [250, 250], [50, 250]], np.int32)
#pts1 = np.array([[100, 300], [250, 500], [200, 300], [50, 500]], np.int32)
#pts2 = np.array([[350, 150], [450, 150], [500, 350], [300, 350]], np.int32)

#canvas0 = cv.polylines(canvas, [pts0], True, (120, 100, 25), 5)
#canvas1 = cv.polylines(canvas, [pts1], False, (120, 200, 225), 5)
#canvas2 = cv.polylines(canvas, [pts2], True, (120, 100, 25), 5)

# x0=285 #圆心横坐标
# y0=285 #圆心横坐标
# r=160 #半径
# for i in range(0,10,1):
# canvas = cv.circle(canvas, ((i-5)*5+280, (i-5)*5+280), (200+i,15*i,10*i), 2) #输出同心圆

# canvas = cv.circle(canvas, (285, 285), 80, (0, 0, 255), 3)  # 第一个圆形
# canvas = cv.circle(canvas, (100, 285), 80, (0, 255, 255), -1)  # 第二个圆形
# canvas = cv.circle(canvas, (470, 285), 80, (255, 0, 0), -1)  # 第三个圆形
# canvas = cv.rectangle(canvas, (50, 30), (530, 550), (155, 120, 60), 5)  # 矩形
# canvas = cv.rectangle(canvas, (80, 80), (500, 500), (55, 160, 230), 10)  # 矩形
# canvas = cv.rectangle(canvas, (150, 150), (430, 430), (50, 120, 90), -1)  # 矩形
# canvas = cv.line(canvas, (50, 550), (550, 550), (58, 50, 150), 15)  # 线段
# canvas = cv.line(canvas, (300, 50), (300, 550), (120, 150, 25), 20)  # 线段

cv.imshow('Text', canvas)  # 在屏幕展示绘制圆形的效果
# cv.imshow('Polylines1', canvas1)  # 在屏幕展示绘制圆形的效果
# cv.imshow('Polylines2', canvas2)  # 在屏幕展示绘制圆形的效果
cv.imwrite('Text.png', canvas)  # 保存图像
cv.waitKey()  # 图像不会自动关闭
cv.destroyAllWindows()  # 释放所有窗口

【4】代码尝试

尝试新加一行代码,同时定义三种字体:

canvas = cv.putText(canvas,'mimiao',(258,158),cv.FONT_HERSHEY_TRIPLEX+cv.FONT_HERSHEY_SCRIPT_SIMPLEX+cv.FONT_ITALIC,1.8,(150,155,180),5) #输出text

运行后代码报错。

然后我们又改了一下形式:

canvas = cv.putText(canvas,'mimiao',(258,58),cv.FONT_HERSHEY_TRIPLEX+cv.FONT_ITALIC,1.8,(150,155,180),5) #输出text

此时发现可以正常输出:第二排的“mimiao”就是预期的输出text。

图3

实践表明:

【a】一种字体叠加cv.FONT_ITALIC字体可以,但是两种字体叠加cv.FONT_ITALIC字体会报错。

【b】一种字体叠加两次cv.FONT_ITALIC字体可以,但输出是常规的字体样式,无倾斜效果。

【5】总结

掌握了python+opencv绘制倾斜样式文字效果的基本技巧。


http://www.kler.cn/a/468139.html

相关文章:

  • C# 设计模式(行为型模式):责任链模式
  • 什么样的人适合从事FPGA开发的工作?
  • 【读书与思考】历史是一个好东西
  • 前端学习DAY31(子元素溢出父元素)
  • 感知器的那些事
  • 【知识协作工具】confluence、zentao、ONLYOFFICE、kooteam、cloudreve
  • Spring MVC 介绍与实践
  • 2025年AI和AR谁才是智能眼镜的未来
  • Java中String对象创建的方式
  • 【SQL serve】教材数据库(6)
  • 外观模式——C++实现
  • Ubuntu 安装英伟达显卡驱动问题记录
  • 面试场景题系列:设计爬虫系统
  • 新能源电动汽车动力电池技术
  • OSPF一些基础概念
  • 云从科技Java面试题及参考答案
  • STM32F1学习——PWMI模式(IC输入捕获)
  • uniapp H5页面实现懒加载
  • Fireworks AI:图像/PDF非文本内容转LLM可读文本
  • pytorch torch.scatter_reduce函数介绍
  • 使用Java Selenium修改打开页面窗口大小
  • 线程-8-日志_线程池
  • 比较 FreeSWITCH 的 asr 事件和回调函数
  • docker 转移文件到容器内部 以修改nextcloud添加域名信任 为例子
  • 【面试】后端开发面试中常见数据结构及应用场景、原理总结
  • 深入解析桥接模式、NAT模式与仅主机模式