Отображение распознанных фигур с помощью Python opencv

Я все еще новичок в opencv, но я нашел фрагмент кода, который идентифицирует контуры фигур на изображении и указывает их центр. Единственная проблема заключается в том, что программа отображает один контур и один центр, и пользователь должен закрыть окно вручную поэтому отображается центр другой фигуры, наряду с первой.

Есть ли способ иметь одно окно, показывающее все контуры и центр фигур одновременно?

Это довольно проблематично для меня, потому что я планирую заменить изображение потоком камеры позже. Поэтому я буду признателен за любые дополнительные предложения по повышению эффективности этого кода.

Вот код (последние 2 строки являются подозреваемыми):

import argparse
import imutils
import cv2


image = cv2.imread("shapes3.png")
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
blurred = cv2.GaussianBlur(gray, (5, 5), 0)
thresh = cv2.threshold(blurred, 60, 255, cv2.THRESH_BINARY)[1]
# find contours in the thresholded image
cnts = cv2.findContours(thresh.copy(), cv2.RETR_TREE,
        cv2.CHAIN_APPROX_SIMPLE)
cnts = cnts[0] if imutils.is_cv2() else cnts[1]

# loop over the contours
for c in cnts:
        print("1")
        # compute the center of the contour
        M = cv2.moments(c)
        cX = int(M["m10"] / M["m00"])
        cY = int(M["m01"] / M["m00"])

        # draw the contour and center of the shape on the image
        cv2.drawContours(image, [c], -1, (0, 255, 0), 2)
        cv2.circle(image, (cX, cY), 7, (229, 83, 0), -1)
        cv2.putText(image, "center", (cX - 20, cY - 20),
                cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 59, 174), 2)

        # show the image
        cv2.imshow("Image", image) #displaying processed image
        cv2.waitKey(0)

Ссылка на источник

Пример изображения (переименуйте его в shape3.png)

1 ответ

Решение

Проблема была исправлена ​​путем отображения изображения после for цикл заканчивается

# loop over the contours
for c in cnts:
        print("1")
        # compute the center of the contour
        M = cv2.moments(c)
        cX = int(M["m10"] / M["m00"])
        cY = int(M["m01"] / M["m00"])

        # draw the contour and center of the shape on the image
        cv2.drawContours(image, [c], -1, (0, 255, 0), 2)
        cv2.circle(image, (cX, cY), 7, (229, 83, 0), -1)
        cv2.putText(image, "center", (cX - 20, cY - 20),
                cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 59, 174), 2)
# show the image
cv2.imshow("Image", image) #displaying processed image
cv2.waitKey(0)
Другие вопросы по тегам