当前位置: 首页 > news >正文

opencv 给图片和视频添加水印

给图片和视频添加水印

  • 1 给图片添加水印
  • 2 给视频添加水印

1 给图片添加水印

代码如下:

 '''添加水印''' img=cv2.imread(r'../15day4.10/src/xiaoren.png')  img2=cv2.imread(r'../15day4.10/src/bg.png')  h,w,c=img.shapeRIO_img2=img2[100:100+h,200:200+w]img3=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)_,black=cv2.threshold(cv2.cvtColor(img,cv2.COLOR_BGR2GRAY),30,255,cv2.THRESH_BINARY)_,white=cv2.threshold(cv2.cvtColor(img,cv2.COLOR_BGR2GRAY),30,255,cv2.THRESH_BINARY_INV)img_bit=cv2.bitwise_and(img,img,mask=white)RIO2_img2=cv2.bitwise_and(RIO_img2,RIO_img2,mask=black)RIO_img2[::]=cv2.add(RIO2_img2,img_bit)cv2.imshow('img',img)cv2.imshow("img2",img2)# cv2.imshow('RIO_img2',RIO_img2)# cv2.imshow('RIO2_img2',RIO2_img2)cv2.imshow('img_bit',img_bit)cv2.imshow('white',white)# cv2.imshow('img3',img3)cv2.waitKey(0)

在这里插入图片描述
步骤:

  • 1.读取logo图和背景图
  • 2.将logo图的 h,w,c=img.shape求出
  • 3.根据logo图高宽,在背景图里用RIO切割出和logo图形状一样的切片出来
  • 4.在对logo图进行掩膜运算得到白色logo
  • 5.对掩膜运算的logo进行反阈值处理得到黑色的logo
  • 6.再将黑色logo对背景图的切片进行按位与运算,使得黑色logo出现在背景图的切片中(只会有黑色logo区域变为黑色,其余不变)
  • 7 将白色logo与logo的原图进行按位与运算得到,原图的logo的部分
  • 8有黑色logo的切片与原图的logo进行相加,再赋值给原背景图的切片部分,最后语言背景图就有了logo了(切片与原图内存共享)

2 给视频添加水印

代码如下:

def test11(img2,img):'''添加水印''' # img=cv2.imread(r'../15day4.10/src/xiaoren.png')  # img2=cv2.imread(r'../15day4.10/src/bg.png')  h,w,c=img.shapeRIO_img2=img2[100:100+h,200:200+w]img3=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)_,black=cv2.threshold(cv2.cvtColor(img,cv2.COLOR_BGR2GRAY),30,255,cv2.THRESH_BINARY)_,white=cv2.threshold(cv2.cvtColor(img,cv2.COLOR_BGR2GRAY),30,255,cv2.THRESH_BINARY_INV)img_bit=cv2.bitwise_and(img,img,mask=white)RIO2_img2=cv2.bitwise_and(RIO_img2,RIO_img2,mask=black)RIO_img2[::]=cv2.add(RIO2_img2,img_bit)# cv2.imshow('img',img)# cv2.imshow("img2",img2)# # cv2.imshow('RIO_img2',RIO_img2)# # cv2.imshow('RIO2_img2',RIO2_img2)# cv2.imshow('img_bit',img_bit)# cv2.imshow('white',white)# cv2.imshow('img3',img3)# cv2.waitKey(0)return img2
def test12():'''给视频添加logo'''path=r'../15day4.10/src/谁.mp4'img2=cv2.imread(r"../15day4.10/src/xiaoren.png")cap=cv2.VideoCapture(path) #获取视频while True:# 获取每一帧的图片ret,img=cap.read()# ret表示是否获取到视频中的图片if ret:img=test11(img,img2)cv2.imshow("img",img)if cv2.waitKey(17)&0xff==ord('q'):breakelse:break

在这里插入图片描述

相关文章:

  • MySQL运维三部曲初级篇:从零开始打造稳定高效的数据库环境
  • Dify快速入门之chatflow
  • Linux网络编程——基于ET模式下的Reactor
  • 【正则表达式】正则表达式使用总结
  • 如何在3090显卡上使用老版本torch
  • python 库 下载 ,整合在一个小程序 UIUIUI
  • LeetCode 239 滑动窗口最大值
  • 【机器学习】从炼丹到落地!模型部署与监控全流程实战指南 (MLOps 核心)
  • 【sylar-webserver】8 HOOK模块
  • Linux系统:进程终止的概念与相关接口函数(_exit,exit,atexit)
  • BT1120 BT656驱动相关代码示例
  • 计算机网络八股——HTTP协议与HTTPS协议
  • Linux疑难杂惑 | 云服务器重装系统后vscode无法远程连接的问题
  • 针对MCP认证考试中的常见技术难题进行实战分析与解决方案分享
  • Windows桌面图标变白的解决方案
  • springboot--web开发请求参数接收注解
  • GD32H7单片机使用segger_rtt,rtt-viewer看不到输出的问题,怎样解决?
  • 07-DevOps-安装部署Harbor镜像仓库
  • 小刚说C语言刷题——1035 判断成绩等级
  • 资源-又在网上淘到金了
  • 辽宁男篮被横扫这一晚,中国篮球的一个时代落幕了
  • 香港发生车祸致22人受伤,4人伤势严重
  • 今年4月上海一二手房成交面积同比增21%,二手房成交2.07万套
  • 老凤祥一季度净利减少两成,去年珠宝首饰营收下滑19%
  • 影子调查丨危房之下,百余住户搬离梦嘉商贸楼
  • 柴德赓、纪庸与叫歇碑