python,opencv读写视频,cv2.putText写入汉字

读写视频

#coding=UTF-8
import cv2

cap = cv2.VideoCapture('v.mp4')#打开相机

#创建VideoWriter类对象
fourcc = cv2.VideoWriter_fourcc(*'mp4v') #若是opencv2,就是VideoWriter_fourcc要改为cv.CV_FOURCC
out = cv2.VideoWriter('output.mp4',fourcc, 20, (1280,720))#20帧/s,输出分辨率,要和输入视频的分辨率一致
#若发现存并没有存下视频,将上述*'mp4v'改为*'XVID',文件名mpv改为avi
i=1
while(True):
	ret,frame = cap.read()#捕获一帧图像
	out.write(frame)#保存帧
	#判断按键,如果按键为q,退出循环
	i+=1
	if i==400: #400帧退出
		break
	if cv2.waitKey(1) & 0xFF == ord('q'):
		break

cap.release()#关闭相机
out.release()
cv2.destroyAllWindows()#关闭窗口

cv2.putText添加汉字
参考链接:https://blog.csdn.net/weixin_30569033/article/details/95614972
代码中的ttf文件是字体文件,可在http://www.font5.com.cn/下载

from PIL import Image, ImageDraw, ImageFont
import cv2
 
frame=cv2.irmead(' jpg')
img_PIL = Image.fromarray(cv2.cvtColor(frame, cv2.COLOR_BGR2RGB))# 图像从OpenCV格式转换成PIL格式
font = ImageFont.truetype('ziti.ttf', 40)#40为字体大小,根据需要调整
fillColor = (255,255,0)
position = (100,120)#第一个数值是距左,第二个数值是距上
str = '你要放的汉字'.decode('utf8')
draw = ImageDraw.Draw(img_PIL)
draw.text(position, str, font=font, fill=fillColor)
frame = cv2.cvtColor(np.asarray(img_PIL),cv2.COLOR_RGB2BGR)#转换回OpenCV格式
  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 要在Python中使用cv2.putText显示中文,需要先安装中文字体。可以通过以下步骤来实现: 1. 下载中文字体文件(例如:SimHei.ttf)并将其保存在项目文件夹中。 2. 在代码中导入cv2和PIL库: ```python import cv2 from PIL import ImageFont, ImageDraw, Image ``` 3. 创建一个PIL图像对象并加载字体: ```python img_pil = Image.fromarray(cv2.cvtColor(img, cv2.COLOR_BGR2RGB)) font = ImageFont.truetype('SimHei.ttf', 40) ``` 4. 创建一个PIL绘图对象并使用puttext方法添加中文文本: ```python draw = ImageDraw.Draw(img_pil) draw.text((x, y), text, font=font, fill=(255, 0, 0)) ``` 5. 将PIL图像对象转换回OpenCV图像对象: ```python img = cv2.cvtColor(np.array(img_pil), cv2.COLOR_RGB2BGR) ``` 完整代码示例: ```python import cv2 import numpy as np from PIL import ImageFont, ImageDraw, Image # 加载图像 img = cv2.imread('test.jpg') # 创建PIL图像对象并加载字体 img_pil = Image.fromarray(cv2.cvtColor(img, cv2.COLOR_BGR2RGB)) font = ImageFont.truetype('SimHei.ttf', 40) # 创建PIL绘图对象并使用puttext方法添加中文文本 draw = ImageDraw.Draw(img_pil) text = '你好,世界!' x, y = 50, 50 draw.text((x, y), text, font=font, fill=(255, 0, 0)) # 将PIL图像对象转换回OpenCV图像对象 img = cv2.cvtColor(np.array(img_pil), cv2.COLOR_RGB2BGR) # 显示图像 cv2.imshow('image', img) cv2.waitKey(0) cv2.destroyAllWindows() ``` ### 回答2: 在使用OpenCVPython接口进行图像处理的过程中,有时需要向图像中添加中文文字。然而,由于Python默认使用的是ASCII编码,所以无法直接使用cv2.putText函数显示中文。 解决这个问题的方法有很多,下面介绍两种比较常用的方法: 方法一:使用第三方库Pillow Pillow是Python中一个非常常用的图像处理库,它也可以用来在图像中添加中文文字。 首先需要安装Pillow库,在命令行中输入以下命令: ``` pip install Pillow ``` 安装完成后,可以使用以下代码向图像中添加中文文字: ```python from PIL import Image, ImageDraw, ImageFont import cv2 # 加载图像 img = cv2.imread('test.jpg') # 将BGR格式转为RGB格式 img_rgb = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) # 在Pillow中创建图像对象 pil_img = Image.fromarray(img_rgb) # 创建绘图对象 draw = ImageDraw.Draw(pil_img) # 设置中文字体 font = ImageFont.truetype('msyh.ttc', 30) # 绘制中文文字 text = '测试中文' draw.text((50, 50), text, font=font, fill=(255, 0, 0)) # 将Pillow中的图像对象转为OpenCV中的图像格式 img_with_text = cv2.cvtColor(np.asarray(pil_img), cv2.COLOR_RGB2BGR) # 显示图像 cv2.imshow('image with text', img_with_text) cv2.waitKey(0) cv2.destroyAllWindows() ``` 在以上代码中,使用Pillow库中的ImageDraw对象创建了一个图像实例,设置好字体后调用text()方法绘制中文文字。最后将Pillow库中的实例转换为OpenCV中的格式即可在图像上显示中文文字。 方法二:使用cv2的putText函数配合自定义字体文件 这种方法需要事先准备好自己的中文字体文件,这里以微软雅黑字体为例,具体操作过程如下: 首先下载微软雅黑字体文件msyh.ttc,放在当前工程目录下。 在代码中添加如下代码: ```python font = cv2.FONT_HERSHEY_SIMPLEX # 字体类型 text = '测试中文' # 中文文字 position = (50, 50) # 文字位置 fontScale = 1 # 字体大小 fontColor = (0, 0, 255) # 字体颜色 thickness = 2 # 字体线条厚度 cv2.putText(img, text, position, font, fontScale, fontColor, thickness) ``` 以上代码中,需要将字体类型设置为cv2.FONT_HERSHEY_SIMPLEX,使用cv2.putText函数绘制中文文字,并同时设置好文字位置、字体大小、字体颜色和线条厚度等参数。这里笔者将文字的位置设置为(50, 50),文字大小设置为1,字体颜色设置为红色,线条厚度设置为2,可以自己根据需要进行调整。 完整代码如下: ```python import cv2 import numpy as np # 加载图像 img = cv2.imread('test.jpg') # 将BGR格式转为RGB格式 img_rgb = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) # 将RGB格式转为灰度图像 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 将灰度图像转为BGR格式 gray_bgr = cv2.cvtColor(gray, cv2.COLOR_GRAY2BGR) # 在灰度图像上添加中文文字 font = cv2.FONT_HERSHEY_SIMPLEX text = '测试中文' position = (50, 50) fontScale = 1 fontColor = (0, 0, 255) thickness = 2 cv2.putText(gray_bgr, text, position, font, fontScale, fontColor, thickness) # 显示图像 cv2.imshow('image', img) cv2.imshow('gray image with chinese text', gray_bgr) cv2.waitKey(0) cv2.destroyAllWindows() ``` 使用以上代码可以在灰度图像中添加中文文字。一定要注意字体文件路径和编码类型,防止中文乱码的出现。 总之,在OpenCV Python接口中显示中文文字,可以使用Pillow库或自定义字体文件配合使用cv2.putText函数来实现。希望本文的方法可以帮到大家,也希望大家还有其他更好的解决方案,可以分享给大家。 ### 回答3: 在Python中使用OpenCVcv2库显示中文比较麻烦,需要将文字字符串转换成Unicode编码,并且选择合适的字体,使用cv2.putText()函数显示。 首先需要使用Pillow库(Python Image Library)中的ImageFont和ImageDraw类来创建一个PIL(Python Imaging Library)图像,再利用Pillow库的tobytes()函数将图像转为numpy数组,最后再使用cv2.imshow()函数显示图片。 以下是一个大致的方法: 1、导入需要的库: ``` import cv2 from PIL import Image, ImageFont, ImageDraw import numpy as np ``` 2、创建一个PIL图像,并在图片上绘制中文字符串: ``` # 创建一个100x100的纯白色图像 image = Image.new('RGB', (100, 100), (255, 255, 255)) # 中文字体设置 fontpath = 'simhei.ttf' # 字体文件路径 font = ImageFont.truetype(fontpath, 30) # 字体大小 # 绘制中文字符 draw = ImageDraw.Draw(image) text = "你好,世界!" draw.text((10, 10), text, font=font, fill=(0, 0, 0)) ``` 3、将PIL图像对象转换成numpy数组: ``` array = np.array(image) # 转为numpy数组 ``` 4、将numpy数组转换成OpenCV的图像对象: ``` cv2.imshow('image', array) # 显示OpenCV处理后的图像 cv2.waitKey() # 等待键盘按键 cv2.destroyAllWindows() # 关闭所有窗口 ``` 这样就可以在OpenCV的窗口里显示中文字符串了。 注意:在Windows中,需要安装中文字体文件,比如SimHei.ttf,才能正确显示中文。同样,也可以使用微软雅黑字体微软雅黑.ttf或其他已经安装的中文字体。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值