使用open-cv实现图片添加水印

实验原理

  • 将一个透明的水印图层覆盖到原始图像上

实验过程

python 复制代码
import cv2

def add_logo_to_image(img, logo_path, position, mask_threshold=0):
    """
    在图像上添加logo。

    参数:
    img: 输入的图像,为一个二维或三维的numpy数组。
    logo_path: logo图片的路径,字符串类型。
    position: logo在图像上的位置,为一个元组,包含两个整数,分别表示x和y坐标。
    mask_threshold: 用于创建logo二值掩码的阈值,可选,默认为0。

    返回:
    添加logo后的图像。
    """
    # 读取logo图片
    logo = cv2.imread(logo_path)
    # 将logo转换为灰度图
    logo_gray = cv2.cvtColor(logo, cv2.COLOR_BGR2GRAY)
    # 根据灰度图和阈值创建logo的二值掩码
    _, logo_binary = cv2.threshold(logo_gray, mask_threshold, 255, cv2.THRESH_BINARY_INV)

    # 解包位置坐标
    x, y = position
    # 根据logo尺寸定义图像上的区域
    ROI = img[y:y + logo.shape[0], x:x + logo.shape[1]]
    # 使用掩码对ROI区域和logo进行位运算,以融合logo
    ROI_logo = cv2.bitwise_and(ROI, ROI, mask=logo_binary)
    img_logo = cv2.add(ROI_logo, logo)

    # 将融合后的logo放置到原图像的相应位置
    img[y:y + logo.shape[0], x:x + logo.shape[1]] = img_logo
    # 返回添加logo后的图像
    return img


# 读取背景图像
img = cv2.imread('./bgc.jpeg')

# 在图像的左上角添加第一个logo
img = add_logo_to_image(img, './tm1.png', (0, 0))
# 在图像的右上角添加第二个logo
img = add_logo_to_image(img, './tm2.png', (400, 0))

# 显示最终的图像
cv2.imshow('img', img)
# 等待按键按下,然后关闭窗口
cv2.waitKey(0)

实验结果

相关推荐
飞翔的佩奇6 小时前
【完整源码+数据集+部署教程】表盘指针检测系统源码和数据集:改进yolo11-CA-HSFPN
python·yolo·计算机视觉·数据集·yolo11·表盘指针检测
lxmyzzs8 小时前
pyqt5无法显示opencv绘制文本和掩码信息
python·qt·opencv
Coovally AI模型快速验证9 小时前
农田扫描提速37%!基于检测置信度的无人机“智能抽查”路径规划,Coovally一键加速模型落地
深度学习·算法·yolo·计算机视觉·transformer·无人机
飞翔的佩奇10 小时前
【完整源码+数据集+部署教程】二维码与查找模式检测系统源码和数据集:改进yolo11-CSwinTransformer
python·yolo·计算机视觉·数据集·yolo11·二维码与查找模式检测
qq_5260991312 小时前
图像采集卡与工业相机:机器视觉“双剑合璧”的效能解析
图像处理·数码相机·计算机视觉
CoovallyAIHub14 小时前
为高空安全上双保险!无人机AI护航,YOLOv5秒判安全带,守护施工生命线
深度学习·算法·计算机视觉
才思喷涌的小书虫15 小时前
小白玩转 DINO-X MCP(2):基于 DINO-X MCP 搭建饮食规划工作流
计算机视觉·mcp
计算机sci论文精选16 小时前
CVPR 2025 | 具身智能 | HOLODECK:一句话召唤3D世界,智能体的“元宇宙练功房”来了
人工智能·深度学习·机器学习·计算机视觉·机器人·cvpr·具身智能
山烛17 小时前
OpenCV 图像处理基础操作指南(二)
人工智能·python·opencv·计算机视觉
CoovallyAIHub18 小时前
线性复杂度破局!Swin Transformer 移位窗口颠覆高分辨率视觉建模
深度学习·算法·计算机视觉