当前位置: 首页 > 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 判断成绩等级
  • 资源-又在网上淘到金了
  • 影子调查丨义门陈遗址建筑被“没收”风波
  • 一季度江西GDP达7927.1亿元,同比增长5.7%
  • 居然智家:实控人、董事长兼CEO汪林朋被留置、立案,公司经营正常
  • 恒大汽车接获港交所复牌指引,还未披露公司2024年年报
  • 建投读书会·东西汇流|上海城市体育休闲中的东西方元素
  • 一季度全国铁路发送旅客10.74亿人次,创同期历史新高