Ниже приведена моя программа, я пытаюсь найти выпуклую оболочку изображения и снова отправить эти выпуклые точки корпуса в OpenCV Convex Hull, чтобы найти ее внешнюю выпуклую оболочку.
import cv2
import numpy as np
# Load the image
img1 = cv2.imread(r'test.tif')
# Convert it to greyscale
img = cv2.cvtColor(img1, cv2.COLOR_BGR2GRAY)
# Threshold the image
ret, thresh = cv2.threshold(img,50,255,0)
# Find the contours
contours, hierarchy = cv2.findContours(thresh, cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)
cv2.drawContours(img1, contours, -1, (255, 0, 0), 2)
hull=np.array([])
for i in range(len(contours)):
hullv=cv2.convexHull(contours[i])
hull=np.append(hull,hullv)
cv2.drawContours(img1, [hullv], 0, (255, 0, 0), 2)
conv2=cv2.convexHull(hull)
cv2.drawContours(img1, conv2, -1, (255, 0, 0), 2)
cv2.imwrite(r"contours2.png",img1)
Я вижу ниже ошибку, когда я делаю это.
Traceback (most recent call last):
File "C:/TestCode/DocumentLayoutDetection/ConvexHull.py", line 17, in <module>
conv2=cv2.convexHull(hull)
cv2.error: OpenCV(4.2.0) C:\projects\opencv-python\opencv\modules\imgproc\src\convhull.cpp:137: error: (-215:Assertion failed) total >= 0 && (depth == CV_32F || depth == CV_32S) in function 'cv::convexHull'
входное изображение
Выходное изображение