掩模运算3x16C语言,python opencv图像叠加/图像融合/mask掩模

目录

1、图像叠加

2、图像融合

3、图像mask掩模(包括按位AND,OR,NOT和XOR运算)

1、图像叠加

可以通过OpenCV函数cv.add()或简单地通过numpy操作添加两个图像,res = img1 + img2.两个图像应该具有相同的深度和类型,或者第二个图像可以是标量值.

import cv2

import numpy as np

img1 = cv2.imread('4.jpg')

img2 = cv2.imread('1.jpg')

imgadd = cv2.add(cv2.resize(img1,(200,200)),cv2.resize(img2,(200,200)))

cv2.imshow('imgadd',imgadd)

cv2.waitKey(0)

叠加结果:如果叠加两个图像,它将改变颜色

09382eaeefc784cd90625ea8516d66b1.pngb35a2e67c98be61c9629f2d2daa3fd0f.pngb3533862dff8c511207c51a99c4b39a1.png

2、图像融合

图像加法,但是对图像赋予不同的权重(0到1之间),使得它具有混合感或透明感。

# 图像融合

combine = cv2.addWeighted(cv2.resize(img1,(200,200)),0.5,cv2.resize(img2,(200,200)),0.5,0)

cv2.imshow('combine',combine)

cv2.waitKey(0)

结果:如果融合两个图像,会得到一个透明的效果.

0364cec1efbf1ad3f685db73e3e9e877.png

3、图像mask掩模(包括按位AND,OR,NOT和XOR运算)

.

目的:希望将opencv徽标放在图像上方

如果叠加两个图像,它将改变颜色

如果融合两个图像,会得到一个透明的效果. 我希望它不透明

如果它是一个矩形区域,我可以使用ROI按之前描述的操作

但是opencv徽标并不是矩形,可以按位操作完成相关功能

img2 = cv2.resize(img2,(100,100))

# I want to put logo on top-left corner, So I create a ROI

#首先获取原始图像roi

rows,cols,channels = img2.shape

roi = img1[0:rows, 0:cols ]

#原始图像转化为灰度值

# Now create a mask of logo and create its inverse mask also

img2gray = cv2.cvtColor(img2,cv2.COLOR_BGR2GRAY)

cv2.imshow('img2gray',img2gray)

cv2.waitKey(0)

'''

将一个灰色的图片,变成要么是白色要么就是黑色。(大于规定thresh值就是设置的最大值(常为255,也就是白色))

'''

#将灰度值二值化,得到ROI区域掩模

ret, mask = cv2.threshold(img2gray, 200, 255, cv2.THRESH_BINARY)

cv2.imshow('mask',mask)

cv2.waitKey(0)

#ROI掩模区域反向掩模

mask_inv = cv2.bitwise_not(mask)

cv2.imshow('mask_inv',mask_inv)

cv2.waitKey(0)

#掩模显示背景

# Now black-out the area of logo in ROI

img1_bg = cv2.bitwise_and(roi,roi,mask = mask)

cv2.imshow('img1_bg',img1_bg)

cv2.waitKey(0)

#掩模显示前景

# Take only region of logo from logo image.

img2_fg = cv2.bitwise_and(img2,img2,mask = mask_inv)

cv2.imshow('img2_fg',img2_fg)

cv2.waitKey(0)

#前背景图像叠加

# Put logo in ROI and modify the main image

dst = cv2.add(img1_bg,img2_fg)

img1[0:rows, 0:cols ] = dst

cv2.imshow('res',img1)

cv2.waitKey(0)

cv2.destroyAllWindows()

img1[0:rows, 0:cols ] = dst

cv2.imshow('res',img1)

cv2.waitKey(0)

cv2.destroyAllWindows()

结果:

灰度图

b085d15ad01bb8273ac0321357e3e416.png

二值化掩模             二值化掩模取反     ROI背景提取        ROI前景提取          ROI前背景融合

2576ec424f3b098a5336ffa4b9244264.png98acf9a8900adc38ea47bcbf74da8ed8.png78f410f235418b95e7b795439943e7d8.png67813d878339bf8806b270b8be8a0bc3.png7ca06eacd16be9abc81f4bb044e685b4.png

最终融合:

89d9bdde5674c822d1c506082732d190.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值