-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcreatingDataset.py
96 lines (87 loc) · 2.92 KB
/
creatingDataset.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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
import cv2
import numpy as np
int(input("Enter Camera Index : "))
cap=cv2.VideoCapture(cam)
i=6
j=1
name=""
def dodgeV2(image, mask):
return cv2.divide(image, 255-mask, scale=256)
def nothing(x) :
pass
#Get the biggest Controur
def getMaxContour(contours,minArea=200):
maxC=None
maxArea=minArea
for cnt in contours:
area=cv2.contourArea(cnt)
if(area>maxArea):
maxArea=area
maxC=cnt
return maxC
# cv2.namedWindow('trackbar')
# cv2.createTrackbar('Y_min','trackbar',0,255,nothing)
# cv2.createTrackbar('Y_max','trackbar',0,255,nothing)
# cv2.createTrackbar('Cr_min','trackbar',0,255,nothing)
# cv2.createTrackbar('Cr_max','trackbar',0,255,nothing)
# cv2.createTrackbar('Cb_min','trackbar',0,255,nothing)
# cv2.createTrackbar('Cb_max','trackbar',0,255,nothing)
while(cap.isOpened()):
# Y_min = cv2.getTrackbarPos('Y_min','trackbar')
# Y_max = cv2.getTrackbarPos('Y_max','trackbar')
# Cr_min = cv2.getTrackbarPos('Cr_min','trackbar')
# Cr_max = cv2.getTrackbarPos('Cr_max','trackbar')
# Cb_min = cv2.getTrackbarPos('Cb_min','trackbar')
# Cb_max = cv2.getTrackbarPos('Cb_max','trackbar')
_,img=cap.read()
img = cv2.flip(img,1)
cv2.rectangle(img,(450,100),(640,350),(255,0,0),2)
img1=img[100:350,450:640]
img_ycrcb = cv2.cvtColor(img1, cv2.COLOR_BGR2YCR_CB)
blur = cv2.GaussianBlur(img_ycrcb,(11,11),0)
# skin_ycrcb_min = np.array((Y_min,Cr_min,Cb_min))
# skin_ycrcb_max = np.array((Y_max,Cr_max,Cb_max))
skin_ycrcb_min = np.array((0, 138, 67))
skin_ycrcb_max = np.array((255, 173, 133))
mask = cv2.inRange(blur, skin_ycrcb_min, skin_ycrcb_max)
#gray=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
#ret,mask = cv2.threshold(gray.copy(),20,255,cv2.THRESH_BINARY)
contours,hierarchy = cv2.findContours(mask.copy(),cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)
cnt=getMaxContour(contours,4000)
try:
if cnt!=None:
x,y,w,h = cv2.boundingRect(cnt)
img_gray = cv2.cvtColor(img1[y:y+h,x:x+w], cv2.COLOR_BGR2GRAY)
img_gray_inv = 255 - img_gray
img_blur = cv2.GaussianBlur(img_gray_inv, ksize=(21, 21),sigmaX=0, sigmaY=0)
imgT = dodgeV2(img_gray, img_blur)
imgT=cv2.bitwise_and(imgT,imgT,mask=mask[y:y+h,x:x+w])
imgT=cv2.resize(imgT,(200,200))
cv2.imshow('Trainer',imgT)
except:
if cnt.any()!=None:
x,y,w,h = cv2.boundingRect(cnt)
img_gray = cv2.cvtColor(img1[y:y+h,x:x+w], cv2.COLOR_BGR2GRAY)
img_gray_inv = 255 - img_gray
img_blur = cv2.GaussianBlur(img_gray_inv, ksize=(21, 21),sigmaX=0, sigmaY=0)
imgT = dodgeV2(img_gray, img_blur)
imgT=cv2.bitwise_and(imgT,imgT,mask=mask[y:y+h,x:x+w])
imgT=cv2.resize(imgT,(200,200))
cv2.imshow('Trainer',imgT)
cv2.imshow('Frame',img)
cv2.imshow('Thresh',mask)
k = 0xFF & cv2.waitKey(10)
if k == 27:
break
if k == 13:
name=str(chr(i+64))+"_"+str(j)+".jpg"
cv2.imwrite(name,imgT)
if(j<400):
j+=1
else:
while(0xFF & cv2.waitKey(0)!=ord('n')):
j=201
j=1
i+=1
cap.release()
cv2.destroyAllWindows()