Ошибка подтверждения ошибки контура чертежа OpenCV

Поэтому я стараюсь следовать руководству по сканированию документа в https://www.pyimagesearch.com/2014/09/01/build-kick-ass-mobile-document-scanner-just-5-minutes/ именно на На шаге 2, где я должен найти контур и нарисовать его на изображении, я получил ошибку "Ошибка утверждения" в функции drawContour

Гид не имел

screenCnt = Нет

так что сначала я получил ошибку, как screenCnt не существует

после того, как я его добавил, вместо этого получил Assertion Failed, хотя я использовал то же изображение, что и руководство, и попробовал другое изображение

#find contour
cnts = cv2.findContours(edged.copy(), cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)
cnts = imutils.grab_contours(cnts)
cnts = cnts[0] if imutils.is_cv2() else cnts[1]
cnts = sorted(cnts, key=cv2.contourArea, reverse=True)[:5]
screenCnt = None

# loop over the contours
for c in cnts:
    peri = cv2.arcLength(c, True)
    approx = cv2.approxPolyDP(c, 0.02 * peri, True)
    if len(approx) == 4:
        screenCnt = approx
        break

#draw contour
cv2.drawContours(image, [screenCnt], -1, (0, 255, 0), 2)

Вот что я получил:

Трассировка (последний вызов был последним): файл "C:/Users/User/PycharmProjects/learn/project/app.py", строка 218, в cv2.drawContours(изображение, [screenCnt], -1, (0, 255, 0), 2)

cv2.error: OpenCV (4.1.0) C: \ projects \ opencv-python \ opencv \ modules \ imgproc \ src \ drawing.cpp: 2606: ошибка: (-215: утверждение не выполнено) reader.ptr!= NULL в функции 'cvDrawContours'

Любое решение для этого? Спасибо, прежде чем

2 ответа

Решение

Попробуйте заменить screenCnt = 0 вместо None. и дай мне знать. Для справки, я предоставляю небольшой фрагмент кода.

(cnts, contours, heirarchy) = cv2.findContours (edged.copy (), cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)

cnts = contours [0] screenCnt = 0

для контура в контурах: # получить прямоугольник, ограничивающий контур [x,y,w,h] = cv2.boundingRect(контур)

# draw rectangle around contour on original image
#cv2.rectangle(image,(x,y),(x+w,y+h),(255,0,255),2)

##### code added..for thresholding
for c in cnts:
    # approximate the contour
    peri = cv2.arcLength(c, True)
    approx = cv2.approxPolyDP(c, 0.02 * peri, True)

# if our approximated contour has four points, then
# we can assume that we have found our screen
if len(approx) == 4:
    screenCnt = approx
    break

Попробуйте распечатать все входные данные для функции, которую вы предоставляете. Я думаю, вы можете найти что-то не так. Позвольте мне знать в комментариях ниже.

Другие вопросы по тегам