我想使用 opencv 库中的边缘检测算法。
这是一段Python代码:
from opencv.cv import *
from opencv.highgui import *
img = cvLoadImage ('xxx.jpg')
cvNamedWindow ('img')
cvShowImage ('img', img)
cvWaitKey ()
canny = cvCreateImage (cvSize (img.width, img.height), 8, 3)
cvCanny (img, canny, 50, 200)
harris = cvCreateImage (cvSize (img.width, img.height), 8, 3)
cvCornerHarris (img, harris, 5, 5, 0.1)
加载和显示图像工作正常,但精明和哈里斯转换失败。
cvCanny
失败并显示:
RuntimeError: openCV Error:
Status=Unsupported format or combination of formats
function name=cvCanny
error message=
file_name=cv/cvcanny.cpp
line=72
and cvCornerHarris
失败并出现此错误:
RuntimeError: openCV Error:
Status=Assertion failed
function name=cvCornerHarris
error message=src.size() == dst.size() && dst.type() == CV_32FC1
file_name=cv/cvcorner.cpp
line=370
从这条消息我可以推断加载的图像格式无效。但我不明白如何转换它。
这是一些值img
fields:
img.type = 1111638032
img.nChannels = 3
img.depth = 8