- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试使用代码阅读多项选择测试反馈中的答案,但出现以下错误消息:
error: (-215:Assertion failed) npoints >= 0 && (depth == CV_32F || depth == CV_32S) in function 'cv::contourArea
我已经尝试使用计算机中的 .png 图像而不是使用相机,但我遇到了同样的问题。我是 python 的新手,我不知道库或代码是否有问题。这是我正在使用的代码:
from imutils.perspective import four_point_transform
from imutils import contours
import numpy as np
import imutils
import cv2
ct = 0
cap = cv2.VideoCapture(0)
correct = 0
gb = [3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3]
while (1):
ct = 0
ret, image = cap.read()
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
blurred = cv2.GaussianBlur(gray, (3, 3), 0)
edged = cv2.Canny(blurred, 20, 150)
cv2.imshow("Camera", edged)
if cv2.waitKey(1) & 0xFF == ord('q'):
break
cv2.moveWindow("Camera", 0, 0)
cnts = cv2.findContours(edged.copy(), cv2.RETR_EXTERNAL,
cv2.CHAIN_APPROX_SIMPLE)
cnts = cnts[0] if imutils.is_cv2() else cnts[1]
docCnt = None
if len(cnts) > 0:
cnts = sorted(cnts, key=cv2.contourArea, reverse=True)
for c in cnts:
peri = 0.02 * cv2.arcLength(c, True)
approx = cv2.approxPolyDP(c, peri, True)
if len(approx) == 4:
ct = 1
docCnt = approx
break
if ct == 1:
paper = four_point_transform(image, docCnt.reshape(4, 2))
warped = four_point_transform(gray, docCnt.reshape(4, 2))
altura = paper.shape[0] // 11
largura = paper.shape[0] // 2.95
paper = paper[altura:paper.shape[0], largura:paper.shape[1]]
thresh = cv2.threshold(warped, 0, 255, cv2.THRESH_BINARY_INV | cv2.THRESH_OTSU)[1]
thresh = thresh[altura:thresh.shape[0], largura:thresh.shape[1]]
if thresh.shape[0] > 0 and thresh.shape[1] > 0:
cnts = cv2.findContours(thresh.copy(),
cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
cnts = cnts[0] if imutils.is_cv2() else cnts[1]
questionCnts = []
for c in cnts:
tamanho = thresh.shape[1] / 5
(x, y, w, h) = cv2.boundingRect(c)
ar = w / float(h)
approx = cv2.approxPolyDP(c, peri, True)
if (w <= tamanho and h < tamanho) and (ar >= 1.6 and ar <= 2.6) and (w > tamanho / 10 and h > tamanho / 10):
questionCnts.append(c)
print(len(questionCnts))
if len(questionCnts) == 50:
break
cont = 0
x = 0
y = 0
res = []
bubbled = []
questao = []
for (q, i) in enumerate(np.arange(0, len(questionCnts), 5)):
cont = 0
cnts = contours.sort_contours(questionCnts[i:i + 5])[0]
bubbled = []
for (j, c) in enumerate(cnts):
x = thresh.shape[0]
y = thresh.shape[1]
mask = np.zeros(thresh.shape, dtype="uint8")
cv2.drawContours(mask, [c], -1, 255, -1)
mask = cv2.bitwise_and(thresh, thresh, mask=mask)
total = cv2.countNonZero(mask)
if total > x // 20 * y // 10:
bubbled.append(j)
cont += 1
if cont == 1:
res.append(bubbled[0])
else:
res.append(-1)
color = (0, 0, 255)
k = gb[q]
if cont == 1:
if k == bubbled[0]:
color = (0, 255, 0)
correct += 1
for s in range(cont):
cv2.drawContours(paper, [cnts[bubbled[s]]], -1, color, 3)
res2 = []
for i in range(len(res)):
res2.append(res[len(res) - i - 1])
print("Gabarito:", gb)
print("Respostas:", res2)
print("Nota:", float(correct))
cv2.imshow("Cartao Resposta", paper)
cv2.waitKey(0)
cv2.imshow("real", image)
cv2.waitKey(0)
cap.release()
最佳答案
你把这条线倒过来了。变化
cnts = cnts[0] if imutils.is_cv2() else cnts[1]
到
cnts = cnts[1] if imutils.is_cv2() else cnts[0]
这一行实质上是检查您正在运行的 OpenCV 版本。如果是 OpenCV 3.4.X,则 cv2.findContours()
函数返回 3 项,因此要获取实际轮廓,您需要获取第二个返回值。同样,如果您运行的是 OpenCV 4.1.X,cv2.findContours()
返回 2 个项目,因此您需要获取第一个值才能获得实际轮廓。
这是固定代码
from imutils.perspective import four_point_transform
from imutils import contours
import numpy as np
import imutils
import cv2
ct = 0
cap = cv2.VideoCapture(0)
correct = 0
gb = [3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3]
while (1):
ct = 0
ret, image = cap.read()
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
blurred = cv2.GaussianBlur(gray, (3, 3), 0)
edged = cv2.Canny(blurred, 20, 150)
cv2.imshow("Camera", edged)
if cv2.waitKey(1) & 0xFF == ord('q'):
break
cv2.moveWindow("Camera", 0, 0)
cnts = cv2.findContours(edged.copy(), cv2.RETR_EXTERNAL,
cv2.CHAIN_APPROX_SIMPLE)
cnts = cnts[1] if imutils.is_cv2() else cnts[0]
docCnt = None
if len(cnts) > 0:
cnts = sorted(cnts, key=cv2.contourArea, reverse=True)
for c in cnts:
peri = 0.02 * cv2.arcLength(c, True)
approx = cv2.approxPolyDP(c, peri, True)
if len(approx) == 4:
ct = 1
docCnt = approx
break
if ct == 1:
paper = four_point_transform(image, docCnt.reshape(4, 2))
warped = four_point_transform(gray, docCnt.reshape(4, 2))
altura = paper.shape[0] // 11
largura = paper.shape[0] // 2.95
paper = paper[altura:paper.shape[0], largura:paper.shape[1]]
thresh = cv2.threshold(warped, 0, 255, cv2.THRESH_BINARY_INV | cv2.THRESH_OTSU)[1]
thresh = thresh[altura:thresh.shape[0], largura:thresh.shape[1]]
if thresh.shape[0] > 0 and thresh.shape[1] > 0:
cnts = cv2.findContours(thresh.copy(),
cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
cnts = cnts[0] if imutils.is_cv2() else cnts[1]
questionCnts = []
for c in cnts:
tamanho = thresh.shape[1] / 5
(x, y, w, h) = cv2.boundingRect(c)
ar = w / float(h)
approx = cv2.approxPolyDP(c, peri, True)
if (w <= tamanho and h < tamanho) and (ar >= 1.6 and ar <= 2.6) and (w > tamanho / 10 and h > tamanho / 10):
questionCnts.append(c)
print(len(questionCnts))
if len(questionCnts) == 50:
break
cont = 0
x = 0
y = 0
res = []
bubbled = []
questao = []
for (q, i) in enumerate(np.arange(0, len(questionCnts), 5)):
cont = 0
cnts = contours.sort_contours(questionCnts[i:i + 5])[0]
bubbled = []
for (j, c) in enumerate(cnts):
x = thresh.shape[0]
y = thresh.shape[1]
mask = np.zeros(thresh.shape, dtype="uint8")
cv2.drawContours(mask, [c], -1, 255, -1)
mask = cv2.bitwise_and(thresh, thresh, mask=mask)
total = cv2.countNonZero(mask)
if total > x // 20 * y // 10:
bubbled.append(j)
cont += 1
if cont == 1:
res.append(bubbled[0])
else:
res.append(-1)
color = (0, 0, 255)
k = gb[q]
if cont == 1:
if k == bubbled[0]:
color = (0, 255, 0)
correct += 1
for s in range(cont):
cv2.drawContours(paper, [cnts[bubbled[s]]], -1, color, 3)
res2 = []
for i in range(len(res)):
res2.append(res[len(res) - i - 1])
print("Gabarito:", gb)
print("Respostas:", res2)
print("Nota:", float(correct))
cv2.imshow("Cartao Resposta", paper)
cv2.waitKey(0)
cv2.imshow("real", image)
cv2.waitKey(0)
cap.release()
关于python - 出现以下错误消息 : error: (-215:Assertion failed) npoints >= 0 && (depth == CV_32F || depth == CV_32S) in function 'cv::contourArea' ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57980005/
reqwest v0.9 将 serde v1.0 作为依赖项,因此实现 converting serde_json errors into reqwest error . 在我的代码中,我使用 se
我有这个代码: let file = FileStorage { // ... }; file.write("Test", bytes.as_ref()) .map_err(|e| Mu
我只是尝试用angular-cli创建一个新项目,然后运行服务器,但是它停止并显示一条有趣的消息:Error: No errors。 我以这种方式更新了(希望有帮助):npm uninstall -g
我从我的 javascript 发送交易 Metamask 打开传输对话框 我确定 i get an error message in metamask (inpage.js:1 MetaMask -
这个问题在这里已经有了答案: How do you define custom `Error` types in Rust? (3 个答案) How to get a reference to a
我想知道两者之间有什么大的区别 if let error = error{} vs if error != nil?或者只是人们的不同之处,比如他们如何用代码表达自己? 例如,如果我使用这段代码: u
当我尝试发送超过 50KB 的图像时,我在 Blazor 服务器应用程序上收到以下错误消息 Error: Connection disconnected with error 'Error: Serv
我有一个error-page指令,它将所有异常重定向到错误显示页面 我的web.xml: [...] java.lang.Exception /vi
我有这样的对象: address: { "phone" : 888, "value" : 12 } 在 WHERE 中我需要通过 address.value 查找对象,但是在 SQL 中有函数
每次我尝试编译我的代码时,我都会遇到大量错误。这不是我的代码的问题,因为它在另一台计算机上工作得很好。我尝试重新安装和修复,但这没有帮助。这是整个错误消息: 1>------ Build starte
在我的代码的类部分,如果我写一个错误,则在不应该的情况下,将有几行报告为错误。我将'| error'放在可以从错误中恢复的良好/安全位置,但是我认为它没有使用它。也许它试图在某个地方恢复中间表情? 有
我遇到了 csv 输入文件整体读取故障的问题,我可以通过在 read_csv 函数中添加 "error_bad_lines=False" 来删除这些问题来解决这个问题。 但是我需要报告这些造成问题的文
在 Spring 中,验证后我们在 controller 中得到一个 BindingResult 对象。 很简单,如果我收到验证错误,我想重新显示我的表单,并在每个受影响的字段上方显示错误消息。 因此
我不知道出了什么问题,因为我用 Java 编程了大约一年,从来没有遇到过这个错误。在一分钟前在 Eclipse 中编译和运行工作,现在我得到这个错误: #A fatal error has been
SELECT to_char(messages. TIME, 'YYYY/MM/DD') AS FullDate, to_char(messages. TIME, 'MM/DD
我收到这些错误: AnonymousPath\Anonymized.vb : error BC30037: Character is not valid. AnonymousPath\Anonymiz
我刚刚安装了 gridengine 并在执行 qstat 时出现错误: error: commlib error: got select error (Connection refused) erro
嗨,我正在学习 PHP,我从 CRUD 系统开始,我在 Windows 上安装了 WAMP 服务器,当我运行它时,我收到以下错误消息。 SCREAM: Error suppression ignore
我刚刚开始一个新项目,我正在学习核心数据教程,可以找到:https://www.youtube.com/watch?v=zZJpsszfTHM 我似乎无法弄清楚为什么会抛出此错误。我有一个名为“Exp
当我使用 Jenkins 运行新构建时,出现以下错误: "FilePathY\XXX.cpp : fatal error C1853: 'FilePathZ\XXX.pch' precompiled
我是一名优秀的程序员,十分优秀!