OpenCV图片添加水印

函数效果图:

本来只有蓝色背景,这两个人物是水印添加上去的

原理:

本实验中添加水印的概念其实可以理解为将一张图片中的某个物体或者图案提取出来,然后叠加到另一张图片上。具体的操作思想是通过将原始图片转换成灰度图,并进行二值化处理,去除背景部分,得到一个类似掩膜的图像。然后将这个二值化图像与另一张图片中要添加水印的区域进行"与"运算,使得目标物体的形状出现在要添加水印的区域。最后,将得到的目标物体图像与要添加水印的区域进行相加,就完成了添加水印的操作。这样可以实现将一个图像中的某个物体或图案叠加到另一个图像上,从而实现添加水印的效果。就本实验而言,会用到两个新的组件,一个是模板输入,一个是图像融合。

python 复制代码
import cv2
logo=cv2.imread('./tm1.png')
img=cv2.imread('./bgc.jpeg')
logo2=cv2.imread('./tm2.png')
def koutu(logo,img,height=0,width=0):
    logo_gray = cv2.cvtColor(logo, cv2.COLOR_BGR2GRAY)
    _,logo_binary=cv2.threshold(logo_gray,
                                0,#阈值
                                255,#最大值
                                cv2.THRESH_BINARY_INV)#反阈值法
    # 二值化的logo图与原图的roi区域与操作
    ROI=img[height:height+logo.shape[0],width:width+logo.shape[1]]# 原图的roi区域:高度0 ~ rows-1,宽度0 ~ cols-1
    ROI_logo=cv2.bitwise_and(ROI,ROI,mask=logo_binary)# 通过位于操作得到图片除掩膜以外的背景
    img_logo=cv2.add(ROI_logo,logo)# 图像融合
    img[height:height+logo.shape[0], width:width+logo.shape[1]] = img_logo# 把roi的数据更新到原图中
    cv2.imshow('img', img)
    cv2.waitKey(0)
koutu(logo,img,0,0)
koutu(logo2,img,width=500)
相关推荐
To_OC4 小时前
搞懂 Token 和 Embedding 后,我终于明白大模型是怎么 "读" 文字的
人工智能·llm·agent
冬奇Lab6 小时前
每日一个开源项目(第139篇):Voicebox - 本地运行的开源 ElevenLabs 替代品
人工智能·开源·资讯
冬奇Lab6 小时前
Skill 系列(03):Skill 设计范式——5 个模式让输出从混沌到可预测
人工智能·开源·agent
IT_陈寒8 小时前
Python搞不定字符串编码?这破玩意坑我两小时!
前端·人工智能·后端
大模型真好玩10 小时前
什么是Loop Engineering?最通俗易懂的Loop Engineering核心概念
人工智能·agent·deepseek
叁两10 小时前
前端转型AI Agent该如何学习?(前置篇)
前端·人工智能·node.js
LaiYoung_10 小时前
🎁 送你一套超好用超实用的 FE AI-Coding Skills
前端·人工智能·开源
ZzT13 小时前
怎么做才不会被 AI 替代?
人工智能·程序员
道友可好13 小时前
从今天开始:你的第一个 Harness Engineering 实践
前端·人工智能·后端