aidiary
4/9/2017 - 12:53 AM

ビット演算による画像の合成

ビット演算による画像の合成

import cv2
import numpy as np


img1 = cv2.imread('bird.jpg')
img2 = cv2.imread('opencv_logo.jpg')

# ロゴをimg1の左上に置きたいためROIを定義
rows, cols, channels = img2.shape
roi = img1[0:rows, 0:cols]

# マスクを作成
img2gray = cv2.cvtColor(img2, cv2.COLOR_BGR2GRAY)

# しきい値10より大きいピクセルは255でそれ以外は0はになる
ret, mask = cv2.threshold(img2gray, 10, 255, cv2.THRESH_BINARY)
# 白と黒をひっくり返す
# ロゴの色がついているところが黒(0)になる
mask_inv = cv2.bitwise_not(mask)

# ROIのロゴ部分を黒で塗りつぶす
img1_bg = cv2.bitwise_and(roi, roi, mask=mask_inv)

# ロゴの模様以外を塗りつぶす
img2_fg = cv2.bitwise_and(img2, img2, mask=mask)

# ROIの部分を合成
dst = cv2.add(img1_bg, img2_fg)

# 画像全体でROIを置き換え
img1[0:rows, 0:cols] = dst

cv2.imshow('result', img1)
cv2.waitKey(0)
cv2.destroyAllwindows()