Моменты помогают в обнаружении Python OpenCV - PullRequest
2 голосов
/ 06 апреля 2019

Моменты проходят по каждому контуру, но каждый раз, когда круг не может быть в предсказанном месте, которое является центром прямоугольника;место постоянно каждый раз, когда (0,0) не центр, который я хочу

это результат белый круг в (0,0)

# -*- coding: utf-8 -*-
"""
Created on Sat Apr  6 09:53:56 2019

@author: lenovo
"""

import cv2
import numpy as np
import time

lowerBound=np.array([85,153,50])
upperBound=np.array([255,255,255])
cam= cv2.VideoCapture(1)

kernelOpen=np.ones((5,5))
kernelClose=np.ones((20,20))

font = cv2.FONT_HERSHEY_SIMPLEX
while True:
    ret, img=cam.read()
    img=cv2.resize(img,(340,220))

    #convert BGR to HSV
    imgHSV= cv2.cvtColor(img,cv2.COLOR_BGR2HSV)
    # create the Mask
    mask=cv2.inRange(imgHSV,lowerBound,upperBound)
    #morphology
    maskOpen=cv2.morphologyEx(mask,cv2.MORPH_OPEN,kernelOpen)
    maskClose=cv2.morphologyEx(maskOpen,cv2.MORPH_CLOSE,kernelClose)

    maskFinal=maskClose
    _,conts,h=cv2.findContours(maskFinal.copy(),cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_NONE)

    cv2.drawContours(img,conts,-1,(255,0,0),3)

    for i in range(len(conts)):
        M = cv2.moments(i)
        x,y,w,h=cv2.boundingRect(conts[i])
        if M["m00"] != 0:

            cX = int(M["m10"] / M["m00"])
            cY = int(M["m01"] / M["m00"])
        else:

    # set values as what you need in the situation
            cX, cY = 0, 0
        cv2.rectangle(img,(x,y),(x+w,y+h),(0,0,255), 2)
        cv2.circle(img, (cX, cY), 5, (255, 255, 255), -1)
        cv2.putText(img, str(i+1),(x,y+h),cv2.FONT_HERSHEY_SIMPLEX,1.0,(0,255,255))


    cv2.imshow("maskClose",maskClose)
    cv2.imshow("maskOpen",maskOpen)
    cv2.imshow("mask",mask)
    cv2.imshow("cam",img)
    cv2.waitKey(10)

1 Ответ

0 голосов
/ 07 апреля 2019

M = cv2.moments(i) должно быть M = cv2.moments(conts[i]), в данный момент вы вводите индекс, а не контур.

То, что вы рассчитываете, это центр тяжести контура, который может отличаться от центра ограничивающего направления,Пример:
enter image description here

Если вы хотите, чтобы окружность находилась в центре вашего ограничивающего направления, вы должны использовать размеры x, y, w, h для ее вычисления:

cX = x + int(w/2)
cY = y + int(h/2)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...