【Python】基于blind-watermark库添加图片盲水印

blind-watermark 是一个用于在图像中添加和提取盲水印的 Python 库。盲水印是一种嵌入信息(如水印)到图像中的方法,使得水印在视觉上不可见,但在需要时可以通过特定的算法进行提取。以下是如何使用 blind-watermark 库来添加和提取盲水印的示例。

首先,你需要安装 blind-watermark 库。你可以通过以下命令来安装它:

bash 复制代码
pip install blind-watermark

添加盲水印

下面是一个示例代码,用于在图像中添加盲水印:

python 复制代码
from blind_watermark import Watermark
import cv2

# 读取原始图像和水印图像
original_image_path = 'path_to_your_original_image.png'
watermark_image_path = 'path_to_your_watermark_image.png'

# 加载图像
original_image = cv2.imread(original_image_path, cv2.IMREAD_GRAYSCALE)
watermark_image = cv2.imread(watermark_image_path, cv2.IMREAD_GRAYSCALE)

# 创建水印对象
wm = Watermark(alpha=32)  # alpha 是水印嵌入强度

# 添加水印到原始图像
marked_image = wm.embed(original_image, watermark_image)

# 保存带有水印的图像
cv2.imwrite('marked_image.png', marked_image)

提取盲水印

下面是一个示例代码,用于从带有水印的图像中提取盲水印:

python 复制代码
# 读取带有水印的图像
marked_image_path = 'marked_image.png'
marked_image = cv2.imread(marked_image_path, cv2.IMREAD_GRAYSCALE)

# 使用相同的水印对象(注意要使用相同的 alpha 值)
wm = Watermark(alpha=32)

# 提取水印
extracted_watermark = wm.extract(marked_image, original_image)

# 保存提取的水印图像
cv2.imwrite('extracted_watermark.png', extracted_watermark)

注意事项

  1. 图像格式 :确保原始图像和水印图像都是灰度图像(即单通道图像)。你可以使用 OpenCV 的 cv2.imread 函数,并指定 cv2.IMREAD_GRAYSCALE 标志来读取灰度图像。

  2. 图像大小:通常,水印图像应该比原始图像小得多。如果水印图像太大,可能会导致嵌入水印后的图像质量下降或水印提取效果不佳。

  3. alpha 参数alpha 参数控制水印的嵌入强度。较大的 alpha 值会使水印更难以去除,但也可能导致原始图像质量下降。

  4. 图像路径:确保提供的图像路径是正确的,并且图像文件存在。

通过以上步骤,你可以使用 blind-watermark 库在图像中添加和提取盲水印。如果你遇到任何问题,请查阅 blind-watermark 的官方文档或 GitHub 仓库以获取更多信息和帮助。

相关推荐
__lost14 分钟前
Python图像变清晰与锐化,调整对比度,高斯滤波除躁,卷积锐化,中值滤波钝化,神经网络变清晰
python·opencv·计算机视觉
海绵波波10719 分钟前
玉米产量遥感估产系统的开发实践(持续迭代与更新)
python·flask
欣然~22 分钟前
借助 OpenCV 和 PyTorch 库,利用卷积神经网络提取图像边缘特征
人工智能·计算机视觉
漫谈网络32 分钟前
基于 Netmiko 的网络设备自动化操作
运维·自动化·netdevops·netmiko
豆豆1 小时前
day32 学习笔记
图像处理·笔记·opencv·学习·计算机视觉
逢生博客1 小时前
使用 Python 项目管理工具 uv 快速创建 MCP 服务(Cherry Studio、Trae 添加 MCP 服务)
python·sqlite·uv·deepseek·trae·cherry studio·mcp服务
堕落似梦1 小时前
Pydantic增强SQLALchemy序列化(FastAPI直接输出SQLALchemy查询集)
python
白熊1881 小时前
【计算机视觉】CV实战项目 - 基于YOLOv5的人脸检测与关键点定位系统深度解析
人工智能·yolo·计算机视觉
nenchoumi31191 小时前
VLA 论文精读(十六)FP3: A 3D Foundation Policy for Robotic Manipulation
论文阅读·人工智能·笔记·学习·vln
后端小肥肠1 小时前
文案号搞钱潜规则:日入四位数的Coze工作流我跑通了
人工智能·coze