【发布时间】:2019-04-19 03:35:04
【问题描述】:
最近,我正在尝试使用带有 imx6 处理器和 MIPI-CSI 摄像头的板来传输视频。
我们的目标是通过 RTP 协议传输视频 (1920x1080@30fps),我们使用 gstreamer 管道来实现。要传输的命令管道是:
gst-launch-1.0 imxv4l2videosrc device=/dev/video1 imx-capture-mode=2 ! imxvpuenc_h264 quant-param=29 ! rtph264pay mtu=60000 ! udpsink host=10.42.0.1 port=5000 sync=false
该命令传输分辨率为 1920x108 的视频(imx-capture-mode=2 参数)。
我们使用以下命令从 PC (10.42.0.1) 捕获视频(通过端口 5000):
gst-launch-1.0 -v udpsrc port=5000 ! application/x-rtp, media=video, clock-rate=90000, encoding-name=H264, payload=96 ! rtph264depay ! avdec_h264 ! fpsdisplaysink text-overlay=false sync=false &
而且视频的流动性非常好。
但是现在,我们要在视频传输之前对其进行处理,因为相机是在运动的,我们需要添加一些算法来减少由于晃动而产生的噪音。
换句话说,主要思想是:从摄像头获取视频->处理视频->传输到RTP。所有这些都使用带有 imx6 的开发板。
该板基于 linux yocto 项目,它具有启用了 gstreamer 插件的 opencv 3.1。我们的想法是使用opencv和gstreamer管道获取视频,处理并传输它......但首先我们做了一些测试,获取视频并在不处理它的情况下传输它,但是当我们从PC捕获视频时,它非常慢并且延迟了...
我们想知道这是否是实现我们目标的正确方法。这是我们正在使用的源代码:
#include <QCoreApplication>
#include <QDebug>
#include <opencv2/opencv.hpp>
#include <opencv2/video.hpp>
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
cv::VideoCapture cap("imxv4l2videosrc device=/dev/video1 imx-capture-mode=2 ! videoconvert ! appsink");
Q_ASSERT(cap.isOpened());
if(!cap.isOpened())
{
qDebug() << "Error with the video capturer";
a.exit(-1);
}
cv::Mat frame;
cap >> frame; //Dummy read
double frame_width= cap.get(CV_CAP_PROP_FRAME_WIDTH);
double frame_height= cap.get(CV_CAP_PROP_FRAME_HEIGHT);
cv::VideoWriter writer;
writer.open("appsrc ! videoconvert ! imxvpuenc_h264 quant-param=29 ! rtph264pay mtu=60000 ! udpsink host=10.42.0.1 port=5000 sync=false",
0,30,cv::Size(frame_width,frame_height));
if(!writer.isOpened())
{
qDebug() << "Error video writer";
a.exit(-1);
}
while(true) {
cap.read(frame);
if(frame.empty())
break;
writer.write(frame);
cv::waitKey(33);
}
return a.exec();
}
【问题讨论】:
-
你好@E.Vera 1- 你能在你的主板和你的电脑上添加 gstreamer 的版本吗? 2- 当您使用
top或htop时,您是否看到使用超过100% cpu 的进程以及您的应用程序名称? -
嗨@AlperKucukkomurler,对于延迟回答表示歉意。 gstreamer 版本是... PC:GStreamer 1.8.3 和板:GStreamer 1.10.4。是的!你是对的,这个过程正在使用超过 100% 到 150% 左右。你知道为什么吗?是因为 gstreamer 版本吗?
-
我问版本的原因是gstreamer有
udpsrc元素的bug,导致播放慢。但是据我记得它已经在 1.8.3 中解决了。我的其余评论不适合此处,因此我将其发布为答案。
标签: opencv video gstreamer yocto imx6