前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >图像处理: 设计 自定义透明度 水印

图像处理: 设计 自定义透明度 水印

作者头像
JNingWei
发布2018-09-28 14:47:28
1K0
发布2018-09-28 14:47:28
举报
文章被收录于专栏:JNing的专栏JNing的专栏

效果图

未加水印前:

这里写图片描述
这里写图片描述

水印掩码:

这里写图片描述
这里写图片描述

透明度为 0.3 的水印图片:

这里写图片描述
这里写图片描述

透明度为 1.0 的水印图片:

这里写图片描述
这里写图片描述

实现代码

感觉我自己写的这段代码,效果比opencv官网上给出的例子效果要好,水印中不会夹带黑色噪点。

代码语言:javascript
复制
# coding=utf-8
import cv2
import numpy as np

bottom = cv2.imread('elegent.jpg')
mark = cv2.imread('mask.jpg')

# 加水印
def waterMark(src, mask, transparency):
    # 对掩码:转为float型 --> 乘上透明度 --> 地板整数 --> 回到uint8型
    mask = np.floor(mask.astype(np.float32) * transparency).astype(np.uint8)
    dst = cv2.add(src, mask)
    # 防止溢出像素值域
    dst = dst*(dst<=255) + 255*(dst>255)
    # 回到uint8型
    dst = dst.astype(np.uint8)
    return dst

b_rows, b_cols, b_channels = bottom.shape
m_rows, m_cols, m_channels = mark.shape
# 将图片右下角矩形块 替换为 加过水印的矩形块
bottom[b_rows-m_rows:b_rows, b_cols-m_cols:b_cols, ] = waterMark(bottom[b_rows-m_rows:b_rows, b_cols-m_cols:b_cols, ], mark, 0.3)

# 保存水印图片
cv2.imwrite('waterMark.jpg', bottom)

cv2.imshow('waterMark', bottom)
cv2.waitKey(3000)
cv2.destroyAllWindows()

对比

OpenCV官网上的类似例程

这里写图片描述
这里写图片描述

具体代码:

代码语言:javascript
复制
# coding=utf-8
import cv2

img1 = cv2.imread('elegent.jpg')
img2 = cv2.imread('mask.jpg')

b_rows, b_cols, b_channels = img1.shape
m_rows, m_cols, m_channels = img2.shape

# I want to put logo on top-left corner, So I create a ROI
rows,cols,channels = img2.shape
roi = img1[b_rows-m_rows:b_rows, b_cols-m_cols:b_cols, ]
# Now create a mask of logo and create its inverse mask also
img2gray = cv2.cvtColor(img2,cv2.COLOR_BGR2GRAY)
ret, mask = cv2.threshold(img2gray, 10, 255, cv2.THRESH_BINARY)
mask_inv = cv2.bitwise_not(mask)
# Now black-out the area of logo in ROI
img1_bg = cv2.bitwise_and(roi,roi,mask = mask_inv)
# Take only region of logo from logo image.
img2_fg = cv2.bitwise_and(img2,img2,mask = mask)
# Put logo in ROI and modify the main image
dst = cv2.add(img1_bg,img2_fg)
# img1[0:rows, 0:cols ] = dst

# 将图片右下角矩形块 替换为 加过水印的矩形块
img1[b_rows-m_rows:b_rows, b_cols-m_cols:b_cols, ] = dst
cv2.imwrite('res.jpg', img1)
cv2.imshow('res',img1)
cv2.waitKey(0)
cv2.destroyAllWindows()

该例程的实现效果:

这里写图片描述
这里写图片描述

劣势:

由细节放大图可看出,opencv官网例程的效果不佳,不仅 不能自定义 水印透明度,而且水印中还会 夹带黑色噪点,有损美观:

这里写图片描述
这里写图片描述
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017年10月15日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 效果图
  • 实现代码
  • 对比
    • 该例程的实现效果:
      • 劣势:
      相关产品与服务
      图像处理
      图像处理基于腾讯云深度学习等人工智能技术,提供综合性的图像优化处理服务,包括图像质量评估、图像清晰度增强、图像智能裁剪等。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档