forked from niconielsen32/ComputerVision
-
Notifications
You must be signed in to change notification settings - Fork 0
/
backgroundSub2.py
78 lines (55 loc) · 1.98 KB
/
backgroundSub2.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
import cv2 as cv
import numpy as np
import sys
def resize(dst,img):
width = img.shape[1]
height = img.shape[0]
dim = (width, height)
resized = cv.resize(dst, dim, interpolation = cv.INTER_AREA)
return resized
video = cv.VideoCapture(0, cv.CAP_DSHOW)
oceanVideo = cv.VideoCapture("ocean.mp4")
takeBgImage = 0
ret, bgReference = video.read()
while True:
ret, img = video.read()
ret2, bg = oceanVideo.read()
if bg is not None:
bg = resize(bg,bgReference)
if takeBgImage == 0:
bgReference = img
# Create a mask
diff1=cv.subtract(img, bgReference)
diff2=cv.subtract(bgReference, img)
diff = diff1 + diff2
diff[abs(diff) < 25.0] = 0
cv.imshow("diff1", diff)
gray = cv.cvtColor(diff, cv.COLOR_BGR2GRAY)
gray[np.abs(gray) < 10] = 0
fgMask = gray
# Opening to reduce noise
kernel = np.ones((3,3), np.uint8)
fgMask = cv.erode(fgMask, kernel, iterations=2)
fgMask = cv.dilate(fgMask, kernel, iterations=2)
fgMask[fgMask>5]=255
cv.imshow("Foreground Mask", fgMask)
# Inverting the mask
fgMask_inv = cv.bitwise_not(fgMask)
# Get relevant information from fore- and background with the masks
fgImage = cv.bitwise_and(img, img, mask=fgMask)
bgImage = cv.bitwise_and(bg, bg, mask=fgMask_inv)
# Combine the fore- and background images
bgSub = cv.add(bgImage,fgImage)
cv.imshow('Background Removed', bgSub)
cv.imshow('Original', img)
key = cv.waitKey(5) & 0xFF
if ord('q') == key:
break
elif ord('e') == key:
takeBgImage = 1
print("Background Captured")
elif ord('r') == key:
takeBgImage = 0
print("Ready to Capture new Background")
cv.destroyAllWindows()
video.release()