CN114339316A - 一种基于视频直播的视频流编码处理方法 - Google Patents

一种基于视频直播的视频流编码处理方法 Download PDF

Info

Publication number
CN114339316A
CN114339316A CN202210023945.XA CN202210023945A CN114339316A CN 114339316 A CN114339316 A CN 114339316A CN 202210023945 A CN202210023945 A CN 202210023945A CN 114339316 A CN114339316 A CN 114339316A
Authority
CN
China
Prior art keywords
video
recorder
frame
encoder
encoded
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202210023945.XA
Other languages
English (en)
Inventor
陈江
王红梅
刘伟
李建华
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Easy Times Digital Technology Co ltd
Original Assignee
Beijing Easy Times Digital Technology Co ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Beijing Easy Times Digital Technology Co ltd filed Critical Beijing Easy Times Digital Technology Co ltd
Priority to CN202210023945.XA priority Critical patent/CN114339316A/zh
Publication of CN114339316A publication Critical patent/CN114339316A/zh
Pending legal-status Critical Current

Links

Images

Landscapes

  • Compression Or Coding Systems Of Tv Signals (AREA)
  • Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)

Abstract

本申请公开了一种基于视频直播的视频流编码处理方法,通过获取用户配置视频的编码信息,根据读取的视频编码配置信息创建编码器并初始化,之后根据读取的视频录制配置信息判断是否需要创建录制器,根据时间戳及关键帧信息计算是否编码或跳帧,进行视频编码,若配置了录制器,视频流推回流媒体服务器的时候,录制的视频文件也将同时存储与内容服务器中,编码结束时录制也将结束。本方案,有效的动态跳过关键帧,可以达到动态降低视频帧率,以保证视频能持续编码不中断,不影响客户端流畅播放,且支持编码过程中直接使用编码后的视频帧数据,无需单独转码,可以高分辨率视频场景的网络传输消耗。

Description

