Raspberry pi 如何在raspberry pi上使用omxh264enc将图像传输到gstreamer?

Raspberry pi 如何在raspberry pi上使用omxh264enc将图像传输到gstreamer?,raspberry-pi,raspberry-pi3,gstreamer,gstreamer-1.0,Raspberry Pi,Raspberry Pi3,Gstreamer,Gstreamer 1.0,我正在将图像传送到gstreamer,以便使用omxh264将其编码为视频。在我的代码中,图像从源接收并通过管道传输到gstreamer。为了复制这个问题,我在一个目录中提取了一些帧,并尝试使用以下命令将图像通过管道传输到gstreamer cat Images/* |gst-launch-1.0 fdsrc fd=0 ! videoparse framerate=25 ! videoconvert ! omxh264enc ! qtmux ! filesink location=out.mp4

我正在将图像传送到gstreamer,以便使用omxh264将其编码为视频。在我的代码中,图像从源接收并通过管道传输到gstreamer。为了复制这个问题,我在一个目录中提取了一些帧,并尝试使用以下命令将图像通过管道传输到gstreamer

cat Images/* |gst-launch-1.0 fdsrc fd=0 ! videoparse framerate=25 ! videoconvert ! omxh264enc ! qtmux ! filesink location=out.mp4
但是,我收到以下消息(在设置GST_DEBUG=“*:3”)之后)

正在将管道设置为暂停。。。
0:00:00.136206216 14317 0x1ee58a0警告GST\u POLL gstpoll.c:829:GST\u POLL\u remove\u fd:0x1edf450:找不到fd!
管道正在预滚。。。
0:00:00.171278212 14317 0x1ec0c90 FIXME视频编码器gstvideoencoder.c:606:gst\U video\U编码器\U setcaps:gstvideoencoder::reset()不推荐使用
0:00:00.181177600 14317 0x72302120警告GST_pad gstpad.c:4092:GST_pad_peer_查询:无法发送粘性事件
0:00:00.183710793 14317 0x72302120错误omx gstomx.c:2098:gst_omx_端口_填充_解锁:未能将缓冲区0x71900d50(0x71804010)传递到视频_编码端口201:端口索引错误(0x8000101b)
0:00:00.184424533 14317 0x72302120警告omxvideoenc gstomxvideoenc.c:945:gst_omx_video_enc_循环:错误:无法重新配置输出端口
错误:来自元素/GstPipeline:pipeline0/GstOMXH264Enc-omxh264enc:omxh264enc-omxh264enc0:无法配置支持库。
其他调试信息:
gstomxvideoenc.c(945):gst_omx_video_enc_loop():/GstPipeline:pipeline0/gstomxh264 enc-omxh264 enc:omxh264 enc-omxh264 enc0:
无法重新配置输出端口
错误:管道不想预卷。
正在将管道设置为空。。。
0:00:0.185111606 14317 0x72302120FixMeBaseCsgBaseSink .C: 3126:GSTYBaseXSKY-DEFAUTTHEL事件:没有组ID的流启动事件。考虑在上游元素中实现组ID处理
释放管道。。。
如果将omxh264enc替换为x264enc,则该命令可以正常工作。omxh264enc有什么问题

我也遇到了类似的问题(当时正在努力将一堆图像放到RPI上的H264视频中)。假设照片位于名为Image001.jpg、Image002.jpg等的文件夹中。这将把图像转换成一个avi文件,分辨率为640*480,每秒30帧。在RPIzero上运行,使用omxh264enc(GPU硬件加速)

尝试:

我有一个类似的问题(当时我正在努力把一堆图像放到RPI上的H264视频中)。假设照片位于名为Image001.jpg、Image002.jpg等的文件夹中。这将把图像转换成一个avi文件,分辨率为640*480,每秒30帧。在RPIzero上运行,使用omxh264enc(GPU硬件加速)

尝试:

Setting pipeline to PAUSED ...
0:00:00.136206216 14317  0x1ee58a0 WARN                GST_POLL gstpoll.c:829:gst_poll_remove_fd: 0x1edf450: couldn't find fd !
Pipeline is PREROLLING ...
0:00:00.171278212 14317  0x1ec0c90 FIXME           videoencoder gstvideoencoder.c:606:gst_video_encoder_setcaps:<omxh264enc-omxh264enc0> GstVideoEncoder::reset() is deprecated
0:00:00.181177600 14317 0x72302120 WARN                GST_PADS gstpad.c:4092:gst_pad_peer_query:<omxh264enc-omxh264enc0:src> could not send sticky events
0:00:00.183710793 14317 0x72302120 ERROR                    omx gstomx.c:2098:gst_omx_port_populate_unlocked:<omxh264enc-omxh264enc0> Failed to pass buffer 0x71900d50 (0x71804010) to video_encode port 201: Bad port index (0x8000101b)
0:00:00.184424533 14317 0x72302120 WARN             omxvideoenc gstomxvideoenc.c:945:gst_omx_video_enc_loop:<omxh264enc-omxh264enc0> error: Unable to reconfigure output port
ERROR: from element /GstPipeline:pipeline0/GstOMXH264Enc-omxh264enc:omxh264enc-omxh264enc0: Could not configure supporting library.
Additional debug info:
gstomxvideoenc.c(945): gst_omx_video_enc_loop (): /GstPipeline:pipeline0/GstOMXH264Enc-omxh264enc:omxh264enc-omxh264enc0:
Unable to reconfigure output port
ERROR: pipeline doesn't want to preroll.
Setting pipeline to NULL ...
0:00:00.185111606 14317 0x72302120 FIXME               basesink gstbasesink.c:3126:gst_base_sink_default_event:<filesink0> stream-start event without group-id. Consider implementing group-id handling in the upstream elements
Freeing pipeline ...
 gst-launch-1.0 -e multifilesrc location="/Folder/Image%03d.jpg" !  
 image/jpeg, framerate=30/1 ! decodebin ! video/x-raw, width=640,  
 height=480 ! progressreport name=progress ! omxh264encode   
 target-bitrate=7500000 control-rate=variable ! video/x-h264, profile=high !  
 h264parse ! filesink location="/home/pi/Desktop/NewVideo.avi"