python给图片加半透明水印_Python+OpenCV为图片添加中文水印与图片水印
OpenCV中在图片上输出中文一般有两种解决办法:
一种需要借助FreeType库实现。FreeType库是一个完全免费(开源)的、高质量的且可移植的字体引擎,它提供统一的接口来访问多种字体格式文件。但使用FreeType需要下载库并重新编译,但这种方法及其麻烦,完全不建议尝试
在Python中,可以借助PIL(Python Imaging Library)模块和OpenCV对象进行数据类型转换实现,相对简单很多,需要做的只是对图像进行OpenCV格式和PIL格式的相互转换。
一、水印为英文
直接使用cv2中的putText
import cv2
img1 = cv2.imread('linuxidc.com.jpg',cv2.IMREAD_COLOR)
text = 'www.linuxidc.com'
pos = (10,150)
font_type = 4
font_size = 2
color = (255,0,0)
bold = 1
#图片,文字,位置,字体,字号,颜色,厚度
cv2.putText(img1,text,pos, font_type, font_size, color,bold)
cv2.imshow('www.linuxidc.com',img1)
cv2.waitKey(0)
效果图如下:
二、水印为中文
这种情况下处理较为复杂,因为cv2的putText直接输出中文会出现乱码的情况。
opencv对象转PIL对象,注意将opencv的BGR通道转成RGB通道
Image.fromarray(cv2.cvtColor(img1, cv2.COLOR_BGR2RGB))
PIL对象转opencv对象,注意将PIL的RGB通道转成BGR通道
cv_img = cv2.cvtColor(np.asarray(pil_image),cv2.COLOR_RGB2BGR)
import cv2
from PIL import Image,ImageFont,ImageDraw
import numpy as np
img1 = cv2.imread('linuxidc.com.jpg',cv2.IMREAD_COLOR)
pil_image = Image.fromarray(cv2.cvtColor(img1, cv2.COLOR_BGR2RGB))
font = ImageFont.truetype('NotoSerifCJK-Regular.ttc', 40)
color = (0,0,255)
pos = (10,150)
text = u"Linux公社www.linuxidc.com"
draw = ImageDraw.Draw(pil_image)
draw.text(pos,text,font=font,fill=color)
cv_img = cv2.cvtColor(np.asarray(pil_image),cv2.COLOR_RGB2BGR)
cv2.imshow('www.linuxidc.com',cv_img)
cv2.waitKey(0)
效果如如下:
三、图片水印
from PIL import Image
im = Image.open("linuxidc.com.jpg")
mark=Image.open("linuxidc.png")
layer=Image.new('RGBA', im.size, (0,0,0,0))
layer.paste(mark, (im.size[0]-220,im.size[1]-520))
out=Image.composite(layer,im,layer)
out.show()
效果图如下:
Python skimage模块的安装
pip3 install scikit-image
python给图片加半透明水印_Python+OpenCV为图片添加中文水印与图片水印相关推荐
- python给图片加半透明水印_Python 批量加水印就这么简单!
工作的时候,尤其是自媒体,我们必备水印添加工具以保护我们的知识产权,网上有许多的在线/下载的水印添加工具,但他们或多或少都存在以下问题: 在线工具需要将图片上传到对方服务器,信息不安全. 很多工具不具 ...
- python给图片加半透明水印_图片添加半透明文字水印 Python
效果 python marker.py -f ./input/test.png -m '添加水印' 功能 使用知名python图片处理库PIL,为图片添加文字水印. 实现 步骤:根据文字生成水印图片: ...
- python的pillow给图片加文字_详解PILLOW图片中加入中文的实例
索引简述 准备 示例 效果图 结语 简述 我在使用opencv2或3的时候想要在图片上添加中文文字,需要去下载Freetype库,编译好链接到opencv库中才能中文的输出.网上大部分在图片中插入中文 ...
- python打出由边框包围的_python opencv 图像边框(填充)添加及图像混合的实现方法(末尾实现类似幻灯片渐变的效果)...
图像边框的实现 图像边框设计的主要函数 cv.copyMakeBorder()--实现边框填充 主要参数如下: 参数一:源图像--如:读取的img 参数二--参数五分别是:上下左右边的宽度--单位:像 ...
- python图片转换成文字_Python输出汉字字库及将文字转换为图片的方法
用python输出汉字字库问题1:假设我们知道汉字编码范围是0x4E00到0x9FA5,怎么从十六进制的编码转成人类可读的字呢? 问题2:怎么把unicode编码的字写入文件呢,如果直接用open() ...
- 【web】图片加载失败,重试三次, 若失败则使用占位图片
需求描述: 加载图片过程中,可能遇见网络不好第一次加载不出来,那么此时,需要重复加载三次,若还是失败就使用默认的占位图 解决思路 监听图片的error事件, 当图片上的error事件被触发,就进入我们 ...
- Java使用Graphics2D添加文字水印碰见的坑(给透明底图片加半透明水印)
先上代码 public static void addText(String fileName, String text) throws IOException {BufferedImage buff ...
- python二维码识别读取_python+opencv检测图片中二维码
缘起 需要检测发票中二维码的位置,以确定图像该怎么旋转,同时也可以为提取二维码信息创造先觉条件!(万恶的需求!) 失败的尝试--opencv训练大法 不感兴趣的可跳过不看! 解释:原文作者是训练检测舌 ...
- python图片相似度计算_python Opencv计算图像相似度过程解析
这篇文章主要介绍了python Opencv计算图像相似度过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一.相关概念 一般我们人区分谁是谁 ...
最新文章
- 决策树准确率低原因_机器学习决策树算法--剪枝算法
- java 异常信息_优雅的异常处理 -- Java中的异常
- OpenStack、KVM、Docker——Docker之后还需要OpenStack吗?
- java 超时中断_JAVA 超时中断处理
- 转载 敏捷教练,从A到Z
- iPhone 15有望配备潜望式摄像头 供应商已宣布投资建厂
- javascript案例大全_JavaScript 中文资源大全,你值得拥有
- 末学者笔记--Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站
- BZOJ4817 [SDOI2017]树点涂色
- python3实现bicubic(双三次插值)重建四倍放大图像
- Linux如何磁盘分区
- mysql 官网 update_UPDATE
- c语言 函数调用顺序,C++函数定义和调用过程(超详细)
- ValueError: only single character unicode strings can be converted to Py_UCS4, got length 0
- 三十天博客计划之《引言》
- Java创建单例模式(singleton)的几种实现方式
- cesium面积计算_GitHub - BulletYuan/bulletCesium: GIS可视化——基于Cesiumjs的一些工具类,测量距离、测量面积。持续更新......
- 苏宁门店数字化白皮书发布 行业数字化进程将再提速
- vue 二维码解码器
- FME高性能编程,让你的FME快起来