一种基于视频直播的视频流编码处理方法
技术领域
本申请涉及计算机应用技术领域,具体而言,涉及一种基于视频直播的视频流编码处理方法。
背景技术
现有的视频直播平台视频编码支持服务端转码,一路支持高分辨率原视频流转一路或多路4K分辨率以内视频分辨率视频流,且支持原视频流实时录制,录制的视频格式支持MP4、HLS、FLV,通过此方法,将直播视频流进行多分辨率编码以适应不同播放端网络带宽环境及不同硬件设备性能,以及直播活动结束后的视频回看。
市面上的视频编码服务能支持多分辨率、录制,由于编码过程中,高分辨率视频视频编码对硬件要求较高,且编码过程中对不同视频有不同硬件要求,编码过程中可能会出现编码性能不足导致视频流卡顿,最终导致视频编码停止工作,录制程序也可能会因为视频流不稳定导致工作不正常。
发明内容
本申请的主要目的在于提供一种基于视频直播的视频流编码处理方法,以改善相关技术中的问题。
为了实现上述目的,本申请提供了一种基于视频直播的视频流编码处理方法,具体包括以下几个步骤:
S1:获取用户配置视频的编码信息,根据读取的视频编码配置信息创建编码器并初始化,之后根据读取的视频录制配置信息判断是否需要创建录制器;
S101:通过流媒体服务获取推流设备所推的视频流,并初始化解码器开始拉流;
S2:取视频帧数据,根据时间戳及关键帧信息计算是否编码或跳帧,视频帧数据传入编码器,进行视频编码,若配置了录制器,复用编码后的帧数据放入录制器中;
S3:视频流推回流媒体服务器的时候,录制的视频文件也将同时存储与内容服务器中,编码结束时录制也将结束。
在本申请的一种实施例中,所述步骤S1中如果需要创建录制器则创建录制器并初始化,用户将在视频编码服务中配置编码视频的信息,视频编码服务启动编码流程后将读取编码配置信息及录制配置信息,并将初始化编码器和录制器。
在本申请的一种实施例中,所述步骤S101中服务将从配置信息中读取需要处理的视频流地址,并根据拉流地址初始化解码器从流媒体服务器拉取视频流。
在本申请的一种实施例中,所述步骤S2中,第一次编码前将创建时间戳和图像帧计数器,从解码器持续读取视频帧,结合时间戳和关键帧计算跳帧状态,将视频帧数据传入编码器,编码后的视频帧数据将被复用于录制器中,录制器只需要将视频帧数据转换为文件。
在本申请的一种实施例中,所述步骤S2中从视频解码器中解码一帧视频帧,此时将判断是否创建时间戳和编码图像帧计数器,如果没有创建则创建,之后根据编码图像帧计数器(fs)和视频GOP值进行计算是否需要跳帧,计算:fs%gop=gf,其中:编码图像帧计数器(fs):每次编码器编码图像帧或跳过图像帧都将自增1,视频GOP值:由编码信息中设置或取预设默认值,表示视频画面组大小,图像帧计数器自增1。
在本申请的一种实施例中,所述步骤S2中,根据视频解码帧时间戳(ft)、时间戳(t0)、计算结果(gf)判断是否需要跳帧,ft<t0且gf>0,其中,视频解码帧时间戳(ft):由原视频帧数据通过解码器解码过程得来,时间戳(t0):在第一次编码器准备编码时创建的一个系统时间戳。
在本申请的一种实施例中,所述步骤S3中视频编码器将编码后的视频流推回流媒体服务器,录制器将视频文件同步存储于内容服务器中,当编码器停止时录制器也将停止录制。
在本申请的一种实施例中,所述步骤S3中,如果配置了录制,则将视频编码器产生的视频帧数据传入录制器中,之后编码器将推送编码后的视频流到流媒体服务器,录制器将产生视频文件,视频文件将实时保存至内容服务器中,此流程结束后将继续重复从所述步骤S2向后的流程,直到解码器拉取视频流终止,编码器将停止推流和编码,录制器也将结束。
与现有技术相比,本申请的有益效果是:通过上述设计的基于视频直播的视频流编码处理方法,使用时,方法基于FFmpeg视频处理工具,在保证原视频流延时不增加的情况下,结合编码消耗时长,计算跳过非关键帧,从而实现动态插入I帧的效果;并且在编码过程中复用编码后的视频帧数据实现视频录制的能力,有效的动态跳过关键帧,可以达到动态降低视频帧率,以保证视频能持续编码不中断,不影响客户端流畅播放,且支持编码过程中直接使用编码后的视频帧数据,无需单独转码,可以高分辨率视频场景的网络传输消耗。
附图说明
图1为根据本申请实施例提供的基于视频直播的视频流编码处理方法的视频流编码服务工作流程示意图结构示意图;
图2为根据本申请实施例提供的基于视频直播的视频流编码处理方法的视频编码、录制主流程示意图结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本申请方案,下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分的实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本申请保护的范围。
需要说明的是,本申请的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本申请的实施例。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。
在本申请中,术语“上”、“下”、“左”、“右”、“前”、“后”、“顶”、“底”、“内”、“外”、“中”、“竖直”、“水平”、“横向”、“纵向”等指示的方位或位置关系为基于附图所示的方位或位置关系。这些术语主要是为了更好地描述本申请及其实施例,并非用于限定所指示的装置、元件或组成部分必须具有特定方位,或以特定方位进行构造和操作。
并且,上述部分术语除了可以用于表示方位或位置关系以外,还可能用于表示其他含义,例如术语“上”在某些情况下也可能用于表示某种依附关系或连接关系。对于本领域普通技术人员而言,可以根据具体情况理解这些术语在本申请中的具体含义。
另外,术语“多个”的含义应为两个以及两个以上。
需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。下面将参考附图并结合实施例来详细说明本申请。
实施例1
请参阅图1-图2,本申请提供了一种基于视频直播的视频流编码处理方法,具体包括以下几个步骤:
S1:获取用户配置视频的编码信息,根据读取的视频编码配置信息创建编码器并初始化,之后根据读取的视频录制配置信息判断是否需要创建录制器;
S101:通过流媒体服务获取推流设备所推的视频流,并初始化解码器开始拉流;
S2:取视频帧数据,根据时间戳及关键帧信息计算是否编码或跳帧,视频帧数据传入编码器,进行视频编码,若配置了录制器,复用编码后的帧数据放入录制器中;
S3:视频流推回流媒体服务器的时候,录制的视频文件也将同时存储与内容服务器中,编码结束时录制也将结束。
在本实施例中,所述步骤S1中如果需要创建录制器则创建录制器并初始化,之后用户将在视频编码服务中配置编码视频的信息,视频编码服务启动编码流程后将读取编码配置信息及录制配置信息,并将初始化编码器和录制器。
在本实施例中,所述步骤S101中服务将从配置信息中读取需要处理的视频流地址,并根据拉流地址初始化解码器从流媒体服务器拉取视频流。
在本实施例中,所述步骤S2中,第一次编码前将创建时间戳和图像帧计数器,从解码器持续读取视频帧,结合时间戳和关键帧计算跳帧状态,将视频帧数据传入编码器,编码后的视频帧数据将被复用于录制器中,录制器只需要将视频帧数据转换为文件,所述步骤S2中从视频解码器中解码一帧视频帧,此时将判断是否创建时间戳和编码图像帧计数器,如果没有创建则创建,之后根据编码图像帧计数器(fs)和视频GOP值进行计算是否需要跳帧,如果不需要跳帧,则将原视频帧数据传入编码器进行编码,计算方法:fs%gop=gf,其中:编码图像帧计数器(fs):每次编码器编码图像帧或跳过图像帧都将自增1,视频GOP值:由编码信息中设置或取预设默认值,表示视频画面组大小,图像帧计数器自增1,所述步骤S2中,根据视频解码帧时间戳(ft)、时间戳(t0)、计算结果(gf)判断是否需要跳帧,ft<to且gf>0,其中,视频解码帧时间戳(ft):由原视频帧数据通过解码器解码过程得来,时间戳(t0):在第一次编码器准备编码时创建的一个系统时间戳。
在本实施例中,所述步骤S3中视频编码器将编码后的视频流推回流媒体服务器,录制器将视频文件同步存储于内容服务器中,当编码器停止时录制器也将停止录制,具体实施时,如果配置了录制,则将视频编码器产生的视频帧数据传入录制器中,之后编码器将推送编码后的视频流到流媒体服务器,录制器将产生视频文件,视频文件将实时保存至内容服务器中,此流程结束后将继续重复从所述步骤S2向后的流程,直到解码器拉取视频流终止,编码器将停止推流和编码,录制器也将结束。
实施例2
请参阅图1-图2,本申请提供了一种基于视频直播的视频流编码处理方法,具体包括以下几个步骤:
S1:获取用户配置视频的编码信息,根据读取的视频编码配置信息创建编码器并初始化,之后根据读取的视频录制配置信息判断是否需要创建录制器;
S101:通过流媒体服务获取推流设备所推的视频流,并初始化解码器开始拉流;
S2:取视频帧数据,根据时间戳及关键帧信息计算是否编码或跳帧,视频帧数据传入编码器,进行视频编码,若配置了录制器,复用编码后的帧数据放入录制器中;
S3:视频流推回流媒体服务器的时候,录制的视频文件也将同时存储与内容服务器中,编码结束时录制也将结束。
在本实施例中,所述步骤S1中如果需要创建录制器则创建录制器并初始化,之后用户将在视频编码服务中配置编码视频的信息,视频编码服务启动编码流程后将读取编码配置信息及录制配置信息,并将初始化编码器和录制器。
在本实施例中,所述步骤S101中服务将从配置信息中读取需要处理的视频流地址,并根据拉流地址初始化解码器从流媒体服务器拉取视频流。
在本实施例中,所述步骤S2中,第一次编码前将创建时间戳和图像帧计数器,从解码器持续读取视频帧,结合时间戳和关键帧计算跳帧状态,将视频帧数据传入编码器,编码后的视频帧数据将被复用于录制器中,录制器只需要将视频帧数据转换为文件,所述步骤S2中从视频解码器中解码一帧视频帧,此时将判断是否创建时间戳和编码图像帧计数器,如果没有创建则创建,之后根据编码图像帧计数器(fs)和视频GOP值进行计算是否需要跳帧,如果需要跳帧,则直接结束。
实施例3
请参阅图1-图2,本申请提供了一种基于视频直播的视频流编码处理方法,具体包括以下几个步骤:
S1:获取用户配置视频的编码信息,根据读取的视频编码配置信息创建编码器并初始化,之后根据读取的视频录制配置信息判断是否需要创建录制器;
S101:通过流媒体服务获取推流设备所推的视频流,并初始化解码器开始拉流;
S2:取视频帧数据,根据时间戳及关键帧信息计算是否编码或跳帧,视频帧数据传入编码器,进行视频编码,若配置了录制器,复用编码后的帧数据放入录制器中;
S3:视频流推回流媒体服务器的时候,录制的视频文件也将同时存储与内容服务器中,编码结束时录制也将结束。
在本实施例中,所述步骤S1中如果需要创建录制器则创建录制器并初始化,之后用户将在视频编码服务中配置编码视频的信息,视频编码服务启动编码流程后将读取编码配置信息及录制配置信息,并将初始化编码器和录制器。
在本实施例中,所述步骤S101中服务将从配置信息中读取需要处理的视频流地址,并根据拉流地址初始化解码器从流媒体服务器拉取视频流。
在本实施例中,所述步骤S2中,第一次编码前将创建时间戳和图像帧计数器,从解码器持续读取视频帧,结合时间戳和关键帧计算跳帧状态,将视频帧数据传入编码器,编码后的视频帧数据将被复用于录制器中,录制器只需要将视频帧数据转换为文件,所述步骤S2中从视频解码器中解码一帧视频帧,此时将判断是否创建时间戳和编码图像帧计数器,如果没有创建则创建,之后根据编码图像帧计数器(fs)和视频GOP值进行计算是否需要跳帧,如果不需要跳帧,则将原视频帧数据传入编码器进行编码,计算方法:fs%gop=gf,其中:编码图像帧计数器(fs):每次编码器编码图像帧或跳过图像帧都将自增1,视频GOP值:由编码信息中设置或取预设默认值,表示视频画面组大小,图像帧计数器自增1,所述步骤S2中,根据视频解码帧时间戳(ft)、时间戳(t0)、计算结果(gf)判断是否需要跳帧,ft<t0且gf>0,其中,视频解码帧时间戳(ft):由原视频帧数据通过解码器解码过程得来,时间戳(t0):在第一次编码器准备编码时创建的一个系统时间戳。
在本实施例中,所述步骤S3中视频编码器将编码后的视频流推回流媒体服务器,录制器将视频文件同步存储于内容服务器中,当编码器停止时录制器也将停止录制,具体实施时,如果没有配置录制,则结束。
实施例4
请参阅图1-图2,本申请提供了一种基于视频直播的视频流编码处理方法,具体包括以下几个步骤:
S1:获取用户配置视频的编码信息,根据读取的视频编码配置信息创建编码器并初始化,之后根据读取的视频录制配置信息判断是否需要创建录制器;
S101:通过流媒体服务获取推流设备所推的视频流,并初始化解码器开始拉流;
S2:取视频帧数据,根据时间戳及关键帧信息计算是否编码或跳帧,视频帧数据传入编码器,进行视频编码,若配置了录制器,复用编码后的帧数据放入录制器中;
S3:视频流推回流媒体服务器的时候,录制的视频文件也将同时存储与内容服务器中,编码结束时录制也将结束。
在本实施例中,所述步骤S1中如果不需要创建录制器,则用户直接在视频编码服务中配置编码视频的信息,视频编码服务启动编码流程后将读取编码配置信息及录制配置信息,并将初始化编码器和录制器。
在本实施例中,所述步骤S101中服务将从配置信息中读取需要处理的视频流地址,并根据拉流地址初始化解码器从流媒体服务器拉取视频流。
在本实施例中,所述步骤S2中,第一次编码前将创建时间戳和图像帧计数器,从解码器持续读取视频帧,结合时间戳和关键帧计算跳帧状态,将视频帧数据传入编码器,编码后的视频帧数据将被复用于录制器中,录制器只需要将视频帧数据转换为文件,所述步骤S2中从视频解码器中解码一帧视频帧,此时将判断是否创建时间戳和编码图像帧计数器,如果没有创建则创建,之后根据编码图像帧计数器(fs)和视频GOP值进行计算是否需要跳帧,如果不需要跳帧,则将原视频帧数据传入编码器进行编码,计算方法:fs%gop=gf,其中:编码图像帧计数器(fs):每次编码器编码图像帧或跳过图像帧都将自增1,视频GOP值:由编码信息中设置或取预设默认值,表示视频画面组大小,图像帧计数器自增1,所述步骤S2中,根据视频解码帧时间戳(ft)、时间戳(t0)、计算结果(gf)判断是否需要跳帧,ft<t0且gf>0,其中,视频解码帧时间戳(ft):由原视频帧数据通过解码器解码过程得来,时间戳(t0):在第一次编码器准备编码时创建的一个系统时间戳。
在本实施例中,所述步骤S3中视频编码器将编码后的视频流推回流媒体服务器,录制器将视频文件同步存储于内容服务器中,当编码器停止时录制器也将停止录制,具体实施时,如果配置了录制,则将视频编码器产生的视频帧数据传入录制器中,之后编码器将推送编码后的视频流到流媒体服务器,录制器将产生视频文件,视频文件将实时保存至内容服务器中,此流程结束后将继续重复从所述步骤S2向后的流程,直到解码器拉取视频流终止,编码器将停止推流和编码,录制器也将结束。
实施例5
请参阅图1-图2,本申请提供了一种基于视频直播的视频流编码处理方法,具体包括以下几个步骤:
S1:获取用户配置视频的编码信息,根据读取的视频编码配置信息创建编码器并初始化,之后根据读取的视频录制配置信息判断是否需要创建录制器;
S101:通过流媒体服务获取推流设备所推的视频流,并初始化解码器开始拉流;
S2:取视频帧数据,根据时间戳及关键帧信息计算是否编码或跳帧,视频帧数据传入编码器,进行视频编码,若配置了录制器,复用编码后的帧数据放入录制器中;
S3:视频流推回流媒体服务器的时候,录制的视频文件也将同时存储与内容服务器中,编码结束时录制也将结束。
在本实施例中,所述步骤S1中如果不需要创建录制器,则用户直接在视频编码服务中配置编码视频的信息,视频编码服务启动编码流程后将读取编码配置信息及录制配置信息,并将初始化编码器和录制器。
在本实施例中,所述步骤S101中服务将从配置信息中读取需要处理的视频流地址,并根据拉流地址初始化解码器从流媒体服务器拉取视频流。
在本实施例中,所述步骤S2中,第一次编码前将创建时间戳和图像帧计数器,从解码器持续读取视频帧,结合时间戳和关键帧计算跳帧状态,将视频帧数据传入编码器,编码后的视频帧数据将被复用于录制器中,录制器只需要将视频帧数据转换为文件,所述步骤S2中从视频解码器中解码一帧视频帧,此时将判断是否创建时间戳和编码图像帧计数器,如果没有创建则创建,之后根据编码图像帧计数器(fs)和视频GOP值进行计算是否需要跳帧,在本实施例中,所述步骤S101中服务将从配置信息中读取需要处理的视频流地址,并根据拉流地址初始化解码器从流媒体服务器拉取视频流。
在本实施例中,所述步骤S2中,第一次编码前将创建时间戳和图像帧计数器,从解码器持续读取视频帧,结合时间戳和关键帧计算跳帧状态,将视频帧数据传入编码器,编码后的视频帧数据将被复用于录制器中,录制器只需要将视频帧数据转换为文件,所述步骤S2中从视频解码器中解码一帧视频帧,此时将判断是否创建时间戳和编码图像帧计数器,如果没有创建则创建,之后根据编码图像帧计数器(fs)和视频GOP值进行计算是否需要跳帧,如果需要跳帧,则直接结束。
实施例6
请参阅图1-图2,本申请提供了一种基于视频直播的视频流编码处理方法,具体包括以下几个步骤:
S1:获取用户配置视频的编码信息,根据读取的视频编码配置信息创建编码器并初始化,之后根据读取的视频录制配置信息判断是否需要创建录制器;
S101:通过流媒体服务获取推流设备所推的视频流,并初始化解码器开始拉流;
S2:取视频帧数据,根据时间戳及关键帧信息计算是否编码或跳帧,视频帧数据传入编码器,进行视频编码,若配置了录制器,复用编码后的帧数据放入录制器中;
S3:视频流推回流媒体服务器的时候,录制的视频文件也将同时存储与内容服务器中,编码结束时录制也将结束。
在本实施例中,所述步骤S1中如果不需要创建录制器,则用户直接在视频编码服务中配置编码视频的信息,视频编码服务启动编码流程后将读取编码配置信息及录制配置信息,并将初始化编码器和录制器。
在本实施例中,所述步骤S101中服务将从配置信息中读取需要处理的视频流地址,并根据拉流地址初始化解码器从流媒体服务器拉取视频流。
在本实施例中,所述步骤S2中,第一次编码前将创建时间戳和图像帧计数器,从解码器持续读取视频帧,结合时间戳和关键帧计算跳帧状态,将视频帧数据传入编码器,编码后的视频帧数据将被复用于录制器中,录制器只需要将视频帧数据转换为文件,所述步骤S2中从视频解码器中解码一帧视频帧,此时将判断是否创建时间戳和编码图像帧计数器,如果没有创建则创建,之后根据编码图像帧计数器(fs)和视频GOP值进行计算是否需要跳帧,如果不需要跳帧,则将原视频帧数据传入编码器进行编码,计算方法:fs%gop=gf,其中:编码图像帧计数器(fs):每次编码器编码图像帧或跳过图像帧都将自增1,视频GOP值:由编码信息中设置或取预设默认值,表示视频画面组大小,图像帧计数器自增1,所述步骤S2中,根据视频解码帧时间戳(ft)、时间戳(t0)、计算结果(gf)判断是否需要跳帧,ft<to且gf>0,其中,视频解码帧时间戳(ft):由原视频帧数据通过解码器解码过程得来,时间戳(t0):在第一次编码器准备编码时创建的一个系统时间戳。
在本实施例中,所述步骤S3中视频编码器将编码后的视频流推回流媒体服务器,录制器将视频文件同步存储于内容服务器中,当编码器停止时录制器也将停止录制,具体实施时,如果没有配置录制,则结束。
具体的,该基于视频直播的视频流编码处理方法的工作原理:使用时,方法基于FFmpeg视频处理工具,在保证原视频流延时不增加的情况下,结合编码消耗时长,计算跳过非关键帧,从而实现动态插入I帧的效果;并且在编码过程中复用编码后的视频帧数据实现视频录制的能力,有效的动态跳过关键帧,可以达到动态降低视频帧率,以保证视频能持续编码不中断,不影响客户端流畅播放,且支持编码过程中直接使用编码后的视频帧数据,无需单独转码,可以高分辨率视频场景的网络传输消耗。
以上所述仅为本申请的优选实施例而已,并不用于限制本申请,对于本领域的技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本申请的保护范围之内。

