使用python-opencv去掉视频水印

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


今天遇到一个新需求,就是去掉视频的水印,原理是先手动标注出水印的区域,再通过代码将区域进行模糊处理,代码如下:

import math
 
import cv2
 
capture=cv2.VideoCapture('1234.mp4')
height=capture.get(cv2.CAP_PROP_FRAME_HEIGHT)
width=capture.get(cv2.CAP_PROP_FRAME_WIDTH)
count=capture.get(cv2.CAP_PROP_FRAME_COUNT)
fps=capture.get(cv2.CAP_PROP_FPS)
 
fourcc=cv2.VideoWriter_fourcc('m','p','4','v')
outVideo=cv2.VideoWriter()
outVideo.open('out.mp4',fourcc,fps,(int(width),int(height)),True)
 
 
def process_video(image):
    # 需要注意的是第一个范围是y轴坐标的范围,第二个是x轴坐标的范围
    # img=image[1160-90:1160, 509-193:509]
    # img=cv2.GaussianBlur(img,(5,5),1.5)
    # image[1160:1160+90, 509:509+193] = img
    mask = cv2.imread( 'cat_inpainted.png' ,0)
    new = cv2.imread( '344.png')
    dst = cv2.inpaint(image, mask, 3 , cv2.INPAINT_NS) # 去掉水印
    # 增加新的水印
    h, w = dst.shape[:2]  # 图片的高度和宽度 
    for i in range(329,h):
        for j in range(236,w):
            for k in range(3):
                dst[i][j][k] =  (int(dst[i][j][k]) + int(new[i][j][k])) if (int(dst[i][j][k]) + int(new[i][j][k]))<255 else 255
    return dst
 
for i in range(int(count)):
    ret,frame=capture.read()
    if ret is True:
        result=process_video(frame)
        outVideo.write(result)
    else:
        break
    print('进度:',str(math.ceil(i/count*100))+'%')
outVideo.release()

其中cat_inpainted.png,是水印的一张mask图片,如下如所示(手动标注出水印的区域):
在这里插入图片描述

344.png是新的水印

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
使用Python对图片去水印,可以按照以下步骤进行操作: 1. 导入必要的库:首先,需要导入一些Python库来处理图像,如PIL(Python Imaging Library)或OpenCV。可以使用以下代码导入PIL库: ```python from PIL import Image ``` 2. 加载图片:使用PIL的`open()`函数加载要处理的图片,并将其赋值给一个变量。例如,可以使用以下代码加载名为"image.jpg"的图片: ```python image = Image.open("image.jpg") ``` 3. 去除水印:根据具体的水印情况,可以考虑以下几种方法去除水印: - 使用图像处理算法:根据水印的特征和位置,可以使用图像处理算法来去除水印。例如,可以使用边缘检测、模糊化、修复或填充等技术来消除水印的痕迹。 - 使用深度学习模型:如果水印比较复杂或难以通过传统图像处理算法去除,可以考虑使用深度学习模型。训练一个神经网络模型来识别并去除水印,或者使用预训练的模型进行水印消除。 - 使用克隆修复工具:克隆修复工具如Photoshop等,可以通过选择和复制周围区域的像素来遮盖水印。你可以使用Python的图像处理库,如PIL或OpenCV,来实现类似的克隆修复功能。 4. 保存处理后的图片:处理完图片后,可以使用PIL库的`save()`函数将结果保存到指定位置。例如,可以使用以下代码将处理后的图片保存为"output.jpg": ```python image.save("output.jpg") ``` 需要注意的是,针对不同的水印情况,可能需要采用不同的方法和技术来去除水印。选择合适的方法需要根据具体的水印特征和要求来决定。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值