关于视频去水印的一点尝试

一. 视频去水印的几种方法

  1. 使用ffmpeg delogo滤镜

delogo 滤镜的原理是通过插值算法,用水印周围的像素填充水印的位置。

示例:

ffmpeg -i input.mp4 -filter_complex "[0:v]delogo=x=420:y=920:w=1070:h=60" output.mp4

该命令表示通过滤镜去除水印,水印的位置为(x,y),尺寸为wxh。

效果如下:

这种方式从原理上来讲是存在问题的,可以保证画面整体颜色看起来差不多,但是局部看画面是不连续的。对于水印周围是纯色的情况,这种方式是没有问题的。

适用场景:水印位置为纯色,或者颜色变化不明显的情况。

  1. AI 去水印

尝试了可以搜索到的几种AI软件:

(1)有的使用的是ffmpeg delogo类似的方案;

(2)有的使用对象识别的方式,理论上来说,这种方式是可行的。但是也有一些问题,首先图像识别运算量大,耗时特别长。如果是单张图片还可以,对于视频耗时太长了。

  1. 同系列图片替换

这是自己尝试的一种方式,算是抛砖引玉吧。原理也很简单,一般视频就是连续变化的图片,只要找到两张图片水印区域不重叠,就可以进行替换。

原图1

原图2

原图1相对于原图2的偏转,这是对原图1 进行旋转后的效果。

提取水印位置,可以看到原图1和原图2,在水印处是没有重叠的。

用从原图2中提取的水印位置的图片,替换原图1 中的水印位置。可以看到图像是连续的,除了图像的清晰度有些区别。这是因为原图1和原图2 水印位置的图片是不一样导致的。

下面是替换后的视频:

视频去水印-CSDN直播

这种方法的适用场景:

  1. 在水印区域是相同的或者变化很小

  2. 水印区域在不同图片存在不重叠的情况。

上面是我的一点尝试,了解的东西有限,欢迎大家交流。

相关推荐
911hzh2 分钟前
Flutter 音视频通话集成实战:WebSocket 做信令,WebRTC 传音视频,附详细事件时序图
websocket·flutter·音视频
大龄程序员狗哥7 小时前
第47篇:使用Speech-to-Text API快速构建语音应用(操作教程)
人工智能
KKKlucifer7 小时前
数据安全合规自动化:策略落地、审计追溯与风险闭环技术解析
人工智能·安全
RWKV元始智能7 小时前
RWKV超并发项目教程,RWKV-LM训练提速40%
人工智能·rnn·深度学习·自然语言处理·开源
dyj0957 小时前
Dify - (一)、本地部署Dify+聊天助手/Agent
人工智能·docker·容器
墨染天姬7 小时前
【AI】Hermes的GEPA算法
人工智能·算法
小超同学你好7 小时前
OpenClaw 深度解析系列 · 第8篇:Learning & Adaptation(学习与自适应)
人工智能·语言模型·chatgpt
紫微AI8 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
码途漫谈8 小时前
Easy-Vibe开发篇阅读笔记(四)——前端开发之结合 Agent Skills 美化界面
人工智能·笔记·ai·开源·ai编程
易连EDI—EasyLink8 小时前
易连EDI–EasyLink实现OCR智能数据采集
网络·人工智能·安全·汽车·ocr·edi