Claims (8)

1.一种基于视频直播的视频流编码处理方法,其特征在于,具体包括以下几个步骤:
S1:获取用户配置视频的编码信息,根据读取的视频编码配置信息创建编码器并初始化,之后根据读取的视频录制配置信息判断是否需要创建录制器;
S101:通过流媒体服务获取推流设备所推的视频流,并初始化解码器开始拉流;
S2:取视频帧数据,根据时间戳及关键帧信息计算是否编码或跳帧,视频帧数据传入编码器,进行视频编码,若配置了录制器,复用编码后的帧数据放入录制器中;
S3:视频流推回流媒体服务器的时候,录制的视频文件也将同时存储与内容服务器中,编码结束时录制也将结束。
2.如权利要求1所述的一种基于视频直播的视频流编码处理方法,其特征在于,所述步骤S1中如果需要创建录制器则创建录制器并初始化,用户将在视频编码服务中配置编码视频的信息,视频编码服务启动编码流程后将读取编码配置信息及录制配置信息,并将初始化编码器和录制器。
3.如权利要求1所述的一种基于视频直播的视频流编码处理方法,其特征在于,所述步骤S101中服务将从配置信息中读取需要处理的视频流地址,并根据拉流地址初始化解码器从流媒体服务器拉取视频流。
4.如权利要求1所述的一种基于视频直播的视频流编码处理方法,其特征在于,所述步骤S2中,第一次编码前将创建时间戳和图像帧计数器,从解码器持续读取视频帧,结合时间戳和关键帧计算跳帧状态,将视频帧数据传入编码器,编码后的视频帧数据将被复用于录制器中,录制器只需要将视频帧数据转换为文件。
5.如权利要求1所述的一种基于视频直播的视频流编码处理方法,其特征在于,所述步骤S2中从视频解码器中解码一帧视频帧,此时将判断是否创建时间戳和编码图像帧计数器,如果没有创建则创建,之后根据编码图像帧计数器(fs)和视频GOP值进行计算是否需要跳帧,计算:fs%gop=gf,其中:编码图像帧计数器(fs):每次编码器编码图像帧或跳过图像帧都将自增1,视频GOP值:由编码信息中设置或取预设默认值,表示视频画面组大小,图像帧计数器自增1。
6.如权利要求1所述的一种基于视频直播的视频流编码处理方法,其特征在于,所述步骤S2中,根据视频解码帧时间戳(ft)、时间戳(t0)、计算结果(gf)判断是否需要跳帧,ft<t0且gf>0,其中,视频解码帧时间戳(ft):由原视频帧数据通过解码器解码过程得来,时间戳(t0):在第一次编码器准备编码时创建的一个系统时间戳。
7.如权利要求1所述的一种基于视频直播的视频流编码处理方法,其特征在于,所述步骤S3中视频编码器将编码后的视频流推回流媒体服务器,录制器将视频文件同步存储于内容服务器中,当编码器停止时录制器也将停止录制。
8.如权利要求1所述的一种基于视频直播的视频流编码处理方法,其特征在于,所述步骤S3中,如果配置了录制,则将视频编码器产生的视频帧数据传入录制器中,之后编码器将推送编码后的视频流到流媒体服务器,录制器将产生视频文件,视频文件将实时保存至内容服务器中,此流程结束后将继续重复从所述步骤S2向后的流程,直到解码器拉取视频流终止,编码器将停止推流和编码,录制器也将结束。
CN202210023945.XA 2022-01-11 2022-01-11 一种基于视频直播的视频流编码处理方法 Pending CN114339316A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202210023945.XA CN114339316A (zh) 2022-01-11 2022-01-11 一种基于视频直播的视频流编码处理方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202210023945.XA CN114339316A (zh) 2022-01-11 2022-01-11 一种基于视频直播的视频流编码处理方法

