Как мне заставить работать этот детектор цветов openCV? - PullRequest
0 голосов
/ 20 апреля 2020

Я создал простую программу, использующую openCV для распознавания цветов в тексте. Код работает нормально, но не допускает прямоугольник с деталями цвета. Я думаю, что проблема в одной из функций.

Вот мой код:

# Imports
import pandas as pd
import cv2
import argparse
import xlrd

clicked = False


ap = argparse.ArgumentParser()
args = vars(ap.parse_args())
img_path = "file path"
# Reading image with opencv
img = cv2.imread(img_path)
index = ["color", "color_name", "hex", "R", "G", "B"]
csv = pd.read_excel('file path', names=index, header=None)


def draw_function(event, x, y, flags, param):
    if event == cv2.EVENT_RBUTTONDBLCLK:
        global b, g, r, xpos, ypos, clicked
        clicked = True
        xpos = x
        ypos = y
        b, g, r = img[y, x]
        b = int(b)
        g = int(g)
        r = int(r)


cv2.setMouseCallback('image', draw_function)


def getColorName(R, G, B):
    minimum = 10000
    for i in range(len(csv)):
        d = abs(R - int(csv.loc[i, "R"])) + abs(G - int(csv.loc[i, "G"])) + abs(B - int(csv.loc[i, "B"]))
        if d <= minimum:
            minimum = d
            cname = csv.loc[i, "color_name"]
    return cname


while 1:
    if clicked:
        cv2.rectangle(img, (20, 20), (750, 60), (b, g, r), -1)
        text = getColorName(r, g, b) + ' R=' + str(r) + ' G=' + str(g) + ' B=' + str(b)
        cv2.putText(img, text, (50, 50), 2, 0.8, (255, 255, 255), 2, cv2.LINE_AA)
        if r + g + b >= 600:
            cv2.putText(img, text, (50, 50), 2, 0.8, (0, 0, 0), 2, cv2.LINE_AA)
        clicked = False
    cv2.imshow('Color Detector', img)
    if cv2.waitKey(20) & 0xFF == 27:
        break
cv2.destroyAllWindows()

Может кто-нибудь сказать мне, где я допустил ошибку?

Спасибо,
-Ме

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...