• 基于python-opencv给图像添加水印


    一.添加水印原理:
    背景图:
    在这里插入图片描述
    水印图:在这里插入图片描述
    1.将logo进行大小调整缩小维度。根据logo的尺度得到背景图上的ROI位置。
    2.制作logo mask。
    基于阈值进行二值化,此时得到的mask,logo位置为黑色,其余位置为白色。
    将mask位置反转, 将logo位置变为白色,其余变为黑色
    在这里插入图片描述
    3.将背景中的ROI区域黑化。利用按位与操作
    img_base_bg = cv2.bitwise_and(roi, roi, mask = mask)
    在这里插入图片描述
    在logo原图中利用mask_inv, 按位与,得到彩色logo区域,其余位置为黑色
    img_logo_fg = cv2.bitwise_and(img_logo, img_logo, mask = mask_inv)#得到彩色logo区域,其余位置为黑色
    在这里插入图片描述
    4.将img_base_bg 与img_logo_fg 相加。
    dst = cv2.add(img_base_bg, img_logo_fg)
    在这里插入图片描述

    5.还原原图。
    在这里插入图片描述
    二.python+openCV代码

    import cv2
    img_base = cv2.imread('saliency.png')
    img_logo = cv2.imread('logo.png')
    
    img_logo = cv2.resize(img_logo, (int(img_logo.shape[1]), int(img_logo.shape[0])))
    
    rows, cols, channels = img_logo.shape
    roi = img_base[0:rows, 0:cols]
    
    img2gray = cv2.cvtColor(img_logo, cv2.COLOR_BGR2GRAY)
    ret, mask = cv2.threshold(img2gray, 20, 255, cv2.THRESH_BINARY_INV)#得到的mask,logo位置为黑色,其余位置为白色
    mask_inv = cv2.bitwise_not(mask) #  将logo位置变为白色,其余变为黑色
    cv2.imshow('mask_inv' ,mask_inv )
    
    # 将ROI掩码区域黑化
    img_base_bg = cv2.bitwise_and(roi, roi, mask = mask)
    img_logo_fg = cv2.bitwise_and(img_logo, img_logo, mask = mask_inv)#得到彩色logo区域,其余位置为黑色
    
    dst = cv2.add(img_base_bg, img_logo_fg)
    img_base[0:rows, 0:cols] = dst
    
    
    cv2.imshow('img_base_bg', img_base_bg)
    cv2.imshow('img_logo_fg', img_logo_fg)
    cv2.imshow('res', img_base)
    cv2.imshow('mask_inv', mask_inv)
    
    cv2.imshow('dst', dst)
    
    cv2.waitKey(0)
    cv2.destroyAllWindows()
    
    cv2.imwrite('result.png', img_base)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
  • 相关阅读:
    发稿渠道和发布新闻的步骤和技巧,收藏!
    CountDownLatch
    根据实体类生成表生成语句
    电力输送、材料和互连领域即将发生巨大变化
    10 个不错的 C 语言开源项目
    基于token进行登录,每次请求携带token
    Js数组去重都有哪些方法?
    rocky9.1 深度学习环境配置
    聊天没有表情包被嘲讽,程序员直接用python爬取了十万张表情包
    40个高质量SSM毕设项目分享【源码+论文】(五)
  • 原文地址:https://blog.csdn.net/exsolar_521/article/details/126409542