python opencv3 给图片加中文

转自:https://www.cnblogs.com/arkenstone/p/6961453.html

opencv3.2将中文输出到图片上

opencv自带的putText函数无法输出utf8类型的字符,因此无法将中文打印到图片上。用这篇文章的freetype可以实现中文输出,但是需要将字符解码转码比较麻烦,而Pillow的Image函数输出中文则相对容易些,因此这里的做法是现将图片从从cv2格式转到PIL格式,加上中文后再转成cv2格式输出。

1. 下载中文字体库

这里可以参考之前matplotlib输出中文的文章的第一部分。

2. cv2转PIL

import Image, ImageDraw, ImageFont, cv2

cap = cv2.VideoCapture(0) # 从视频流中截取图片
ret, im = cap.read()
cv2_im = cv2.cvtColor(im, cv2.COLOR_BGR2RGB) # cv2和PIL中颜色的hex码的储存顺序不同
pil_im = Image.fromarray(cv2_im)

3. PIL图片上打印中文

draw = ImageDraw.Draw(pil_im) # 括号中为需要打印的canvas,这里就是在图片上直接打印
font = ImageFont.truetype("simhei.ttf", 20, encoding="utf-8) # 第一个参数为字体文件路径,第二个为字体大小
draw.text((0, 0), "eg:打印在这里", (0, 0, 255), font=font) # 第一个参数为打印的坐标,第二个为打印的文本,第三个为字体颜色,第四个为字体

4. PIL图片转cv2

import numpy as np
cv2_text_im = cv2.cvrColor(np.array(pil_im), cv2.COLOR_RGB2BGR))
cv2.imshow("Video", cv2_text_im)

参考

https://stackoverflow.com/questions/14134892/convert-image-from-pil-to-opencv-format
https://stackoverflow.com/questions/13576161/convert-opencv-image-into-pil-image-in-python-for-use-with-zbar-library
https://stackoverflow.com/questions/16373425/add-text-on-image-using-pil

时间: 2024-08-30 14:45:34

python opencv3 给图片加中文的相关文章

Python爬虫获取图片并下载保存至本地的实例

今天小编就为大家分享一篇Python爬虫获取图片并下载保存在本地的实例,具有很好的参考价值,希望对大家有所帮助.一起来看看吧! 1.抓取煎蛋网上的图片 2.代码如下 * * * import urllib.request import os def url_open(url): req=urllib.request.Request(url) req.add_header('User-Agent','Mozilla/5.0 (Windows NT 6.3; WOW64; rv:51.0) Geck

Android批量图片加载经典系列——采用二级缓存、异步加载网络图片

一.问题描述 Android应用中经常涉及从网络中加载大量图片,为提升加载速度和效率,减少网络流量都会采用二级缓存和异步加载机制,所谓二级缓存就是通过先从内存中获取.再从文件中获取,最后才会访问网络.内存缓存(一级)本质上是Map集合以key-value对的方式存储图片的url和Bitmap信息,由于内存缓存会造成堆内存泄露, 管理相对复杂一些,可采用第三方组件,对于有经验的可自己编写组件,而文件缓存比较简单通常自己封装一下即可.下面就通过案例看如何实现网络图片加载的优化. 二.案例介绍 案例新

用python切掉图片的黑边

手机里有很多G+里的截屏,都有一些黑边.像这样: 因为原图片的长宽不一定,导致黑边的大小不一定. 虽然图片都是居中的,但是有些图片是宽比高大,是横着截图的,所以这样的情况是上下左右都可能有黑边. 于是想到了用python的 PIL库来进行裁切. 研究了一下,原代码如下 from PIL import Image import os src_folder = "." tar_folder = "tar" backup_folder = "backup&quo

AsyncTask异步任务与LruCache缓存策略实现图片加载(一)

AsyncTask异步任务与LruCache缓存策略实现图片加载 AsyncTask异步任务 以下内容节选自官方文档: AsyncTask enables proper and easy use of the UI thread. This class allows to perform background operations and publish results on the UI thread without having to manipulate threads and/or ha

用python查看URL编码的中文

什么是URL编码呢,请看https://zh.wikipedia.org/wiki/Urlencode. 有时,我们向一些网站提交中文参数时,中文是会被编码成这种格式的 "%B1%E0%C2%EB ",它的原文是"编 码",URL编码也被称为"百分号编码",是不是有很多百分号.我们常使用的"空格"的URL编码就是 "%20",但是新的 标准把"空格" 替换为 "+",

Fresco图片加载框架之自总结Demo分享

学习资源汇总: 1.Fresco中文讲解教程:http://www.fresco-cn.org/ 2.Fresco项目github地址:https://github.com/facebook/fresco 3.自己结合上面两个资源在Android Studio下编写的Fresco完整功能总结Demo:https://github.com/NateRobinson/FrescoStudyDemo Demo效果图: Fresco框架简要说明: [下面文字摘自Fresco中文教材,主要方便自己后期回顾

使用CAShapeLayer来实现圆形图片加载动画(objective c)实现

使用CAShapeLayer来实现圆形图片加载动画(objective c)实现 by 伍雪颖 效果图 博客地址: 英文链接 中文链接 代码实现: swift实现中文链接有 objective c实现(github)

vue的 v-for 循环中图片加载路径问题

先看一下产品需求,如下图所示, 产品要求图片和它的名称一一对应,本来是非常简单的需求,后台直接返回图片路径和名称,前台直接读取就可以了,但是我们没有存储图片的服务器,再加上是一个实验性的需求,图片需要存放到前台.当时我想,vue 中的img 的src 可以动态绑定到一个变量上, 很简单吗,就没有考虑太多,直接开始做了. 首先和后台商量一下数据结构,因为图片要和名称一一对应,所以后台要返回中英文的名称的映射,我把前台的图片名称直接设置给后台给的英文名称,从而读取图片,图片和中文名称就一一对应了.数

Fresco-Facebook的图片加载框架的使用

目前常用的开源图片加载框架有:1.Universal-Image-Loader,该项目存在于Github上面https://github.com/nostra13/Android-Universal-Image-Loader: 2.fresco,该项目的中文网站是:http://www.fresco-cn.org/,在Github上面是:https://github.com/facebook/fresco 之前一直用的是Universal-Image-Loader,改用fresco之后,在有大图