gpt4 book ai didi

python - 如何在 opencv 的 bitwise_operation 中应用掩码?

转载 作者:太空宇宙 更新时间:2023-11-03 22:37:15 24 4
gpt4 key购买 nike

我正在查看 OpenCV 的文档,发现了一些我无法理解的内容。我试图在网上找到它,但找不到任何令人满意的东西。你能帮我写一行代码吗?这是代码:

# Load two images
img1 = cv.imread('messi5.jpg')
img2 = cv.imread('opencv-logo-white.png')
# I want to put logo on top-left corner, So I create a 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 = cv.cvtColor(img2,cv.COLOR_BGR2GRAY)
ret, mask = cv.threshold(img2gray, 10, 255, cv.THRESH_BINARY)
mask_inv = cv.bitwise_not(mask)
# Now black-out the area of logo in ROI
img1_bg = cv.bitwise_and(roi,roi,mask = mask_inv)
# Take only region of logo from logo image.
img2_fg = cv.bitwise_and(img2,img2,mask = mask)
# Put logo in ROI and modify the main image
dst = cv.add(img1_bg,img2_fg)
img1[0:rows, 0:cols ] = dst
cv.imshow('res',img1)
cv.waitKey(0)
cv.destroyAllWindows()

我其实不明白的是这两行

img1_bg = cv.bitwise_and(roi,roi,mask = mask_inv)

img2_fg = cv.bitwise_and(img2,img2,mask = mask)

这些行实际上做了什么以及如何应用掩码?

如果有人能解释在 bitwise_and 操作中应用的掩码,那将非常有帮助。谢谢

最佳答案

如果您查看 tutorial .

掩码是 OpenCV Logo 的黑白图像,它是通过对 OpenCV Logo 应用阈值创建的。

bitwise_and 操作是一个 logical and operation

在这种情况下,它采用两个 8 位数字表示一个像素并对这些数字应用与操作。

Documentation描述此函数的作用。

由于前两个参数相同(roiimg2),如果不使用 mask ,结果将是相同的图像。蒙版为黑色的地方与目标图像保持相同。

在这种情况下,没有提供目标图像,因此 OpenCV 为函数中使用的目标图像分配黑色图像(零)(当函数未提供 Matrix 时,这通常是 OpenCV 的工作方式)。

具体来说,img1_bg = cv.bitwise_and(roi,roi,mask = mask_inv) 将创建一个在函数中使用的黑色矩阵,该矩阵稍后成为输出 img1_bg。只有与 mask_inv 中的白色像素匹配的黑色图像部分才会填充来自 roi 的像素。这意味着在 mask_inv 中有白色像素。 roi值会被复制到函数生成的纯黑图像中相应坐标下。

类似地,img2_fg = cv.bitwise_and(img2,img2,mask = mask) 将创建一个在函数中使用的黑色矩阵,该矩阵随后成为输出 img2_fg。此黑色图像中只有与 mask 中的白色像素匹配的部分才会填充来自 img2 的像素。

这样一来,当您添加 img1_bgimg2_fg 时,结果只是每个图像中被屏蔽的部分。

就我个人而言,我认为这是对 bitwise_and 的一种混淆使用。我认为为了演示 bitwise_and 的功能,移除 mask 参数会更清楚,如下所示:img1_bg = cv.bitwise_and(roi, mask_inv)。这将给出相同的结果,掩码为黑色的地方为零,而 ROI 值不是黑色,因为掩码的像素全为 1 或全为 0。

如果您不想演示bitwise_and 的用法,我认为在python 中使用逻辑索引会更清楚,如下所示:

output = np.zeros(img1.shape, np.uint8)
output[mask_inv] = img1_bg[mask_inv]
output[mask] = img2_fg[mask]

关于python - 如何在 opencv 的 bitwise_operation 中应用掩码?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57034030/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com