opencv外接最小面积长方形

该函数仅对轮廓有效

cnt = get_region(cnt)
contours, hierarchy = cv2.findContours(cnt, cv2.RETR_TREE, cv2.CHAIN_APPROX_NONE)
boundRect=cv2.minAreaRect(contours[0]) ## 得到最小外接矩形的(中心(x,y), (宽,高), 旋转角度)
# 获取矩形四个顶点,浮点型
box = cv2.boxPoints(boundRect)
# 取整
box = np.int0(box)
# 画出该轮廓的外接矩阵
temp_mask =cnt.copy()
temp_mask = cv2.drawContours(temp_mask, [box], 0, 3, 2)
plt.imshow(temp_mask)
plt.show()

opencv外接最小面积长方形_第1张图片

 

注意:

旋转角度θ是水平轴(x轴)逆时针旋转,直到碰到矩形的第一条边停住,此时该边与水平轴的夹角。并且这个边的边长是width,另一条边边长是height。也就是说,在这里,width与height不是按照长短来定义的。

cv2.drawContours第三个参数指定绘制轮廓list中的哪条轮廓,如果是-1,则绘制其中的所有轮廓。
在opencv中,坐标系原点在左上角,相对于x轴,逆时针旋转角度为负,顺时针旋转角度为正。所以,θ∈(-90度,0]。

你可能感兴趣的:(空间艺术Raumkunst,opencv,计算机视觉)