0

杂货账单:

杂货账单

由于图像的顶部和底部的某些部分缺少最大轮廓,即无法裁剪主钞票。该代码在完整的账单图像的情况下运行良好,但无法处理丢失的顶点图像。

代码:

imgContours = img.copy() # COPY ORIGNAL IMAGE
imgBigContour = img.copy() # COPY ORIGNAL IMAGE
_, contours,_ = cv2.findContours(imgThreshold, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) # FIND ALL CONTOURS
cv2.drawContours(imgContours, contours, -1, (0, 255, 0), 10) # DRAW ALL DETECTED CONTOURS

# FIND THE BIGGEST COUNTOUR
biggest, maxArea = utlis.biggestContour(contours) # FIND THE BIGGEST CONTOUR
if biggest.size != 0:
    biggest=utlis.reorder(biggest)
    cv2.drawContours(imgBigContour, biggest, -1, (0, 255, 0), 20) # DRAW THE BIGGEST CONTOUR
    imgBigContour = utlis.drawRectangle(imgBigContour,biggest,2)
    pts1 = np.float32(biggest) # PREPARE POINTS FOR WARP
    pts2 = np.float32([[0, 0],[widthImg, 0], [0, heightImg],[widthImg, heightImg]]) # PREPARE POINTS FOR WARP
    matrix = cv2.getPerspectiveTransform(pts1, pts2)
    imgWarpColored = cv2.warpPerspective(img, matrix, (widthImg, heightImg))
4

1 回答 1

0

正如评论中的一位人士所建议的那样,使用cv2.copyMakeBorder()它有效。因此,关于上述参考代码的正确语法将是:

img = cv2.copyMakeBorder(img, 10, 10, 10, 10, cv2.BORDER_CONSTANT)

实际上它的作用是在每边添加一个 10 像素的黑色边框。而且,当我们使用cv2.findContour()它时,它实际上会检测到之前没有计算过的最大的(包括以前的小)。

于 2020-12-24T08:18:26.930 回答