• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    利用Python+OpenCV三步去除水印

    一、推理原理

    1.标定噪声的特征,使用cv2.inRange二值化标识噪声对图片进行二值化处理,具体代码:cv2.inRange(img, np.array([200, 200, 240]), np.array([255, 255, 255])),把[200, 200, 200]~[255, 255, 255]以外的颜色处理为0

    2.使用OpenCV的dilate方法,扩展特征的区域,优化图片处理效果

    3.使用inpaint方法,把噪声的mask作为参数,推理并修复图片

    二、推理步骤

    1.从源图片,截取右下角部分,另存为新图片

    2.识别水印,颜色值为:[200, 200, 200]~[255, 255, 255]

    3.去掉水印,还原图片

    4.把源图片、去掉水印的新图片,进行重叠合并

    三、参考代码

    import cv2
    import numpy as np
    from PIL import Image
    import os
    ​
    dir = os.getcwd()
    path = "1.jpg"
    newPath = "new.jpg"
    img=cv2.imread(path,1)
    hight,width,depth=img.shape[0:3]
    ​
    #截取
    cropped = img[int(hight*0.8):hight, int(width*0.7):width]  # 裁剪坐标为[y0:y1, x0:x1]
    cv2.imwrite(newPath, cropped)
    imgSY = cv2.imread(newPath,1)
    ​
    #图片二值化处理,把[200,200,200]-[250,250,250]以外的颜色变成0
    thresh = cv2.inRange(imgSY,np.array([200,200,200]),np.array([250,250,250]))
    #创建形状和尺寸的结构元素
    kernel = np.ones((3,3),np.uint8)
    #扩展待修复区域
    hi_mask = cv2.dilate(thresh,kernel,iterations=10)
    specular = cv2.inpaint(imgSY,hi_mask,5,flags=cv2.INPAINT_TELEA)
    cv2.imwrite(newPath, specular)
    ​
    #覆盖图片
    imgSY = Image.open(newPath)
    img = Image.open(path)
    img.paste(imgSY, (int(width*0.7),int(hight*0.8),width,hight))
    img.save(newPath)
    
    import cv2
    import numpy as np
    from PIL import Image
    import os
    ​
    dir = os.getcwd()
    path = "1.jpg"
    newPath = "new.jpg"
    img=cv2.imread(path,1)
    hight,width,depth=img.shape[0:3]
    ​
    #截取
    cropped = img[int(hight*0.8):hight, int(width*0.7):width]  # 裁剪坐标为[y0:y1, x0:x1]
    cv2.imwrite(newPath, cropped)
    imgSY = cv2.imread(newPath,1)
    ​
    #图片二值化处理,把[200,200,200]-[250,250,250]以外的颜色变成0
    thresh = cv2.inRange(imgSY,np.array([200,200,200]),np.array([250,250,250]))
    #创建形状和尺寸的结构元素
    kernel = np.ones((3,3),np.uint8)
    #扩展待修复区域
    hi_mask = cv2.dilate(thresh,kernel,iterations=10)
    specular = cv2.inpaint(imgSY,hi_mask,5,flags=cv2.INPAINT_TELEA)
    cv2.imwrite(newPath, specular)
    ​
    #覆盖图片
    imgSY = Image.open(newPath)
    img = Image.open(path)
    img.paste(imgSY, (int(width*0.7),int(hight*0.8),width,hight))
    img.save(newPath)
    

    四、效果图

    没去水印前:

    去了后:

    到此这篇关于利用Python+OpenCV三步去除水印的文章就介绍到这了,更多相关Python+OpenCV去水印内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • 拒绝盗图!教你怎么用python给图片加水印
    • 基于python的图片修复程序(实现水印去除)
    • 运用python去除图片水印
    • Python编程OpenCV和Numpy图像处理库实现图片去水印
    上一篇:python实现自定义日志的具体方法
    下一篇:解决Python中的modf()函数取小数部分不准确问题
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    利用Python+OpenCV三步去除水印 利用,Python+OpenCV,三步,去除,