open cv学习之图片添加水印

一,实验原理

添加水印的过程可以理解为将一张图片中的物体或图案提取出来,并叠加到另一张图片上。具体操作是:先将原始图像转换为灰度图并进行二值化,去除背景,得到一个掩膜图像。然后将掩膜与目标区域进行"与"运算,使目标物体的形状出现在该区域。最后,将目标物体图像与该区域相加,完成水印添加。

二,实验代码

add_img.py

python 复制代码
import cv2


def img_add(logo, img, x, y):
    # 将logo图像进行灰度化和二值化,得到一个白底的掩膜
    logo_gray = cv2.cvtColor(logo, cv2.COLOR_BGR2GRAY)
    _, logo_binary = cv2.threshold(logo_gray, 0, 255, cv2.THRESH_BINARY_INV)

    # 在原始图像中选取和logo同等大小的矩形区域
    # 这个区域的左上角坐标为(x, y),大小与logo相同
    ROI = img[y:y + logo.shape[0], x:x + logo.shape[1]]

    # 将ROI区域和logo的掩膜进行位与运算,结果存在ROI_logo中
    ROI_logo = cv2.bitwise_and(ROI, ROI, mask=logo_binary)

    # 将处理后的ROI区域与原始的logo进行加法运算,
    # 得到最终的融合logo与ROI区域的效果
    img_logo = cv2.add(ROI_logo, logo)

    # 将融合的图像在要添加logo的原图中进行替换
    img[y:y + logo.shape[0], x:x + logo.shape[1]] = img_logo
    return img

运行文件中:

python 复制代码
import cv2
from day4 import img_add

# 读取两个logo和一个原图
logo = cv2.imread("1.png")
logo2 = cv2.imread("3.png")
img = cv2.imread("2.jpeg")

# 调整原图的大小
img = cv2.resize(img, (0, 0), fx=1, fy=0.45)

# 在原图上的指定位置添加logo和logo2
img = img_add.img_add(logo, img, 120, 180)
img = img_add.img_add(logo2, img, 400, 200)

# 显示加上logo后的图像
cv2.imshow('image', img)
cv2.waitKey(0)

三,实验现象

结果:

相关推荐
OpenVINO 中文社区3 分钟前
OpenVINO™正式进入 llama.cpp:GGUF 模型现已支持 Intel CPU、GPU 与 NPU
人工智能·openvino·英特尔
唐樽7 分钟前
C++ 竞赛学习路线笔记
c++·笔记·学习
ZKNOW甄知科技8 分钟前
数智同行:甄知科技2026年Q1季度回顾
运维·服务器·人工智能·科技·程序人生·安全·自动化
呆呆敲代码的小Y8 分钟前
【Unity工具篇】| 游戏完整资源热更新流程,YooAsset官方示例项目
人工智能·游戏·unity·游戏引擎·热更新·yooasset·免费游戏
jikemaoshiyanshi9 分钟前
B2B企业GEO服务商哪家好?深度解析径硕科技(JINGdigital)及其JINGEO产品为何是首选
大数据·运维·人工智能·科技
Lab_AI9 分钟前
浩天药业携手创腾科技,开启研发数字化新篇章!电子实验记录本(ELN)落地浩天药业
人工智能
supericeice11 分钟前
大模型建筑隐患管理方案怎么做?创邻科技用知识图谱、图数据库和企业AI大脑打通隐患问答、整改与推荐
人工智能·科技·知识图谱
蕤葳-14 分钟前
非编程背景学习AI的方法
人工智能
北京耐用通信17 分钟前
不换设备、不重写程序:耐达讯自动化网关如何实现CC-Link IE转Modbus TCP的高效互通?
人工智能·科技·物联网·网络协议·自动化·信息与通信
计算机毕业设计指导18 分钟前
基于机器学习和深度学习的恶意WebURL检测系统实战详解
人工智能·深度学习·机器学习·网络安全