电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

python gstreamer實現視頻快進/快退/循環播放功能

瀏覽:145日期:2022-07-31 16:09:28

Gstreamer到底是個啥?

GStreamer 是一個 基于pipeline的多媒體框架,基于GObject,以C語言寫成。

應用GStreamer這個這個多媒體框架,你可以寫出任意一種流媒體的應用來如:meidaplayer、音視頻編輯器、VOIP、流媒體服務器、音視頻編碼等等。

關于視頻快進/快退/循環播放的知識總結:

1.本地視頻時長獲取:

Gst.Pad.query_duration官方函數介紹:

def Gst.Pad.query_duration (self, format): #python wrapper for ’gst_pad_query_duration’Queries a pad for the total stream duration.Parameters:pad ( Gst.Pad ) ?a Gst.Pad to invoke the duration query on.format ( Gst.Format ) ?the Gst.Format requestedReturns a tuple made of:( gboolean ) ?TRUE (not introspectable) if the query could be performed.duration ( gint64 ) ?TRUE (not introspectable) if the query could be performed.

使用如下:

pipeline.query_duration(Gst.Format.TIME)[1]

其中pipeline為播放本地視頻的管道,query_duration()函數返回一個元組,元組的形式為[Ture,duration:******],******為以ns為單位的視頻時長。

2.視頻播放當前位置獲取:

Gst.Pad.query_position官方函數介紹:

def Gst.Pad.query_position (self, format): #python wrapper for ’gst_pad_query_position’Queries a pad for the stream position.Parameters:pad ( Gst.Pad ) ?a Gst.Pad to invoke the position query on.format ( Gst.Format ) ?the Gst.Format requestedReturns a tuple made of:( gboolean ) ?TRUE (not introspectable) if the query could be performed.cur ( gint64 ) ?TRUE (not introspectable) if the query could be performed.

使用方法與時長獲取函數query_duration()相同。

3.播放跳轉函數:

Gst.Element.seek_simple官方函數介紹:

def Gst.Element.seek_simple (self, format, seek_flags, seek_pos): #python wrapper for ’gst_element_seek_simple’ Parameters:element ( Gst.Element ) ?a Gst.Element to seek onformat ( Gst.Format ) ?a Gst.Format to execute the seek in, such as Gst.Format.TIMEseek_flags ( Gst.SeekFlags ) ?seek options; playback applications will usually want to use GST_SEEK_FLAG_FLUSH | GST_SEEK_FLAG_KEY_UNIT hereseek_pos ( gint64 ) ?position to seek to (relative to the start); if you are doing a seek in Gst.Format.TIME this value is in nanoseconds - multiply with Gst.SECOND to convert seconds to nanoseconds or with Gst.MSECOND to convert milliseconds to nanoseconds.Returns ( gboolean ) :TRUE (not introspectable) if the seek operation succeeded. Flushing seeks will trigger a preroll, which will emit Gst.MessageType.ASYNC_DONE.

函數使用樣例:

pipeline.seek_simple(Gst.Format.TIME, Gst.SeekFlags.FLUSH, time)

其中time的單位為nanoseconds。

有視頻快進/快退/循環播放功能的小播放器.

