OpenCV:如何在图像上绘制圆形轮廓

时间:2019-05-28 08:40:19

标签: python opencv image-processing video-processing

我已经编写了一个python函数,该函数应该在图像上绘制一个圆,该圆的中心点已使用鼠标回调来定义:

def draw_circle_contour(frame, pt, radius):
    cv2.circle(frame, center=pt, radius=3, color=(255,0,0), thickness=-1)
    discretized_circle_contour_x = [pt[0] + radius*np.cos(theta) for theta in np.linspace(0, 36, 36)]
    discretized_circle_contour_x = map(int, discretized_circle_contour_x)
    discretized_circle_contour_y = [pt[1] + radius*np.sin(theta) for theta in np.linspace(0, 36, 36)]
    discretized_circle_contour_y = map(int, discretized_circle_contour_y)
    discretized_circle_contour = zip(discretized_circle_contour_x, discretized_circle_contour_y)
    for el in discretized_circle_contour:
        cv2.circle(frame, center=el, radius=2, color=(255,0,0), thickness=-1)

现在,当我将theta指定在np.linspace(0,360,360)之内时,这将非常有效。但是,我现在只想绘制一个圆的1/10。即我想绘制一个圆形轮廓,其中被遮盖的角度为36°。我认为这段代码应该可以工作,但是由于某种原因,运行它时,结果看起来像这样:

myCircle

这是怎么回事?谁能告诉?

您已经指出:除了绘制小圆圈/点,我还可以使用cv2.polylines绘制圆线段。只需将最后两行替换为:

for el in discretized_circle_contour:
        help.append(list(el))
    cv2.polylines(frame, [np.asarray(help)], isClosed=False, color=(255,0,0), thickness=1) 

但是,我仍然面临着这个线段被绘制多次的问题,而我希望在[0,36]度之间仅绘制一次!

...,我只是找到了原因:角度theta必须以弧度而不是度为单位。哎呀

最终结果如下: polyline

1 个答案:

答案 0 :(得分:1)

正在发生的事情是,您在State changed的每个点上绘制了一个半径2(看起来像点,因为半径很小)的实心圆。

如果我正确理解了您的问题,那么您真正想要的只是一个跨越半径1/10的弧形。 您已经有了[0,36]度的拱形点,只需将其绘制为折线即可:

discretized_circle_contour