解决python opencv imshow中文乱码问题,亲测有效

opencv imshow font 默认是只能显示英文的,有中文就会出现乱码现象,使用PIL的方式绘制文字,绘制好之后再以opencv的图片类型返回去,在使用imshow就可也解决乱码问题了

解决方案:

1.先去官网下载一个中文字体,网址目的是在使用PIL绘制文字的时候,我们可以指定绘制文字的文字字体类型

下载完成后是一个压缩包,解压,找到 simsun.ttc,把它复制到我们的项目里面,可以给它新建一个文件夹,我这里的路径是 \static\font\simsun.ttc

2.使用PIL的方式绘制文字,代码如下:

"""
coding=utf-8
cv2解决绘制中文乱码的问题
"""
import cv2
import numpy as np
from PIL import Image, ImageDraw, ImageFont


def cv2_chinese_text(img, text, left, top, text_color=(0, 255, 0)):
    text_size = 25
    # 判断是否OpenCV图片类型
    if (isinstance(img, np.ndarray)):
        img = Image.fromarray(cv2.cvtColor(img, cv2.COLOR_BGR2RGB))
    # 创建一个可以在给定图像上绘图的对象
    draw = ImageDraw.Draw(img)
    # 字体的格式
    font_style = ImageFont.truetype(r"D:\softwarebuilding\PyCharm2018\opencv2_wisdom_dormitory\static\font\simsun.ttc",
                                    text_size, encoding="utf-8")
    # 绘制文本
    draw.text((left, top), text, text_color, font=font_style)
    # 转换回OpenCV格式
    return cv2.cvtColor(np.asarray(img), cv2.COLOR_RGB2BGR)

 引用PIL绘制文字,我这里我是在utils文件夹下面新建的new_put_text.py文件

from utils.new_put_text import cv2_chinese_text

"""我这里写的是人脸识别的代码"""

img = cv2_chinese_text(img, '【' + name_str + '】' + str(format(con, '.1f')), x + w + 5, y - 5, (0, 255, 0))
cv2.imshow('Recognition', img)

 看效果,本人太丑,就不上镜了,哈哈哈

 这个中文乱码我也是搞了好久,才解决,亲测有用,希望能帮到你们

  • 10
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

只要思想不滑坡办法总比困难多--小鱼干

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值