我正在尝试转换从捕获(网络摄像头)拍摄的图像,并使用OpenCV对它们进行一些处理,但是我遇到了困难.
尝试将图像转换为灰度时,程序崩溃. (Python.exe已停止工作)
这是我的代码的主要片段:
newFrameImageGS = cv.CreateImage ((320, 240), cv.IPL_DEPTH_8U, 1)
for i in range(0,5):
newFrameImage = cv.QueryFrame(ps3eye)
cv.CvtColor(newFrameImage,newFrameImageGS,cv.CV_BGR2GRAY)
golfSwing.append(newFrameImageGS)
当我尝试使用cvConvertScale时,我得到断言错误:
src.size() == dst.size() && src.channels() == dst.channels()
这很有意义,但是我对如何将网络摄像头的输入图像转换为可由cvUpdateMotionHistory()和cvCalcOpticalFlowLK()等功能使用的图像感到困惑
有任何想法吗?谢谢.
更新:
我将图像手动转换为灰度:
for row in range(0,newFrameImage.height):
for col in range(0,newFrameImage.width):
newFrameImageGS[row,col] = (newFrameImage8U[row,col][0] * 0.114 + # B
newFrameImage8U[row,col][1] * 0.587 + # G
newFrameImage8U[row,col][2] * 0.299) # R
但这要花相当长的时间..而且我仍然不知道为什么cvCvtColor导致程序崩溃.