圖像加法
您可以通過opencv函數 cv2.add() 或通過numpy操作 res = img1+img2 添加兩個圖像。兩個圖像的深度和類型應該相同,或者第二個圖像只能是一個標量值。
>>> x = np.uint8([250])
>>> y = np.uint8([10])
print(cv2.add(x,y)) # 250+10 = 260 => 255
# [[255]]
print(x+y) # 250+10 = 260 % 256 = 4
# [4]
opencv函數將提供更好的結果。所以最好還是使用opencv函數。
圖像融合
這也是圖像加法,但是圖像的權重不同,因此它會給人一種混合或透明的感覺。圖像按以下公式添加:
這里把兩張照片混合在一起。第一幅圖像的權重為0.7,第二幅圖像的權重為0.3。cv2.addWeighted() 在圖像上應用以下公式。
這里 取0。
img1 = cv2.imread('ml.png')
img2 = cv2.imread('opencv_logo.jpg')
dst = cv2.addWeighted(img1,0.7,img2,0.3,0)
cv2.imshow('dst',dst)
cv2.waitKey(0)
cv2.destroyAllWindows()
1.png
位運算
這包括按位的 AND、OR、NOT 和 XOR 操作。它們在提取圖像的任何部分、定義和使用非矩形ROI等時都非常有用。下面我們將看到一個關于如何更改圖像特定區域的示例。
我想把 opencv 標志放在圖片上方。如果我添加兩個圖像,它將改變顏色。如果我混合它,我會得到一個透明的效果。但我希望它是不透明的。如果是矩形區域,我可以像上一章那樣使用ROI。但是opencv標志不是矩形的。因此,您可以使用以下按位操作進行此操作:
import cv2
img1 = cv2.imread('google.png')
img2 = cv2.imread('deeplearning.png')
# I want to put logo on top-left corner, So I create a ROI
rows, cols, channels = img1.shape
roi = img2[0:rows, 0:cols]
# Now create a mask of logo and create its inverse mask also
img1gray = cv2.cvtColor(img1, cv2.COLOR_BGR2GRAY)
ret, mask = cv2.threshold(img1gray, 200, 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)
# Take only region of logo from logo image.
img2_fg = cv2.bitwise_and(img1, img1, mask=mask_inv)
# Put logo in ROI and modify the main image
dst = cv2.add(img1_bg, img2_fg)
img1[0:rows, 0:cols] = dst
cv2.imshow('mask', mask)
cv2.imshow('mask_inv', mask_inv)
cv2.imshow('roi', roi)
cv2.imshow('img1_bg', img1_bg)
cv2.imshow('img1', img1)
cv2.imshow('img2_fg', img2_fg)
cv2.imshow('dst', dst)
cv2.waitKey(0)
cv2.destroyAllWindows()
把google logo 圖片除了google這幾個字以外的像素都變為0;把deep learning圖片需要嵌入google logo圖片的位置上的像素都變為0;那么最后把兩張圖片像素相加的時候,除了google這幾個字,其他的像素值都是deep learning的像素。
2.png