Publications (1)

Publication Number Publication Date
CN114339316A true CN114339316A (zh) 2022-04-12

Family

ID=81026468

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202210023945.XA Pending CN114339316A (zh) 2022-01-11 2022-01-11 一种基于视频直播的视频流编码处理方法

Country Status (1)

Country Link
CN (1) CN114339316A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117579820A (zh) * 2024-01-15 2024-02-20 腾讯科技(深圳)有限公司 编码参数确定方法、装置、电子设备以及存储介质

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108377399A (zh) * 2018-03-07 2018-08-07 广州图普网络科技有限公司 实时视频流转码方法、装置及计算机可读存储介质
WO2019218415A1 (zh) * 2018-05-18 2019-11-21 网宿科技股份有限公司 一种音视频流的转码方法及设备
CN112822503A (zh) * 2020-12-30 2021-05-18 腾讯科技(深圳)有限公司 直播视频流的播放方法、装置、设备及存储介质

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108377399A (zh) * 2018-03-07 2018-08-07 广州图普网络科技有限公司 实时视频流转码方法、装置及计算机可读存储介质
WO2019218415A1 (zh) * 2018-05-18 2019-11-21 网宿科技股份有限公司 一种音视频流的转码方法及设备
CN112822503A (zh) * 2020-12-30 2021-05-18 腾讯科技(深圳)有限公司 直播视频流的播放方法、装置、设备及存储介质

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117579820A (zh) * 2024-01-15 2024-02-20 腾讯科技(深圳)有限公司 编码参数确定方法、装置、电子设备以及存储介质
CN117579820B (zh) * 2024-01-15 2024-05-10 腾讯科技(深圳)有限公司 编码参数确定方法、装置、电子设备以及存储介质