import os, _thread, timeimport gigi.require_version('Gst', '1.0')gi.require_version(’Gtk’, ’3.0’)from gi.repository import Gst, GObject, Gtk, Gdkclass GTK_Main: def __init__(self): window = Gtk.Window(Gtk.WindowType.TOPLEVEL) window.set_title('Vorbis-Player') window.set_default_size(500, -1) window.connect('destroy', Gtk.main_quit, 'WM destroy') vbox = Gtk.VBox() window.add(vbox) self.entry = Gtk.Entry() vbox.pack_start(self.entry, False, False, 0) hbox = Gtk.HBox() vbox.add(hbox) buttonbox = Gtk.HButtonBox() hbox.pack_start(buttonbox, False, False, 0) rewind_button = Gtk.Button('Rewind') rewind_button.connect('clicked', self.rewind_callback) buttonbox.add(rewind_button) self.button = Gtk.Button('Start') self.button.connect('clicked', self.start_stop) buttonbox.add(self.button) forward_button = Gtk.Button('Forward') forward_button.connect('clicked', self.forward_callback) buttonbox.add(forward_button) self.time_label = Gtk.Label() self.time_label.set_text('00:00 / 00:00') hbox.add(self.time_label) window.show_all() self.player = Gst.Pipeline.new('player') source = Gst.ElementFactory.make('filesrc', 'file-source') demuxer = Gst.ElementFactory.make('decodebin', 'demuxer') videoconv = Gst.ElementFactory.make('videoconvert', 'converter') videosink = Gst.ElementFactory.make('xvimagesink', 'video-output') demuxer.connect('pad-added', self.demuxer_callback, videoconv) for ele in [source, demuxer, videoconv, videosink]: self.player.add(ele) source.link(demuxer) videoconv.link(videosink) bus = self.player.get_bus() bus.add_signal_watch() bus.connect('message', self.on_message) def start_stop(self, w): if self.button.get_label() == 'Start': filepath = self.entry.get_text().strip() if os.path.isfile(filepath): filepath = os.path.realpath(filepath) self.button.set_label('Stop') self.player.get_by_name('file-source').set_property('location', filepath) self.player.set_state(Gst.State.PLAYING) self.play_thread_id = _thread.start_new_thread(self.play_thread, ()) else: self.play_thread_id = None self.player.set_state(Gst.State.NULL) self.button.set_label('Start') self.time_label.set_text('00:00 / 00:00') def play_thread(self): play_thread_id = self.play_thread_id Gdk.threads_enter() self.time_label.set_text('00:00 / 00:00') Gdk.threads_leave() print(play_thread_id) print(self.play_thread_id) while play_thread_id == self.play_thread_id: time.sleep(0.2) dur_int = self.player.query_duration(Gst.Format.TIME)[1] if dur_int == -1: continue dur_str = self.convert_ns(dur_int) Gdk.threads_enter() self.time_label.set_text('00:00 / ' + dur_str) Gdk.threads_leave() break time.sleep(0.2) while play_thread_id == self.play_thread_id: pos_int = self.player.query_position(Gst.Format.TIME)[1] pos_str = self.convert_ns(pos_int) if play_thread_id == self.play_thread_id: Gdk.threads_enter() self.time_label.set_text(pos_str + ' / ' + dur_str) Gdk.threads_leave() time.sleep(1) def on_message(self, bus, message): t = message.type if t == Gst.MessageType.EOS: self.player.seek_simple(Gst.Format.TIME, Gst.SeekFlags.FLUSH, 0000000000) elif t == Gst.MessageType.ERROR: err, debug = message.parse_error() print ('Error: %s' % err, debug) self.play_thread_id = None self.player.set_state(Gst.State.NULL) self.button.set_label('Start') self.time_label.set_text('00:00 / 00:00') def demuxer_callback(self, demuxer, pad, dst): caps = Gst.Pad.get_current_caps(pad) structure_name = caps.to_string() if structure_name.startswith('video'): videorate_pad = dst.get_static_pad('sink') pad.link(videorate_pad) def rewind_callback(self, w): rc, pos_int = self.player.query_position(Gst.Format.TIME) seek_ns = pos_int - 10 * 1000000000 if seek_ns < 0: seek_ns = 0 print (’Backward: %d ns -> %d ns’ % (pos_int, seek_ns)) self.player.seek_simple(Gst.Format.TIME, Gst.SeekFlags.FLUSH, seek_ns) def forward_callback(self, w): rc, pos_int = self.player.query_position(Gst.Format.TIME) seek_ns = pos_int + 10 * 1000000000 print (’Forward: %d ns -> %d ns’ % (pos_int, seek_ns)) self.player.seek_simple(Gst.Format.TIME, Gst.SeekFlags.FLUSH, seek_ns) def convert_ns(self, t): s,ns = divmod(t, 1000000000) m,s = divmod(s, 60) if m < 60: return '%02i:%02i' %(m,s) else: h,m = divmod(m, 60) return '%i:%02i:%02i' %(h,m,s)GObject.threads_init()Gst.init(None)GTK_Main()Gtk.main()

總結

