c – OpenCV和GoPro – VideoCapture流中的空帧
发布时间:2020-12-16 07:08:39 所属栏目:百科 来源:网络整理
导读:我有一个GoPro Hero 3(黑色)连接到视频采集卡(AverMedia Game Broadcaster HD).我只是想在OpenCV中获取视频流.使用Logitech网络摄像头没有问题.使用的代码如下. VideoCapture cap;cap.open(0);waitKey(300);//cap.set(CV_CAP_PROP_FRAME_WIDTH,1280);//cap.s
我有一个GoPro Hero 3(黑色)连接到视频采集卡(AverMedia Game Broadcaster HD).我只是想在OpenCV中获取视频流.使用Logitech网络摄像头没有问题.使用的代码如下.
VideoCapture cap; cap.open(0); waitKey(300); //cap.set(CV_CAP_PROP_FRAME_WIDTH,1280); //cap.set(CV_CAP_PROP_FRAME_HEIGHT,720); if (cap.isOpened()){ cout << "Cam identified" << endl; } namedWindow("dst",1); while (1){ Mat frame; if (!cap.read(frame)) { std::cout << "Unable to read frame from video stream" << std::endl; continue; } imshow("dst",frame); [...] } 使用GoPro会发生以下情况:OpenCV能够打开VideoCapture(“Cam已识别”)但无法读取任何帧(只有灰色屏幕和输出:“无法从视频流中读取帧”).我还用frame.empty();检查了这个. 我知道视频采集卡工作正常,因为Unity使用GoPro流打开WebCamTexture没有任何问题.我读了OpenCv中的编解码器问题,所以我已经尝试用FFMPEG支持编译OpenCV.现在可以显示录制的GoPro的MP4-Videos但是流仍然不起作用. 我使用OpenCV 2.48,Windows 7和Visual Studio 2013. 编辑:这是libVLC解决方案的代码: struct ctx { uint8_t* pixeldata; std::mutex imagemutex; }; static void display(void *data,void *id); static void unlock(void *data,void *id,void *const *p_pixels); static void *lock(void *data,void **p_pixels); struct ctx ctx; libvlc_instance_t *inst; libvlc_media_player_t *mp; libvlc_media_t *m; int main(int argc,char* argv[]) { ctx.pixeldata = new uint8_t[1280 * 720 * 3]; char const *vlc_argv[] = { "-vvv","--no-audio",/* skip any audio track */ "--no-xlib",/* tell VLC to not use Xlib */ }; int vlc_argc = sizeof(vlc_argv) / sizeof(*vlc_argv); inst = libvlc_new(vlc_argc,vlc_argv); const char *options[] = { ":dshow-vdev=AVerMedia HD Capture",":dshow-adev=none",//":dshow-size=1280x720",":dshow-fps=24",":dshow-chroma=YUY2",":dshow-video-input=1",":dshow-video-output=1",":dshow-aspect-ratio=16:9",":live-caching=80",NULL }; m = libvlc_media_new_location(inst,"dshow://"); for (const char **opt = options; *opt; opt++) libvlc_media_add_option(m,*opt); mp = libvlc_media_player_new_from_media(m); libvlc_media_release(m); libvlc_video_set_callbacks(mp,lock,unlock,display,&ctx); libvlc_video_set_format(mp,"RV24",1280,720,1280 * 3); libvlc_media_player_play(mp); namedWindow("all",1); Mat frame(720,CV_8UC3); while (1){ ctx.imagemutex.lock(); memcpy(gesamt.data,ctx.pixeldata,1280 * 720 * sizeof(uint8_t) * 3); ctx.imagemutex.unlock(); imshow("all",gesamt); if (waitKey(30) == 27) //wait for 'esc' key press for 30ms. If 'esc' key is pressed,break loop { cout << "esc key is pressed by user" << endl; break; } } libvlc_media_player_stop(mp); libvlc_media_player_release(mp); libvlc_release(inst); delete[] ctx.pixeldata; return 0; } void display(void *data,void *id){ (void)data; assert(id == NULL); } void unlock(void *data,void *const *p_pixels){ struct ctx *ctx = (struct ctx*)data; ctx->imagemutex.unlock(); assert(id == NULL); } void *lock(void *data,void **p_pixels){ struct ctx *ctx = (struct ctx*)data; ctx->imagemutex.lock(); *p_pixels = ctx->pixeldata; return NULL; } 解决方法
我试图通过Avermedia采集卡流式传输索尼动作凸轮时遇到了同样的问题.一个快速修复似乎是使用DVDrive,这使您的捕获卡输出看起来像一个网络摄像头.我已成功使用它作为一种解决方法.
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |