2014-03-30 3 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 채널이 아닌 경우 throw됩니다. 그러나 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() 
다음은 주목해야한다

:

  • 나는 윈도우 8
  • 비디오 파일을 파이썬 편집기 IDLE을 사용하고 있습니다 내가로드하려고하는 것은 파이썬 파일과 똑같습니다.

나는 행운과 함께 여러 비디오 파일을 시도했다. 누구든지이 오류 수정에 대한 제안 사항이 있습니까?

편집 :

내가이 TEH 비디오 캡처 개체에서 읽은 후 바로 프레임을 보여줄 수 있어요. 나는 프로그램이 비디오 파일을 찾을 수 없습니다 생각

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

: 나는 트랙을 그립니다 for 루프 후 프레임을로드 할 경우, 나는이 오류가 발생합니다. 비디오 또는 이미지 파일을로드하려고 할 때마다 if condition을 만들어 비디오/이미지가로드되었는지 여부를 확인하십시오.

if frame data is nothing - >> 다른

print "frame is empty" 당신은로드되면 즉시 프레임을 보여주기 위해 시도 할 수 있지만 waitKey(0) 후를 넣어하는 것을 잊지 마세요, 비디오에서 프레임이 성공적으로로드되었는지 확인하기 the imshow statement

먼저 비디오 프레임이로드되었는지 확인하고 알려주십시오.

+0

제안을 사용하고 오류를 현지화했습니다. 팁). 프레임 변수가 올바른 데이터로 채워지고 비디오 캡처가 읽힌 직후에 표시 될 수 있습니다. 그러나 트랙을 그리는 for 루프 다음에 프레임을 표시하려고하면 오류가 발생합니다 (포스트 편집 참조). –

+0

좋습니다. 어떤 라인이 오류를 던지고 있는지 정확히 표시 할 수 있습니까? 당신의'frame'이 그 범위에서 선언되지 않았을 수도 있습니다 – skm

관련 문제