2014-03-30 55 views
0

我想在OpenCV中打开一个视频源文件进行处理。我下面的教程这里给出:http://docs.opencv.org/trunk/doc/py_tutorials/py_video/py_lucas_kanade/py_lucas_kanade.html#lucas-kanadeOpenCV灰度转换错误

每次我试图打开要处理我收到以下错误.AVI视频文件:

Traceback (most recent call last): 
    File "C:\Users\Adam\Desktop\LastProjectAI\sources\samples\python2\lines.py", line 22, in <module> 
    old_gray = cv2.cvtColor(old_frame, cv2.COLOR_BGR2GRAY) 
error: ..\..\..\src\opencv\modules\imgproc\src\color.cpp:3402: error: (-215) scn == 3 || scn == 4 

我从其他职位读到这样的错误当源视频文件不是3或4个频道时抛出。但是,我使用的是OpenCV教程提供的视频,所以我不明白他们为什么不工作。

下面是完整的代码,我有工作:

import numpy as np 
import cv2 

cap = cv2.VideoCapture('walking.avi') 

# params for ShiTomasi corner detection 
feature_params = dict(maxCorners = 100, 
         qualityLevel = 0.3, 
         minDistance = 7, 
         blockSize = 7) 

# Parameters for lucas kanade optical flow 
lk_params = dict(winSize = (15,15), 
        maxLevel = 2, 
        criteria = (cv2.TERM_CRITERIA_EPS | cv2.TERM_CRITERIA_COUNT, 10, 0.03)) 

# Create some random colors 
color = np.random.randint(0,255,(100,3)) 

# Take first frame and find corners in it 
ret, old_frame = cap.read() 
old_gray = cv2.cvtColor(old_frame, cv2.COLOR_BGR2GRAY) 
p0 = cv2.goodFeaturesToTrack(old_gray, mask = None, **feature_params) 

# Create a mask image for drawing purposes 
mask = np.zeros_like(old_frame) 

while(1): 
    ret,frame = cap.read() 
    frame_gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) 

    # calculate optical flow 
    p1, st, err = cv2.calcOpticalFlowPyrLK(old_gray, frame_gray, p0, None, **lk_params) 

    # Select good points 
    good_new = p1[st==1] 
    good_old = p0[st==1] 

    # draw the tracks 
    for i,(new,old) in enumerate(zip(good_new,good_old)): 
     a,b = new.ravel() 
     c,d = old.ravel() 
     mask = cv2.line(mask, (a,b),(c,d), color[i].tolist(), 2) 
     frame = cv2.circle(frame,(a,b),5,color[i].tolist(),-1) 
    img = cv2.add(frame,mask) 

    cv2.imshow('frame',img) 
    k = cv2.waitKey(30) & 0xff 
    if k == 27: 
     break 

    # Now update the previous frame and previous points 
    old_gray = frame_gray.copy() 
    p0 = good_new.reshape(-1,1,2) 

cv2.destroyAllWindows() 
cap.release() 

下应注意:

  • 我使用与Windows 8
  • 视频文件的Python编辑器IDLE我想要加载的是与Python文件直接相同的文件。

我试过多个视频文件没有运气。有没有人有任何建议去解决这个错误?

编辑:

我能证明它是从德视频拍摄对象直接读取后的帧。但是,如果我尝试后的for循环其中提请轨道加载框架,我得到这个错误:

OpenCV Error: Bad flag (parameter or structure field) (Unrecognized or unsupported array type) in cvGetMat, file /build/buildd/opencv-2.4.5+dfsg/modules/core/src/array.cpp, line 2482 
Traceback (most recent call last): 
    File "prac.py", line 55, in <module> 
    cv2.imshow('frame2', frame) 
cv2.error: /build/buildd/opencv-2.4.5+dfsg/modules/core/src/array.cpp:2482: error: (-206) Unrecognized or unsupported array type in function cvGetMat 
+0

你正在使用哪个opencv版本? 在opencv 2.x cv2.line()和cv2.circle()返回空,所以只需从您的代码中删除“mask =”和“frame =” –

回答

1

我认为程序无法找到您的视频文件。每当您尝试加载视频或图像文件时,请不要忘记制作一个if condition以检查视频/图像是否已加载。

if frame data is nothing - >>print "frame is empty"

否则,以确保从视频帧已经成功加载,你可以尝试立即显示该帧,一旦加载,但不要忘了把waitKey(0)imshow statement

首先检查视频帧是否被加载,并让我们知道它。

+0

我采用了您的建议并已本地化错误(谢谢提示)。看来帧变量正在填充正确的数据,并且可以在视频捕获被读取后直接显示。但是,如果我尝试在绘制轨迹的for循环后显示框架,它会给我一个错误(请参阅后编辑)。 –

+0

好的好!你能准确地标记哪一行发生了错误吗?可能你的'frame'没有在该范围内声明 – skm