gstreamer播放mp4 c代码

时间: 2023-11-25 09:51:30 浏览: 29
以下是Linux平台C语言利用GStreamer实现mp4格式视频播放的代码,包括管道配置,连接,以及动态连接element的pad。其中难点在于demux控件通过回调方式进行音视频的分流,连接解码器、sink输出。 ```c #include <gst/gst.h> typedef struct _CustomData { GstElement *pipeline; GstElement *source; GstElement *demuxer; GstElement *audio_decoder; GstElement *video_decoder; GstElement *audio_sink; GstElement *video_sink; GstElement *convert; GstElement *resample; GstElement *audio_queue; GstElement *video_queue; GstElement *video_convert; GstElement *video_scale; GstElement *video_filter; GstElement *audio_filter; GstElement *audio_convert; GstElement *audio_resample; GstElement *audio_sink2; GstElement *video_sink2; GstBus *bus; guint bus_watch_id; gboolean is_live; } CustomData; static void pad_added_handler (GstElement *src, GstPad *new_pad, CustomData *data); int main(int argc, char *argv[]) { CustomData data; GstStateChangeReturn ret; GstPad *audio_sink_pad = NULL; GstPad *video_sink_pad = NULL; GstPad *audio_src_pad = NULL; GstPad *video_src_pad = NULL; GstCaps *audio_caps = NULL; GstCaps *video_caps = NULL; GstCaps *filter_caps = NULL; GstCaps *convert_caps = NULL; GstCaps *scale_caps = NULL; GstCaps *resample_caps = NULL; GstCaps *audio_convert_caps = NULL; GstCaps *audio_resample_caps = NULL; GstCaps *audio_filter_caps = NULL; GstCaps *video_filter_caps = NULL; GstCaps *video_convert_caps = NULL; GstCaps *video_scale_caps = NULL; /* Initialize GStreamer */ gst_init (&argc, &argv); /* Initialize our data structure */ memset (&data, 0, sizeof (data)); data.is_live = FALSE; /* Create the elements */ data.source = gst_element_factory_make ("filesrc", "source"); data.demuxer = gst_element_factory_make ("qtdemux", "demuxer"); data.audio_decoder = gst_element_factory_make ("decodebin", "audio_decoder"); data.video_decoder = gst_element_factory_make ("decodebin", "video_decoder"); data.convert = gst_element_factory_make ("videoconvert", "convert"); data.resample = gst_element_factory_make ("audioresample", "resample"); data.audio_queue = gst_element_factory_make ("queue", "audio_queue"); data.video_queue = gst_element_factory_make ("queue", "video_queue"); data.audio_sink = gst_element_factory_make ("autoaudiosink", "audio_sink"); data.video_sink = gst_element_factory_make ("autovideosink", "video_sink"); data.video_convert = gst_element_factory_make ("videoconvert", "video_convert"); data.video_scale = gst_element_factory_make ("videoscale", "video_scale"); data.video_filter = gst_element_factory_make ("capsfilter", "video_filter"); data.audio_filter = gst_element_factory_make ("capsfilter", "audio_filter"); data.audio_convert = gst_element_factory_make ("audioconvert", "audio_convert"); data.audio_resample = gst_element_factory_make ("audioresample", "audio_resample"); data.audio_sink2 = gst_element_factory_make ("alsasink", "audio_sink2"); data.video_sink2 = gst_element_factory_make ("xvimagesink", "video_sink2"); /* Create the empty pipeline */ data.pipeline = gst_pipeline_new ("test-pipeline"); if (!data.pipeline || !data.source || !data.demuxer || !data.audio_decoder || !data.video_decoder || !data.convert || !data.resample || !data.audio_queue || !data.video_queue || !data.audio_sink || !data.video_sink || !data.video_convert || !data.video_scale || !data.video_filter || !data.audio_filter || !data.audio_convert || !data.audio_resample || !data.audio_sink2 || !data.video_sink2) { g_printerr ("Not all elements could be created.\n"); return -1; } /* Build the pipeline */ gst_bin_add_many (GST_BIN (data.pipeline), data.source, data.demuxer, data.audio_decoder, data.video_decoder, data.convert, data.resample, data.audio_queue, data.video_queue, data.audio_sink, data.video_sink, data.video_convert, data.video_scale, data.video_filter, data.audio_filter, data.audio_convert, data.audio_resample, data.audio_sink2, data.video_sink2, NULL); if (gst_element_link (data.source, data.demuxer) != TRUE || gst_element_link_many (data.audio_queue, data.audio_convert, data.audio_resample, data.audio_filter, data.audio_sink2, NULL) != TRUE || gst_element_link_many (data.video_queue, data.video_convert, data.video_scale, data.video_filter, data.video_sink2, NULL) != TRUE) { g_printerr ("Elements could not be linked.\n"); gst_object_unref (data.pipeline); return -1; } /* Set the URI to play */ g_object_set (data.source, "location", argv[1], NULL); /* Connect to the pad-added signal */ g_signal_connect (data.demuxer, "pad-added", G_CALLBACK (pad_added_handler), &data); /* Start playing */ ret = gst_element_set_state (data.pipeline, GST_STATE_PLAYING); if (ret == GST_STATE_CHANGE_FAILURE) { g_printerr ("Unable to set the pipeline to the playing state.\n"); gst_object_unref (data.pipeline); return -1; } /* Wait until error or EOS */ data.bus = gst_element_get_bus (data.pipeline); data.bus_watch_id = gst_bus_add_watch (data.bus, bus_call, loop); gst_object_unref (data.bus); g_main_loop_run (loop); /* Free resources */ gst_element_set_state (data.pipeline, GST_STATE_NULL); gst_object_unref (data.pipeline); return 0; } static void pad_added_handler (GstElement *src, GstPad *new_pad, CustomData *data) { GstPad *sink_pad = NULL; GstPadLinkReturn ret; GstCaps *new_pad_caps = NULL; GstStructure *new_pad_struct = NULL; const gchar *new_pad_type = NULL; g_print ("Received new pad '%s' from '%s':\n", GST_PAD_NAME (new_pad), GST_ELEMENT_NAME (src)); /* Check the new pad's type */ new_pad_caps = gst_pad_get_current_caps (new_pad); new_pad_struct = gst_caps_get_structure (new_pad_caps, 0); new_pad_type = gst_structure_get_name (new_pad_struct); if (g_str_has_prefix (new_pad_type, "audio/x-raw")) { sink_pad = gst_element_get_static_pad (data->audio_queue, "sink"); g_print ("Linking audio demuxer to audio queue.\n"); } else if (g_str_has_prefix (new_pad_type, "video/x-raw")) { sink_pad = gst_element_get_static_pad (data->video_queue, "sink"); g_print ("Linking video demuxer to video queue.\n"); } else { g_print ("It has type '%s' which is not raw audio. Ignoring.\n", new_pad_type); goto exit; } /* If we have an unlinked sink pad, link it now */ if (gst_pad_is_linked (sink_pad)) { g_print ("We are already linked. Ignoring.\n"); goto exit; } /* Attempt the link */ ret = gst_pad_link (new_pad, sink_pad); if (GST_PAD_LINK_FAILED (ret)) { g_print ("Type is '%s' but link failed.\n", new_pad_type); } else { g_print ("Link succeeded (type '%s').\n", new_pad_type); } exit: /* Unreference the new pad's caps, if we got them */ if (new_pad_caps != NULL) gst_caps_unref (new_pad_caps); /* Unreference the sink pad */ if (sink_pad != NULL) gst_object_unref (sink_pad); } ```

