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)

三,实验现象

结果:

相关推荐
阿里云大数据AI技术几秒前
Fusion 引擎赋能:七猫如何使用阿里云 EMR Serverless Spark 实现数仓加速
人工智能
fengfuyao9852 分钟前
MATLAB实现全景拼接
人工智能·计算机视觉·matlab
2201_757830873 分钟前
JS的学习
前端·javascript·学习
好游科技6 分钟前
语音语聊系统开发深度解析:WebRTC与AI降噪技术如何重塑
人工智能·webrtc·交友·im即时通讯·社交软件·社交语音视频软件
西格电力科技10 分钟前
源网荷储与碳中和:推动能源清洁转型的关键路径
大数据·人工智能·分布式·系统架构·能源
HyperAI超神经10 分钟前
在线教程丨30毫秒处理100个检测对象,SAM 3实现可提示概念分割,性能提升2倍
人工智能·计算机视觉·ai·图像分割·sam 3
Study99628 分钟前
科普专栏|大语言模型:理解与生成语言的人工智能
人工智能·深度学习·机器学习·大模型·agent·大模型微调·大模型应用开发
xixixi7777728 分钟前
CRNN(CNN + RNN + CTC):OCR识别的经典之作
人工智能·rnn·学习·架构·cnn·ocr·图像识别
c#上位机31 分钟前
halcon获取区域中心坐标以及面积——area_center
图像处理·计算机视觉·c#·halcon
weixin_4296907240 分钟前
数字人源码部署供应商
人工智能·python