forked from avinashkranjan/Amazing-Python-Scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathColor_detection.py
75 lines (55 loc) · 2.15 KB
/
Color_detection.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
import pandas as pd
import cv2
img_path = './Color_detection/colorpic.jpg'
csv_path = './Color_detection/colors.csv'
# Reading csv file with pandas and giving names to each column
index = ['color', 'color_name', 'hex', 'R', 'G', 'B']
df = pd.read_csv(csv_path, names=index, header=None)
# Reading the image with opencv
img = cv2.imread(img_path)
img = cv2.resize(img, (800, 600))
# declaring global variables
clicked = False
r = g = b = xpos = ypos = 0
# function to calculate minimum distance from all colors and get the most matching color
def get_color_name(R, G, B):
minimum = 10000
for i in range(len(df)):
d = abs(R - int(df.loc[i, 'R'])) + abs(G -
int(df.loc[i, 'G'])) + abs(B - int(df.loc[i, 'B']))
if d <= minimum:
minimum = d
cname = df.loc[i, 'color_name']
return cname
# function to get x,y coordinates of mouse double click
def draw_function(event, x, y, flags, param):
if event == cv2.EVENT_LBUTTONDBLCLK:
global clicked, r, g, b, xpos, ypos
clicked = True
xpos = x
ypos = y
b, g, r = img[y, x]
b = int(b)
g = int(g)
r = int(r)
cv2.namedWindow('image')
cv2.setMouseCallback('image', draw_function)
while True:
cv2.imshow('image', img)
if clicked:
# cv2.rectangle(image, startpoint, endpoint, color, thickness)-1 fills entire rectangle
cv2.rectangle(img, (20, 20), (600, 60), (b, g, r), -1)
# Creating text string to display( Color name and RGB values )
text = get_color_name(r, g, b) + ' R=' + str(r) + \
'G=' + str(g) + ' B=' + str(b)
# cv2.putText(img,text,start,font(0-7),fontScale,color,thickness,lineType )
cv2.putText(img, text, (50, 50), 2, 0.8,
(255, 255, 255), 2, cv2.LINE_AA)
# For very light colours we will display text in black colour
if (r + g + b >= 600):
cv2.putText(img, text, (50, 50), 2, 0.8, (0, 0, 0), 2, cv2.LINE_AA)
clicked = False
# Break the loop when user hits 'esc' key
if cv2.waitKey(20) & 0xFF == 27:
break
cv2.destroyAllWindows()