Similar Documents

Publication Publication Date Title
US7835439B2 (en) Video compression system
US6989868B2 (en) Method of converting format of encoded video data and apparatus therefor
US7610605B2 (en) Method and apparatus for conversion and distribution of data utilizing trick-play requests and meta-data information
KR100557103B1 (ko) 데이터 처리방법 및 데이터 처리장치
TWI606722B (zh) 用於減少視訊編碼及解碼中之延遲的方法、系統及電腦可讀取媒體
KR102317938B1 (ko) 타일 기반 스트리밍을 위한 분할영상 분산 디코딩 방법 및 시스템
TWI407796B (zh) An image signal decoding apparatus, an image signal decoding method, an image signal coding apparatus, an image signal coding method, and a program
JPH09139677A (ja) 符号化された信号をスプライシングする方法及び装置
CN101193311B (zh) 一种p2p系统中音视频数据的同步方法
KR20010022752A (ko) 디지털 비디오 레코더용 트릭 플레이 신호 발생
US20060239563A1 (en) Method and device for compressed domain video editing
EP1553779A1 (en) Data reduction of video streams by selection of frames and partial deletion of transform coefficients
TW201238356A (en) Adaptive bit rate control based on scenes
KR20030015950A (ko) 영상 압축 비트 스트림의 트랜스코딩 방법
JPH0884333A (ja) 符号化されたビデオ信号をスプライシングする方法
JP4294933B2 (ja) マルチメディアコンテンツ編集装置およびマルチメディアコンテンツ再生装置
CN101827262B (zh) 解码设备和方法
US20190373213A1 (en) Information processing device and method
US20090328096A1 (en) Preconditioning ad content for digital program insertion
US6940901B2 (en) Apparatus and method for information processing
FI105634B (fi) Menetelmä videokuvien siirtämiseksi, tiedonsiirtojärjestelmä ja multimediapäätelaite
CN114339316A (zh) 一种基于视频直播的视频流编码处理方法
KR20100127237A (ko) 콘텐츠 데이터를 제공하는 장치 및 방법
JP4491918B2 (ja) データ配信装置及び方法、データ配信システム
JP5472094B2 (ja) 動画像変換装置、動画像配信システム、動画像変換方法及びプログラム

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
WD01 Invention patent application deemed withdrawn after publication

Application publication date: 20220412

WD01 Invention patent application deemed withdrawn after publication