相关推荐

最新推荐

recommend-type

gstreamer安装和MP3的播放

gstreamer安装和MP3的播放gstreamer安装和MP3的播放gstreamer安装和MP3的播放gstreamer安装和MP3的播放gstreamer安装和MP3的播放gstreamer安装和MP3的播放gstreamer安装和MP3的播放gstreamer安装和MP3的播放
recommend-type

python gstreamer实现视频快进/快退/循环播放功能

主要介绍了python gstreamer 实现视频快进/快退/循环播放功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

GStreamer+插件开发指南(中文)

GStreamer+插件开发指南(中文) GStreamer+插件开发指南(中文) GStreamer+插件开发指南(中文) GStreamer+插件开发指南(中文)
recommend-type

Gstreamer 测试udpsink udpsrc播放mp3文件

Gstreamer 测试udpsink udpsrc播放mp3文件,提供简单的UDP传输方案
recommend-type

关于__Federico Milano 的电力系统分析工具箱.zip

1.版本:matlab2014/2019a/2021a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

:YOLO目标检测算法的挑战与机遇:数据质量、计算资源与算法优化,探索未来发展方向

![:YOLO目标检测算法的挑战与机遇:数据质量、计算资源与算法优化,探索未来发展方向](https://img-blog.csdnimg.cn/7e3d12895feb4651b9748135c91e0f1a.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5rKJ6YaJ77yM5LqO6aOO5Lit,size_20,color_FFFFFF,t_70,g_se,x_16) # 1. YOLO目标检测算法简介 YOLO(You Only Look Once)是一种
recommend-type

def ObjFun(x,y,beta): # 目标函数 """ Logistic regression loss function :param beta: model parameter vector :param x: feature matrix :param y: label vector :return: loss value """ n = x.shape[0] p = x.shape[1] pred = 1 / (1 + np.exp(-np.dot(x, beta))) pred = np.clip(pred, 1e-15, 1 - 1e-15) # 将预测值限制在一个很小的区间内 ObjVal = -np.sum(y * np.log(pred) + (1 - y) * np.log(1 - pred)) / n return ObjVal

好的,根据上面的目标函数,我们可以推导出其对应的梯度向量函数,如下所示: def gradient(x, y, beta): """ Compute gradient of the logistic regression loss function :param beta: model parameter vector :param x: feature matrix :param y: label vector :return: gradient vector """ n = x.shape[0] pred = 1 /
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。