python学opencv|读取图像(二十五)使用cv2.putText()绘制文字进阶-垂直镜像文字

【1】引言

前序学习进程找那个,已经掌握了使用python+opencv绘制常规文字和倾斜文字的基本技巧。相关链接如下:

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

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

今天在此基础上更进一步,绘制垂直镜像的文字图像。

【2】核心技巧

垂直镜像文字的绘制核心技巧是:bool bottomLeftOrigin 的值由false改为True。

【3】代码测试

【3.1】基础代码

首先我们依然给出完整的完整代码:可以实现绘制常规和倾斜字体的功能。

代码中含有大量的注释,消除注释前的"#",可以实现对绘制线段、圆形、矩形、多边形等代码的测试。

python 复制代码
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

#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()  # 释放所有窗口

此时的输出图像为:

++图1++

【3.2】垂直镜像

修改和增加部分代码,设置bool bottomLeftOrigin=True,实现垂直镜像的目标:

python 复制代码
canvas = cv.putText(canvas,'mimiao',(85,285),cv.FONT_HERSHEY_TRIPLEX,2,(150,225,100),5) #输出text
canvas = cv.putText(canvas,'hellomimiao',(185,220),cv.FONT_HERSHEY_SCRIPT_SIMPLEX,2,(200,155,180),5) #输出text
canvas = cv.putText(canvas,'helloGUOGUOmiao',(58,388),cv.FONT_ITALIC,1.5,(100,55,180),5) #输出text
canvas = cv.putText(canvas,'mimiao',(85,58),cv.FONT_HERSHEY_TRIPLEX,2,(150,225,100),5,8,True) #输出text
canvas = cv.putText(canvas,'hellomimiao',(185,120),cv.FONT_HERSHEY_SCRIPT_SIMPLEX,2,(200,155,180),5,8,True) #输出text
canvas = cv.putText(canvas,'helloGUOGUOmiao',(58,500),cv.FONT_ITALIC,1.5,(100,55,180),5,8,True) #输出text

运行代码后:

++图2++

由图2清晰可见,有一半的输出text是垂直镜像翻转过的。

此时的完整代码为:

python 复制代码
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',(85,285),cv.FONT_HERSHEY_TRIPLEX,2,(150,225,100),5) #输出text
canvas = cv.putText(canvas,'hellomimiao',(185,220),cv.FONT_HERSHEY_SCRIPT_SIMPLEX,2,(200,155,180),5) #输出text
canvas = cv.putText(canvas,'helloGUOGUOmiao',(58,388),cv.FONT_ITALIC,1.5,(100,55,180),5) #输出text
canvas = cv.putText(canvas,'mimiao',(85,58),cv.FONT_HERSHEY_TRIPLEX,2,(150,225,100),5,8,True) #输出text
canvas = cv.putText(canvas,'hellomimiao',(185,120),cv.FONT_HERSHEY_SCRIPT_SIMPLEX,2,(200,155,180),5,8,True) #输出text
canvas = cv.putText(canvas,'helloGUOGUOmiao',(58,500),cv.FONT_ITALIC,1.5,(100,55,180),5,8,True) #输出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('chjxText.png', canvas)  # 保存图像
cv.waitKey()  # 图像不会自动关闭
cv.destroyAllWindows()  # 释放所有窗口

【4】细节说明

在常规代码的基础上实现文字镜像反转功能时,应当注意,直接在代码后面加True不会实现目标功能,这是因为还有一个lineType默认为Line_8,所以正确的补充代码操作为:增加",8,True"。参考下述代码:

复制代码
canvas = cv.putText(canvas,'helloGUOGUOmiao',(58,500),cv.FONT_ITALIC,1.5,(100,55,180),5,8,True) #输出text

【5】总结

掌握了使用python+opencv实现文字垂直镜像输出的功能。

相关推荐
liulilittle35 分钟前
C++/CLI与标准C++的语法差异(一)
开发语言·c++·.net·cli·clr·托管·原生
daixin884839 分钟前
什么是缓存雪崩?缓存击穿?缓存穿透?分别如何解决?什么是缓存预热?
java·开发语言·redis·缓存
你我约定有三1 小时前
RabbitMQ--消息丢失问题及解决
java·开发语言·分布式·后端·rabbitmq·ruby
xw33734095641 小时前
彩色转灰度的核心逻辑:三种经典方法及原理对比
人工智能·python·深度学习·opencv·计算机视觉
蓝桉8021 小时前
opencv学习(图像金字塔)
人工智能·opencv·学习
倔强青铜三1 小时前
为什么 self 与 super() 成了 Python 的永恒痛点?
人工智能·python·面试
墨尘游子1 小时前
目标导向的强化学习:问题定义与 HER 算法详解—强化学习(19)
人工智能·python·算法
张北北.1 小时前
【深入底层】C++开发简历4+4技能描述6
java·开发语言·c++
李永奉2 小时前
STM32-定时器的基本定时/计数功能实现配置教程(寄存器版)
c语言·开发语言·stm32·单片机·嵌入式硬件
go54631584652 小时前
中文语音识别与偏误检测系统开发
开发语言·人工智能·学习·生成对抗网络·数学建模·语音识别