潍坊市网站优化,企业网站服务器建设方法,鑫鼎信长春网站建设,百姓网网站开发的意义【1】引言
前述学习进程中#xff0c;我们已经掌握了pythonopencv绘制文字的基本技能#xff0c;相关链接为#xff1a;
python学opencv|读取图像#xff08;二十三#xff09;使用cv2.putText()绘制文字-CSDN博客
在这里#xff0c;我们使用不同的字体、线条颜色和线…【1】引言
前述学习进程中我们已经掌握了pythonopencv绘制文字的基本技能相关链接为
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_TRIPLEXcv.FONT_ITALIC,1.8,(150,155,180),5) #输出text
canvas cv.putText(canvas,mimiao,(28,58),cv.FONT_ITALICcv.FONT_ITALIC,1.8,(150,155,180),5) #输出text
canvas cv.putText(canvas,mimiao,(258,58),cv.FONT_HERSHEY_TRIPLEXcv.FONT_ITALIC,1.8,(150,155,180),5) #输出text在这里增加了三种形式 canvas cv.putText(canvas,hellomimiao,(28,500),cv.FONT_HERSHEY_TRIPLEXcv.FONT_ITALIC,1.8,(150,155,180),5) #输出text
canvas cv.putText(canvas,mimiao,(28,58),cv.FONT_ITALICcv.FONT_ITALIC,1.8,(150,155,180),5) #输出text
canvas cv.putText(canvas,mimiao,(258,58),cv.FONT_HERSHEY_TRIPLEXcv.FONT_ITALIC,1.8,(150,155,180),5) #输出text其中设置了一个cv.FONT_ITALICcv.FONT_ITALIC的特例并且在同一高度增加了一个cv.FONT_HERSHEY_TRIPLEXcv.FONT_ITALIC进行效果对比。
运行后的输出图像为 图2
由图2可见
【a】第五排最底下的“hellomimiao”是斜体但需要注意第二排的“hellomimiao”是手写体。
【b】第一排的两个“mimiao”左侧的是cv.FONT_ITALICcv.FONT_ITALIC效果他们恢复为常规的文字形式右侧的是cv.FONT_HERSHEY_TRIPLEXcv.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_TRIPLEXcv.FONT_ITALIC,1.8,(150,155,180),5) #输出text
canvas cv.putText(canvas,mimiao,(28,58),cv.FONT_ITALICcv.FONT_ITALIC,1.8,(150,155,180),5) #输出text
canvas cv.putText(canvas,mimiao,(258,58),cv.FONT_HERSHEY_TRIPLEXcv.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)# x0285 #圆心横坐标
# y0285 #圆心横坐标
# r160 #半径
# for i in range(0,10,1):
# canvas cv.circle(canvas, ((i-5)*5280, (i-5)*5280), (200i,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_TRIPLEXcv.FONT_HERSHEY_SCRIPT_SIMPLEXcv.FONT_ITALIC,1.8,(150,155,180),5) #输出text运行后代码报错。
然后我们又改了一下形式
canvas cv.putText(canvas,mimiao,(258,58),cv.FONT_HERSHEY_TRIPLEXcv.FONT_ITALIC,1.8,(150,155,180),5) #输出text此时发现可以正常输出第二排的“mimiao”就是预期的输出text。 图3
实践表明
【a】一种字体叠加cv.FONT_ITALIC字体可以但是两种字体叠加cv.FONT_ITALIC字体会报错。
【b】一种字体叠加两次cv.FONT_ITALIC字体可以但输出是常规的字体样式无倾斜效果。
【5】总结
掌握了pythonopencv绘制倾斜样式文字效果的基本技巧。