这是我写的调用并显示一个摄像头的代码,如何得到每帧图像数据?(得到数据用作Oencv进行处理),希望能得到具体方法或者代码参照,我是刚接触gstreamer,感激不尽。
#include <gst/gst.h>#define Device_path_1 "/dev/video0"
//#define Device_path_2 "/dev/video1"
#define Camera_caps "video/x-raw-yuv,width=(int)1920,height=(int)1080,framerate=(fraction)30/1"int main(int argc, char *argv[])
{
GstElement *camera_source_1,*convert_1,*sink_1,*pipeline;
GMainLoop *loop; //初始化GST
gst_init(&argc,&argv); //创建需要的elements
camera_source_1 = gst_element_factory_make("v4l2src","camera_source_1");
convert_1 = gst_element_factory_make("ffmpegcolorspace","1_csp");
sink_1 = gst_element_factory_make("ximagesink","sink_1");
//创建pipeline
pipeline = gst_pipeline_new("camera_pipeline"); //出错处理
if(!pipeline || !camera_source_1 || !sink_1 || !convert_1){
g_printerr("Not all elements could be created !\n");
return -1;
} //配置 elements
g_object_set(G_OBJECT(camera_source_1),"device",Device_path_1,NULL); //link all elements
gst_bin_add_many(GST_BIN(pipeline),camera_source_1,convert_1,sink_1,NULL);
gst_element_link_many(camera_source_1,convert_1,sink_1,NULL); gst_element_set_state(pipeline,GST_STATE_PLAYING);
loop = g_main_loop_new(NULL,FALSE);
g_main_loop_run(loop);
g_print("stopping sender pipeline\n");
gst_element_set_state(pipeline,GST_STATE_NULL);
return 0;
}
#include <gst/gst.h>#define Device_path_1 "/dev/video0"
//#define Device_path_2 "/dev/video1"
#define Camera_caps "video/x-raw-yuv,width=(int)1920,height=(int)1080,framerate=(fraction)30/1"int main(int argc, char *argv[])
{
GstElement *camera_source_1,*convert_1,*sink_1,*pipeline;
GMainLoop *loop; //初始化GST
gst_init(&argc,&argv); //创建需要的elements
camera_source_1 = gst_element_factory_make("v4l2src","camera_source_1");
convert_1 = gst_element_factory_make("ffmpegcolorspace","1_csp");
sink_1 = gst_element_factory_make("ximagesink","sink_1");
//创建pipeline
pipeline = gst_pipeline_new("camera_pipeline"); //出错处理
if(!pipeline || !camera_source_1 || !sink_1 || !convert_1){
g_printerr("Not all elements could be created !\n");
return -1;
} //配置 elements
g_object_set(G_OBJECT(camera_source_1),"device",Device_path_1,NULL); //link all elements
gst_bin_add_many(GST_BIN(pipeline),camera_source_1,convert_1,sink_1,NULL);
gst_element_link_many(camera_source_1,convert_1,sink_1,NULL); gst_element_set_state(pipeline,GST_STATE_PLAYING);
loop = g_main_loop_new(NULL,FALSE);
g_main_loop_run(loop);
g_print("stopping sender pipeline\n");
gst_element_set_state(pipeline,GST_STATE_NULL);
return 0;
}
解决方案 »
- 关于win32Application的一点小问题,大虾们帮一下忙
- this->InvokeEvent(vtkCommand::LeftButtonPressEvent,NULL);两个参数都是什么含义?
- 新手困惑 一个小问题 快来拿分!
- 关于CRichEditCtrl 中的几个函数,在线等待
- 怎么使用LIB.EXE生成LIB文件?
- 透明显示为什么不能完全透明,在图象的边缘出现少量的不光滑的痕迹,怎么解决这个问题?
- 讨论一下像OICQ那样的聊天室如何实现更好?参与都有分
- 初来刚到
- ComboBox控件的问题
- 300两银子没人要吗(winsock问题)?
- VC MFC操作excel如何将一个excel中的sheet拷贝到另一个excel中
- 开发跨平台桌面应用
也不要做用A语言代码直接调用B语言代码库这样复杂、这样容易出错的傻事。
只需让A、B语言代码的输入输出重定向到文本文件,或修改A、B语言代码让其通过文本文件输入输出。
即可很方便地让A、B两种语言之间协调工作。
比如:
A将请求数据写到文件a.txt,写完后改名为aa.txt
B发现aa.txt存在时,读取其内容,调用相应功能,将结果写到文件b.txt,写完后删除aa.txt,改名为bb.txt
A发现bb.txt存在时,读取其内容,读完后删除bb.txt
以上A可以替换为任何一种开发语言或开发环境,B可以替换为任何一种与A不同的开发语言或开发环境。
除非A或B不支持判断文件是否存在、文件读写和文件更名。
但是谁又能举出不支持判断文件是否存在、文件读写和文件更名的开发语言或开发环境呢?
可以将临时文件放在RamDisk上提高效率减少磨损磁盘。
数据的结构很复杂的话,文本文件的格式问题可参考json或xml共享临时文本文件这种进程之间的通讯方法相比其它方法的优点有很多,下面仅列出我现在能想到的:
·进程之间松耦合
·进程可在同一台机器上,也可跨机,跨操作系统,跨硬件平台,甚至跨国。
·方便调试和监视,只需让第三方或人工查看该临时文本文件即可。
·方便在线开关服务,只需删除或创建该临时文本文件即可。
·方便实现分布式和负载均衡。
·方便队列化提供服务,而且几乎不可能发生队列满的情况(除非硬盘空间满)
·……“跨语言、跨机,跨操作系统,跨硬件平台,跨国,跨*.*的”苦海无边,
回头是“使用共享纯文本文件进行信息交流”的岸!