Определите круг в изображении и получите 4 пикселя (точки) л в круговой периферии - PullRequest
0 голосов
/ 14 марта 2019

Мне нужно обработать изображения кружками, чтобы определить круги. Затем из внутреннего круга мне нужно 4 точки на периферии круга.

До сих пор я программировал этот код с помощью этого блога :

import numpy as np
import cv2
import argparse

def imageProcessing():
    ap=argparse.ArgumentParser()
    ap.add_argument("-i","--image",required=True,help="path to image")
    args=vars(ap.parse_args())

    # load the image, clone it for output, and then convert it to grayscale
    image = cv2.imread(args["image"])
    output = image.copy()
    gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

    # detect circles in the image
    circles = cv2.HoughCircles(gray,cv2.HOUGH_GRADIENT, 1.2, 100)

    # ensure at least some circles were found
    if circles is not None:
        # convert the (x, y) coordinates and radius of the circles to integers
        circles = np.round(circles[0, :]).astype("int")

        # loop over the (x, y) coordinates and radius of the circles
        for (x, y, r) in circles:
            # draw the circle in the output image, then draw a rectangle
            # corresponding to the center of the circle
            cv2.circle(output, (x, y), r, (0, 255, 0), 4)
            cv2.rectangle(output, (x - 5, y - 5), (x + 5, y + 5), (0, 128, 255), -1)

        # show the output image
        cv2.imshow("output", np.hstack([image, output]))
        cv2.waitKey(0)

if __name__=="__main__":
    imageProcessing()

Он может идентифицировать круг в простых изображениях, как показано ниже: enter image description here

Но не удалось определить круг на изображении ниже, который мне нужно обработать: enter image description here

Не могли бы вы указать на ошибки, которые я делаю? Почему программа не может определить круг?

Также укажи мне, как набрать 4 очка на внутреннем круге.

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