0

我得到了源图像的轮廓。我画了 4 条线来近似这些轮廓:

  1. 从轮廓的最小宽度到最小高度。
  2. 从轮廓的最小宽度到最大高度。
  3. 从轮廓的最大宽度到最小高度。
  4. 从轮廓的最大宽度到最大高度。

我想旋转这个矩形,使其与宽度对齐(即图像的 x 坐标)。

4

1 回答 1

0

这可能会帮助你

rect = cv2.minAreaRect(yourcontour)
angle = rect[2]

if angle < -45:
    angle = (90 + angle)

# otherwise, just take the inverse of the angle to make
# it positive
else:
    angle = -angle  

# rotate the image to deskew it
(h, w) = img.shape[:2]
center = (w // 2, h // 2)
M = cv2.getRotationMatrix2D(center, angle, 1.0)
rotated = cv2.warpAffine(img, M, (w, h),
    flags=cv2.INTER_CUBIC, borderMode=cv2.BORDER_REPLICATE) 
于 2018-09-29T01:48:36.550 回答