到此這篇關于python gstreamer 實現視頻快進/快退/循環播放功能的文章就介紹到這了,更多相關python gstreamer 實現視頻快進/快退/循環播放內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 青海电动密集架_智能密集架_密集架价格-盛隆柜业青海档案密集架厂家 | 单螺旋速冻机-双螺旋-流态化-隧道式-食品速冻机厂家-广州冰泉制冷 | 电子万能试验机_液压拉力试验机_冲击疲劳试验机_材料试验机厂家-济南众标仪器设备有限公司 | PC阳光板-PC耐力板-阳光板雨棚-耐力板雨棚,厂家定制[优尼科板材] | 合肥卓创建筑装饰,专业办公室装饰、商业空间装修与设计。 | 德州网站开发定制-小程序开发制作-APP软件开发-「两山开发」 | 特种电缆厂家-硅橡胶耐高温电缆-耐低温补偿导线-安徽万邦特种电缆有限公司 | 变色龙PPT-国内原创PPT模板交易平台 - PPT贰零 - 西安聚讯网络科技有限公司 | 蜘蛛车-高空作业平台-升降机-高空作业车租赁-臂式伸缩臂叉装车-登高车出租厂家 - 普雷斯特机械设备(北京)有限公司 | 铝镁锰板厂家_进口钛锌板_铝镁锰波浪板_铝镁锰墙面板_铝镁锰屋面-杭州军晟金属建筑材料 | LNG鹤管_内浮盘价格,上装鹤管,装车撬厂家-连云港赛威特机械 | 越南专线物流_东莞国际物流_东南亚专线物流_行通物流 | 中直网_行业门户-行业人专业的交流平台!| 干式变压器厂_干式变压器厂家_scb11/scb13/scb10/scb14/scb18干式变压器生产厂家-山东科锐变压器有限公司 | 蔡司三坐标-影像测量机-3D扫描仪-蔡司显微镜-扫描电镜-工业CT-ZEISS授权代理商三本工业测量 | 电子厂招聘_工厂招聘_普工招聘_小时工招聘信息平台-众立方招工网 | 高效节能电机_伺服主轴电机_铜转子电机_交流感应伺服电机_图片_型号_江苏智马科技有限公司 | 数码听觉统合训练系统-儿童感觉-早期言语评估与训练系统-北京鑫泰盛世科技发展有限公司 | 档案密集架,移动密集架,手摇式密集架,吉林档案密集架-厂家直销★价格公道★质量保证 | 温州中研白癜风专科_温州治疗白癜风_温州治疗白癜风医院哪家好_温州哪里治疗白癜风 | 不锈钢钢格栅板_热浸锌钢格板_镀锌钢格栅板_钢格栅盖板-格美瑞 | 有声小说,听书,听小说资源库-听世界网| 大功率金属激光焊接机价格_不锈钢汽车配件|光纤自动激光焊接机设备-东莞市正信激光科技有限公司 定制奶茶纸杯_定制豆浆杯_广东纸杯厂_[绿保佳]一家专业生产纸杯碗的厂家 | 爱佩恒温恒湿测试箱|高低温实验箱|高低温冲击试验箱|冷热冲击试验箱-您身边的模拟环境试验设备技术专家-合作热线:400-6727-800-广东爱佩试验设备有限公司 | 高铝轻质保温砖_刚玉莫来石砖厂家_轻质耐火砖价格 | 塑料异型材_PVC异型材_封边条生产厂家_PC灯罩_防撞扶手_医院扶手价格_东莞市怡美塑胶制品有限公司 | 深圳宣传片制作-企业宣传视频制作-产品视频拍摄-产品动画制作-短视频拍摄制作公司 | 岩棉板|岩棉复合板|聚氨酯夹芯板|岩棉夹芯板|彩钢夹芯板-江苏恒海钢结构 | 国际船舶网 - 船厂、船舶、造船、船舶设备、航运及海洋工程等相关行业综合信息平台 | 食品机械专用传感器-落料放大器-低价接近开关-菲德自控技术(天津)有限公司 | 西点培训学校_法式西点培训班_西点师培训_西点蛋糕培训-广州烘趣西点烘焙培训学院 | 济南轻型钢结构/济南铁艺护栏/济南铁艺大门-济南燕翔铁艺制品有限公司 | 天长市晶耀仪表有限公司| 注浆压力变送器-高温熔体传感器-矿用压力传感器|ZHYQ朝辉 | 鹤壁创新仪器公司-全自动量热仪,定硫仪,煤炭测硫仪,灰熔点测定仪,快速自动测氢仪,工业分析仪,煤质化验仪器 | 智能气瓶柜(大型气瓶储存柜)百科| ERP企业管理系统永久免费版_在线ERP系统_OA办公_云版软件官网 | 连续密炼机_双转子连续密炼机_连续式密炼机-南京永睿机械制造有限公司 | 执业药师报名时间,报考条件,考试时间-首页入口 | 盘扣式脚手架-附着式升降脚手架-移动脚手架,专ye承包服务商 - 苏州安踏脚手架工程有限公司 | 北京开业庆典策划-年会活动策划公司-舞龙舞狮团大鼓表演-北京盛乾龙狮鼓乐礼仪庆典策划公司 |