48

おそらくcv2.minAreaRect()によって返される回転した長方形を描画するヘルパーメソッドはあります((x1,y1),(x2,y2),angle)か? cv2.rectangle()は角度をサポートしていません。また、返されたタプルは「RotatedRect」クラスのものではないため (Python バインディングで実装されていないように見えるため) points()、C++ チュートリアル「等高線用の境界を回転させたボックスと楕円を作成する¶」に示されているように、メソッドはありません。

中心点または指定された最初の点を中心に回転させて、回転した長方形を線からどのように描画できますか?

4

5 に答える 5

77
rect = cv2.minAreaRect(cnt)
box = cv2.cv.BoxPoints(rect) # cv2.boxPoints(rect) for OpenCV 3.x
box = np.int0(box)
cv2.drawContours(im,[box],0,(0,0,255),2)

トリックを行う必要があります。

ソース:

1) http://opencvpython.blogspot.in/2012/06/contours-2-brotherhood.html

2) Python OpenCV Box2D

于 2013-08-13T11:35:25.443 に答える
6

回転した四角形を描画する具体的な例を次に示します。アイデアは、 Otsu のしきい値を使用してバイナリ イメージを取得し、を使用して輪郭を見つけることcv2.findContours()です。を使用して回転した長方形を取得し、 を使用cv2.minAreaRect()して 4 つの角の頂点を取得できcv2.boxPoints()ます。cv2.drawContours()またはを使用して長方形を描画しますcv2.polylines()


入力->出力

コード

import cv2
import numpy as np

# Load image, convert to grayscale, Otsu's threshold for binary image
image = cv2.imread('1.jpg')
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
thresh = cv2.threshold(gray, 0, 255, cv2.THRESH_BINARY_INV + cv2.THRESH_OTSU)[1]

# Find contours, find rotated rectangle, obtain four verticies, and draw 
cnts = cv2.findContours(thresh, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
cnts = cnts[0] if len(cnts) == 2 else cnts[1]
rect = cv2.minAreaRect(cnts[0])
box = np.int0(cv2.boxPoints(rect))
cv2.drawContours(image, [box], 0, (36,255,12), 3) # OR
# cv2.polylines(image, [box], True, (36,255,12), 3)

cv2.imshow('image', image)
cv2.waitKey()
于 2020-01-29T03:19:41.920 に答える