CN111526387B - 一种视频处理方法、装置、电子设备及存储介质 - Google Patents

一种视频处理方法、装置、电子设备及存储介质 Download PDF

Info

Publication number
CN111526387B
CN111526387B CN202010239641.8A CN202010239641A CN111526387B CN 111526387 B CN111526387 B CN 111526387B CN 202010239641 A CN202010239641 A CN 202010239641A CN 111526387 B CN111526387 B CN 111526387B
Authority
CN
China
Prior art keywords
video
key frame
target
address
video data
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.)
Active
Application number
CN202010239641.8A
Other languages
English (en)
Other versions
CN111526387A (zh
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 Dajia Internet Information Technology Co Ltd
Original Assignee
Beijing Dajia Internet Information 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 Dajia Internet Information Technology Co Ltd filed Critical Beijing Dajia Internet Information Technology Co Ltd
Priority to CN202010239641.8A priority Critical patent/CN111526387B/zh
Publication of CN111526387A publication Critical patent/CN111526387A/zh
Application granted granted Critical
Publication of CN111526387B publication Critical patent/CN111526387B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/234Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
    • H04N21/2343Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements
    • H04N21/234309Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements by transcoding between formats or standards, e.g. from MPEG-2 to MPEG-4 or from Quicktime to Realvideo
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/234Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
    • H04N21/23418Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving operations for analysing video streams, e.g. detecting features or characteristics
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/239Interfacing the upstream path of the transmission network, e.g. prioritizing client content requests
    • H04N21/2393Interfacing the upstream path of the transmission network, e.g. prioritizing client content requests involving handling client requests
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/27Server based end-user applications
    • H04N21/274Storing end-user multimedia data in response to end-user request, e.g. network recorder
    • H04N21/2747Remote storage of video programs received via the downstream path, e.g. from the server
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/80Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
    • H04N21/85Assembly of content; Generation of multimedia applications
    • H04N21/854Content authoring
    • H04N21/8547Content authoring involving timestamps for synchronizing content

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)

Abstract

本公开关于一种视频处理方法、装置、电子设备及存储介质,应用于网络技术领域,所述方法包括:接收客户端发送的视频获取请求,所述视频获取请求至少包括:第一视频地址、目标关键帧位置,目标关键帧位置是预先从第一视频数据获取的;根据所述第一视频地址获取所述第一视频数据;从所述第一视频数据的所述目标关键帧位置开始进行视频编码格式转换,得到目标视频编码格式的第二视频数据,所述目标视频编码格式是所述客户端支持的类型;返回所述第二视频数据。根据本公开的方案,服务器将客户端不支持视频编码格式的视频数据从用户指定的关键帧位置开始解析和转码,实现了客户端对不支持视频编码格式的视频数据的播放位置的控制,提高了用户体验。

Description

一种视频处理方法、装置、电子设备及存储介质
技术领域
本公开属于网络技术领域,特别是涉及一种视频处理方法、装置、电子设备及存储介质。
背景技术
网络直播、视频点播已成为人们日常生活中的主要娱乐方式,由于视频原数据的数据量过大,不适用于直接进行网络传输,服务提供商往往需要使用特定标准对视频数据进行编码压缩。
现有技术中,客户端在播放视频时,必须先解析视频内容数据,从而获取该视频内容数据的元数据,再从该元数据中获取该视频内容数据的关键帧的相关信息。该关键帧的相关信息可以用于在用户对客户端所播放视频进行控制操作时,确定与该控制操作相对应的关键帧的相关信息,从而调整视频数据内容的播放时间点,以实现对视频内容数据的播放控制。
这种方式由于依赖于客户端需要能够对视频数据进行解析,因此在所需播放视频内容数据的视频编码格式是该客户端不支持的,则无法实现针对该视频数据的控制操作,影响用户体验。
发明内容
本公开提供一种视频处理方法、装置、电子设备及存储介质,以至少解决相关技术中客户端无法对不支持视频编码格式的视频数据进行控制的问题。
本公开的技术方案如下:
根据本公开实施例的第一方面,提供一种视频处理方法,所述方法应用于服务器,所述方法包括:
接收客户端发送的视频获取请求,所述视频获取请求至少包括:第一视频地址、目标关键帧位置,所述目标关键帧位置是预先从第一视频数据获取的;
根据所述第一视频地址获取所述第一视频数据;
从所述第一视频数据的所述目标关键帧位置开始进行视频编码格式转换,得到目标视频编码格式的第二视频数据,所述目标视频编码格式是所述客户端支持的类型;
返回所述第二视频数据。
可选的,在所述接收客户端发送的视频获取请求的步骤之前,还包括:
接收客户端发送的视频转码请求,所述视频转码请求至少包括:原视频地址、目标视频编码格式;
根据所述原视频地址获取第一视频数据;
解析所述第一视频数据的元数据,获取关键帧位置;
根据所述目标视频编码格式、原视频地址生成相对应的第一视频地址;
将所述关键帧位置、所述第一视频地址返回至所述客户端。
可选的,所述根据所述第一视频地址获取第一视频数据的步骤,包括:
根据所述第一视频地址查询相对应的原视频地址;
从所述原视频地址获取第一视频数据。
可选的,所述视频转码请求还包括:预设封装格式,所述得到目标视频编码格式的第二视频数据的步骤,包括:
将按照所述目标视频编码格式转换后的第一视频数据按照预设封装格式进行封装,得到第二视频数据,所述预设封装格式是所述客户端支持的类型。
根据本公开实施例的第二方面,提供另一种视频处理方法,所述方法应用于客户端,所述方法包括:
接收播放控制指令,所述播放控制指令至少包括:目标时间点、第一视频地址;
从与所述第一视频地址相对应的关键帧时间戳中,确定与所述目标时间点距离最近的目标关键帧时间戳;
确定与所述目标关键帧时间戳相对应的目标关键帧位置;
向所述服务器发送视频获取请求,所述视频获取请求至少包括:所述目标关键帧位置、第一视频地址;
接收所述服务器根据所述目标关键帧位置及第一视频地址,返回的第二视频数据;
在所述第二视频数据所对应的关键帧时间戳大于或等于所述目标时间点的情况下,播放所述第二视频数据。
可选的,在所述接收播放控制指令的步骤之前,还包括:
接收视频播放指令,所述视频播放指令包括:第一视频数据的原视频地址;
在预设视频编码格式集合中不存在所述第一视频数据对应的视频编码格式的情况下,向所述服务器发送视频转码请求,所述视频转码请求至少包括:所述原视频地址、目标视频编码格式;
接收所述服务器根据所述原视频地址及目标视频编码格式,返回的关键帧信息及第一视频地址,所述关键帧信息至少包括关键帧时间戳及相对应的关键帧位置。
可选的,所述视频转码请求还包括:预设封装格式,所述播放所述第二视频数据的步骤,包括:
根据所述预设封装格式对所述第二视频数据进行解封装,并将解封后的第二视频数据进行播放,所述预设封装格式是所述客户端支持的类型。
根据本公开实施例的第三方面,提供一种视频处理装置,所述装置应用于服务器,所述服务器与客户端通信连接,所述装置包括:
第一接收模块,被配置为接收客户端发送的视频获取请求,所述视频获取请求至少包括:第一视频地址、目标关键帧位置,所述目标关键帧位置是预先从第一视频数据获取的;
第一获取模块,被配置为根据所述第一视频地址获取所述第一视频数据;
转码模块,被配置为从所述第一视频数据的所述目标关键帧位置开始进行视频编码格式转换,得到目标视频编码格式的第二视频数据,所述目标视频编码格式是所述客户端支持的类型;
第一返回模块,被配置为返回所述第二视频数据。
可选的,所述装置,还包括:
第二接收模块,被配置为接收客户端发送的视频转码请求,所述视频转码请求至少包括:原视频地址、目标视频编码格式;
第二获取模块,被配置为根据所述原视频地址获取第一视频数据;
解析模块,被配置为解析所述第一视频数据的元数据,获取关键帧位置;
第一生成模块,被配置为根据所述目标视频编码格式、原视频地址生成相对应的第一视频地址;
第二返回模块,被配置为将所述关键帧位置、所述第一视频地址返回至所述客户端。
可选的,所述第一获取模块,还被配置为:
根据所述第一视频地址查询相对应的原视频地址;
从所述原视频地址获取第一视频数据。
可选的,所述视频转码请求还包括:预设封装格式,所述转码模块613,还被配置为:将按照所述目标视频编码格式转换后的第一视频数据按照预设封装格式进行封装,得到第二视频数据,所述预设封装格式是所述客户端支持的类型。
根据本公开实施例的第四方面,提供另一种视频处理装置,所述装置应用于客户端,所述客户端与服务器通信连接,所述装置包括:
第三接收模块,被配置为接收播放控制指令,所述播放控制指令至少包括:目标时间点、第一视频地址;
第一确定模块,被配置为从与所述第一视频地址相对应的关键帧时间戳中,确定与所述目标时间点距离最近的目标关键帧时间戳;
第二确定模块,被配置为确定与所述目标关键帧时间戳相对应的目标关键帧位置;
第一发送模块,被配置为向所述服务器发送视频获取请求,所述视频获取请求至少包括:所述目标关键帧位置、第一视频地址;
第四接收模块,被配置为接收所述服务器根据所述目标关键帧位置及第一视频地址,返回的第二视频数据;
播放模块,被配置为在所述第二视频数据所对应的关键帧时间戳大于或等于所述目标时间点的情况下,播放所述第二视频数据。
可选的,所述装置,还包括:
第五接收模块,被配置为接收视频播放指令,所述视频播放指令包括:第一视频数据的原视频地址;
第二发送模块,被配置为在预设视频编码格式集合中不存在所述第一视频数据对应的视频编码格式的情况下,向所述服务器发送视频转码请求,所述视频转码请求至少包括:所述原视频地址、目标视频编码格式;
第六接收模块,被配置为接收所述服务器根据所述原视频地址及目标视频编码格式,返回的关键帧信息及第一视频地址,所述关键帧信息至少包括关键帧时间戳及相对应的关键帧位置。
可选的,所述视频转码请求还包括:预设封装格式,所述播放模块,还被配置为:根据所述预设封装格式对所述第二视频数据进行解封装,并将解封后的第二视频数据进行播放,所述预设封装格式是所述客户端支持的类型。
根据本公开实施例的第五方面,提供一种电子设备,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现上述第一、二方面中任一所述的视频处理方法。
根据本公开实施例的第六方面,提供一种计算机可读存储介质,所述计算机可读存储介质上存储计算机程序,所述计算机程序被处理器执行时实现上述第一、二方面中任一所述的视频处理方法。
根据本公开实施例的第七方面,提供一种计算机程序产品,包括一条或多条指令,该一条或多条指令可以由电子设备的处理器执行时,使得电子设备能够执行第一、二方面中任一所述的视频处理方法。
本公开的实施例提供的技术方案至少带来以下有益效果:
本公开实施例中提供一种视频处理的方法、装置、电子设备及装置,通过服务器对客户端不支持视频编码格式的视频数据进行解析并获得关键帧位置,以使得客户端根据该关键帧位置确定需要播放的目标关键帧位置,从而服务器根据该目标关键帧位置向客户端返回转码后的视频数据,实现了客户端对不支持视频编码格式的视频数据的播放控制,提高了用户体验。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起被配置为解释本公开的原理,并不构成对本公开的不当限定。
图1是根据一示例性实施例示出的第一种视频处理方法的流程图;
图2是根据一示例性实施例示出的第一种视频处理方法的数据传输流程图;
图3是根据一示例性实施例示出的第二种视频处理方法的流程图;
图4是根据一示例性实施例示出的第二种视频处理方法的数据传输流程图;
图5是根据一示例性实施例示出的第三种视频处理方法的流程图;
图6是根据一示例性实施例示出的第四种视频处理方法的流程图;
图7是根据一示例性实施例示出的一种视频处理方法的交互步骤流程图;
图8是根据一示例性实施例示出的第一种视频处理系统的框图;
图9是根据一示例性实施例示出的一种电子设备的结构框图。
具体实施方式
为了使本领域普通人员更好地理解本公开的技术方案,下面将结合附图,对本公开实施例中的技术方案进行清楚、完整地描述。
需要说明的是,本公开的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是被配置为区别类似的对象,而不必被配置为描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本公开的实施例能够以除了在这里图示或描述的那些以外的顺序实施。以下示例性实施例中所描述的实施方式并不代表与本公开相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本公开的一些方面相一致的装置和方法的例子。
图1是本公开实施例提供的第一种视频处理方法的步骤流程图,所述方法应用于服务器,所述服务器与客户端通信连接,所述方法包括:
步骤101,接收客户端发送的视频获取请求,所述视频获取请求至少包括:第一视频地址、目标关键帧位置,所述目标关键帧位置是预先从第一视频数据获取的。
在本公开实施例中,用户通过其电子设备上的客户端观看直播视频的时候,若其客户端所获取的直播视频数据的视频编码格式是其不支持的视频编码格式,可将直播视频数据的原视频地址发送至所连接的服务器,服务器将从原视频地址获取第一视频数据的元数据,该元数据用于描述视频文件的多媒体信息,包括:视频流信息,例如视频宽高、视频编码格式、所有关键帧的关键帧位置及相对应的关键帧时间戳等;音频流信息,例如:音频数据编码格式、采样率、声道数等。服务器将从所述第一视频数据的元数据中提取关键帧位置及相对应的关键帧时间戳返回给客户端存储,并开始从第一视频数据的起始位置或者默认位置按照所述客户端所支持的目标视频编码格式开始转码,并将转码后的第一视频数据返回给客户端,以供客户端通过播放窗口开始播放第一视频数据。
若用户在客户端播放第一视频数据的过程中控制客户端调整播放的时间点,客户端将根据时间点从关键帧时间戳中确定与其距离最近目标关键帧时间戳,并从关键帧位置中确定相对应的目标关键帧位置,然后根据该直播视频的第一视频地址,向服务器发送包含目标关键帧位置的视频获取请求。
步骤102,根据所述第一视频地址获取所述第一视频数据。
在本公开实施例中,服务器在获取到客户端发送的视频获取请求的情况下,提取该视频获取请求中的第一视频地址,确定用户所需进行播放的第一视频数据。此处需要注意,第一视频地址是所述服务器提供给客户端用于获取第一视频数据转码后数据的地址,并不是第一视频数据的原视频地址。服务器在用户首次请求播放该第一视频数据时,根据其所支持的目标视频编码格式生成有与所述原视频地址相对应的视频转码配置,并根据视频转码配置生成相对应的第一视频地址。因此服务器提取到第一视频地址时,是通过查询相对应的视频转码配置来确定原视频地址,然后从该原视频地址中获取第一视频数据。
步骤103,从所述第一视频数据的所述目标关键帧位置开始进行视频编码格式转换,得到目标视频编码格式的第二视频数据,所述目标视频编码格式是所述客户端支持的类型。
在本公开实施例中,服务器通过所述目标关键帧位置确定所需进行转码的视频数据在所述第一视频数据中存储位置,并从该目标关键帧位置开始对所述第一视频数据进行转码,得到目标视频编码格式的第二视频数据。由于该第一视频数据是直播视频类型,因此该转码过程是一个动态的过程,所述第一视频数据的数据量将持续变化,而服务器也将持续对该第一视频数据进行转码。
目标视频编码格式可以是服务器根据所述客户端的类型和第一视频数据的规格参数确定的,也可以是用户通过客户端根据不同格式的第一视频数据的转码需求在服务器进行设置的,可以理解,客户端支持的视频编码格式不一定只有一种,具体选取哪个视频编码格式作为所述第一视频数据的目标视频编码格式,可以根据用户对不同视频编码格式的需求自行设置,此处不做限定。
步骤104,返回所述第二视频数据。
在本公开实施例中,由于第一视频数据为直播视频类型,因此服务器可持续返回转码得到的第二视频数据,并且服务器在发送第二视频数据后会清除本地存储空间中已发送的第二视频数据。进一步的,服务器可以将所述第二视频数据上传至CDN(ContentDelivery Network,内容分发网络),而不再本地存储,由CDN负责数据的分发,从而提高客户端获取所述第二视频数据的效率。
在实际应用中,参照图2示出的第一种视频处理方法的数据传输流程图,客户端在接收到用户输入时间点后确定相对应的目标关键帧位置,并根据向服务器发送包含所述目标关键帧位置的视频获取请求,服务器可以将所述目标关键帧位置透传给转码服务器,然后转码服务器将第一视频数据从所述目标关键帧位置开始进行转码,并通过CDN将转码获得的第二视频数据转发给客户端。本公开实施例不仅通过转码服务器进行对视频数据进行转码,减轻了服务器的数据处理压力,并且通过CDN将第二视频数据转发给客户端,提高了客户端获取第二视频数据的效率。通过设置专门用于转码的转码服务器可以减轻服务器的数据处理压力,当然该转码服务器也可以为服务器中的虚拟终端,从而减轻服务器的硬件数据量,降低运维成本,具体可根据实际需求确定,此处不做限定
本公开的实施例提供的技术方案至少带来以下有益效果:
本公开实施例提供的第一种视频处理方法,应用于服务器,所述服务器与客户端通信连接,通过服务器对客户端不支持视频编码格式的视频数据进行解析并获得关键帧位置,以使得客户端根据该关键帧位置确定需要播放的目标关键帧位置,从而服务器根据该目标关键帧位置向客户端返回转码后的视频数据,实现了客户端对不支持视频编码格式的视频数据的播放位置的控制,提高了用户体验。
图3是本公开实施例提供的第二种视频处理方法的步骤流程图,所述方法应用于服务器,所述服务器与客户端通信连接,所述方法包括:
步骤201,接收客户端发送的视频转码请求,所述视频转码请求至少包括:原视频地址、目标视频编码格式。
在本公开实施例中,客户端在首次播放第一视频数据,若所述第一视频数据的视频编码格式是客户端不支持的视频编码格式,则会向所连接的服务器发送包含其所支持的目标视频编码格式、第一视频数据的原数据地址的视频转码请求。
若第一视频数据的视频编码格式是客户端支持的视频编码格式,客户端也可以本地从原视频地址获取第一视频数据进行解码然后进行播放。
步骤202,根据所述原视频地址获取第一视频数据。
在本公开实施例中,服务器从所述视频转码请求中提取原视频地址,并从所述原视频地址获取第一视频数据。
步骤203,解析所述第一视频数据的元数据,获取关键帧位置。
在本公开实施例中,由于第一视频数据为客户端不支持的视频编码类型,因此交由服务器通过解析第一视频数据,提取所述第一视频数据中的元数据,并从该元数据中提取第一视频数据的关键帧的相关信息,所述相关信息可以包括:关键帧位置、关键帧时间戳等信息。
步骤204,根据所述目标视频编码格式、原视频地址生成相对应的第一视频地址。
在本公开实施例中,服务器根据所述客户端支持的目标视频编码格式、原视频地址生成与所述第一视频数据相对应的视频编码配置,并生成与该视频编码配置相对应的第一视频地址,该第一视频地址用于客户端获取第一视频数据转码后的视频数据。
步骤205,将所述关键帧位置、所述第一视频地址返回至所述客户端。
在本公开实施例中,服务器将所包括关键帧位置的关键帧信息返回给客户端,供客户端后续对第一视频数据的播放位置进行控制。
本公开实施例在客户端需要对不支持视频编码格式的视频进行播放时,将所需播放的视频交由服务器进行解析,并由服务器提供所需播放视频的关键帧信息和客户端所支持目标视频编码格式的转码后的视频数据,从而实现了客户端对不支持视频编码格式的视频数据进行播放,提高了客户端播放视频数据的适用范围。
步骤206,接收客户端发送的视频获取请求,所述视频获取请求至少包括:第一视频地址、目标关键帧位置,所述目标关键帧位置是预先从第一视频数据获取的。
该步骤可参照步骤101的详细描述,此处不再赘述。
步骤207,根据所述第一视频地址查询相对应的原视频地址。
在本公开实施例中,给第一视频地址存在相对应的视频转码配置,因此可通过查询第一视频地址对应的转码配置获取所对应的原视频地址,而原视频地址是客户端首次播放该视频数据时,服务器预先记录在该视频转码配置的。
步骤208,从所述原视频地址获取第一视频数据。
在公开实施例中,所述第一视频数据为直播视频数据,因此服务器将会从所述原视频地址持续获取第一视频数据。
本公开实施例通过查询视频转码配置获取原视频地址,使得客户端在每次对视频的播放位置进行控制时,无需再重新放视频转码请求告知服务器原视频地址,仅需请求调整视频的播放位置即可,提高了视频播放控制的效率。
步骤209,从所述第一视频数据的所述目标关键帧位置开始进行视频编码格式转换,并将按照所述目标视频编码格式转换后的第一视频数据按照预设封装格式进行封装,得到第二视频数据,所述预设封装格式是所述客户端支持的类型,所述目标视频编码格式是所述客户端支持的类型。
在本公开实施例中,所述预设封装格式是指根据客户端所支持的流媒体协议确定的,可以是在客户端首次请求播放该第一视频数据时发送给服务器记录在视频转码配置里。从而在按照目标视频编码格式进行转码得到的视频数据进行报文封装,从而得到符合该流媒体传输协议的第二视频数据,例如:TCP(Transmission Control Protocol,传输控制协议)协议会将所需传输的第二视频数据按照预设数据量进行拆分,得到由若干个分包组成的第二视频数据,所述预设封装格式具体可根据不同流媒体协议确定,此处不做限定。
步骤210,返回所述第二视频数据。
该步骤可参照步骤104的详细描述,此处不再赘述。
在实际应用中,参照图4示出本公开的第二种视频处理方法的数据传输流程图,所述客户端通过CDN服务器获取第一视频数据,在第一视频数据的视频编码格式为客户端不支持的视频编码格式的情况下,客户端将所述第一视频数据的原视频地址及其支持的目标视频编码格式发送给服务器,服务器根据所述原视频地址及目标视频编码格式透传给转码服务器,转码服务器根据原视频地址获取并解析第一视频数据,得到第一视频数据的关键帧信息以及转码得到目标视频编码格式的第二视频数据,并将所述第二视频地址及关键帧信息返回给服务器,服务器再将所述第一视频地址及关键帧信息返回给客户端;客户端可以根据所述关键帧信息及第一视频地址,通过CDN服务器从转码服务器获取目标视频编码格式的第二视频数据。其中,转码服务器与服务器可以是同一服务器,也可以是不同的服务器,具体可根据服务器设备的性能和成本需求确定,此处不做具体限定。
本公开的实施例提供的技术方案至少带来以下有益效果:
本公开实施例提供的第二种视频处理方法,应用于服务器,所述服务器与客户端通信连接,通过服务器对客户端不支持视频编码格式的视频数据进行解析并获得关键帧位置,以使得客户端根据该关键帧位置确定需要播放的目标关键帧位置,从而服务器根据该目标关键帧位置向客户端返回转码后的视频数据,实现了客户端对不支持视频编码格式的视频数据的播放控制,提高了用户体验。并且服务器在客户端首次请求播放不支持编码格式的视频数据时,会生成记录原视频地址和目标视频编码格式的视频编码配置,从而在客户端进行播放位置的控制时,无需客户端重新发送原视频地址和目标视频编码格式,提高了客户端对不支持视频编码格式的视频进行播放控制的效率。
图5是本公开实施例提供的第三种视频处理方法的步骤流程图,所述方法应用于客户端,所述客户端与服务器通信连接,所述方法包括:
步骤301,接收播放控制指令,所述播放控制指令至少包括:目标时间点、第一视频地址。
在本公开实施例中,当用户在需要对第一视频数据的播放进行控制时,可在客户端的播放窗口中,通过点击视频播放进度条,选取将述第一视频的播放位置进行切换到的目标时间点,从而生成针对该第一视频数据的播放控制指令。
步骤302,从与所述第一视频地址相对应的关键帧时间戳中,确定与所述目标时间点距离最近的目标关键帧时间戳。
在本公开实施例中,由于用户选取的目标时间点不一定存在完全贴合的关键帧时间戳,因此客户端可以从该第一视频数据的关键帧时间点中,确定与所述第一视频的关键帧时间戳距离最近的目标关键帧时间戳,以使得视频播放位置的控制更加贴合用户需求。
步骤303,确定与所述目标关键帧时间戳相对应的目标关键帧位置。
在本公开实施例中,客户端从第一视频数据的关键帧位置中确定与目标关键帧时间戳相对应的目标关键帧位置。
步骤304,向所述服务器发送视频获取请求,所述视频获取请求至少包括:所述目标关键帧位置、第一视频地址。
在本公开实施例中,向服务器发送包含第一视频数据的关键帧位置、述第二视频数据的第一视频地址的的视频获取请求。由于目标关键帧时间戳仅用于供客户端确定所需视频数据的目标关键帧位置,因此视频获取请求无需包含关键帧时间戳。
步骤305,接收所述服务器根据所述目标关键帧位置及第一视频地址,返回的第二视频数据。
在本公开实施例中,服务器会响应于所述客户端的视频获取请求向客户端返回相对应的第二视频数据。所述第二视频数据是通过将第一视频数据从目标关键帧位置开始按照客户端支持的目标视频编码格式进行转换得到的。
步骤306,在所述第二视频数据所对应的关键帧时间戳大于或等于所述目标时间点的情况下,播放所述第二视频数据。
在本公开实施例中,为了保障客户端所播放第二视频数据的关键帧时间戳符合用户需求的,因此所述客户端在获取到第二视频数据后,会解析获取第二视频数据的关键帧时间戳,将第二视频数据所中所对应的关键帧时间戳大于或等于用户指定的目标时间点的视频数据进行播放。
本公开的实施例提供的技术方案至少带来以下有益效果:
本公开实施例提供的第三种视频处理方法,应用于客户端,所述客户端与服务器通信连接,通过服务器对客户端不支持视频编码格式的视频数据进行解析并获得关键帧位置,以使得客户端根据该关键帧位置确定需要播放的目标关键帧位置,从而服务器根据该目标关键帧位置向客户端返回转码后的视频数据,实现了客户端对不支持视频编码格式的视频数据的播放控制,提高了用户体验。
图6是本公开实施例提供的第四种视频处理方法的步骤流程图,所述方法应用于客户端,所述客户端与服务器通信连接,所述方法包括:
步骤401,接收视频播放指令,所述视频播放指令包括:第一视频数据的原视频地址。
在本公开实施例中,当用户首次需要对第一视频数据进行播放时,可通过点击客户端的的视频列表展示界面,点击选取第一视频数据所对应的视频标识,确定与视频标识所对应的原视频地址,从而生成包含原视频地址的视频播放指令。
步骤402,在预设视频编码格式集合中不存在所述第一视频数据对应的视频编码格式的情况下,向所述服务器发送视频转码请求,所述视频转码请求至少包括:所述原视频地址、目标视频编码格式。
在本公开实施例中,客户端在接收到视频播放指令时,从原视频地址获取第一视频数据,并确定所述第一视频数据的视频编码格式。若第一视频数据的视频编码格式是客户端不支持的视频编码格式,则根据户端支持的目标视频编码格式以及原视频地址生成视频转码请求,向服务器发送所述视频转码请求,以使得服务器对所述第一视频数据进行解析。
当然,若所述第一视频数据的视频编码格式是客户端支持的视频编码格式,客户端可以本地对第一视频数据进行解码,并播放解码后的第一视频数据。
步骤403,接收所述服务器根据所述原视频地址及目标视频编码格式,返回的关键帧信息及第一视频地址,所述关键帧信息至少包括关键帧时间戳及相对应的关键帧位置。
在本公开实施例中,服务器会响应于所述视频转码请求,对第一视频数据进行解析,并将解析获取到的关键帧信息返回给客户端。所述关键帧信息用于客户端对所述第一视频数据的播放位置进行控制。
步骤404,接收播放控制指令,所述播放控制指令至少包括:目标时间点、第一视频地址。
该步骤可参照步骤301的详细描述,此处不再赘述。
步骤405,从与所述第一视频地址相对应的关键帧时间戳中,确定与所述目标时间点距离最近的目标关键帧时间戳。
该步骤可参照步骤302的详细描述,此处不再赘述。
步骤406,确定与所述目标关键帧时间戳相对应的目标关键帧位置。
该步骤可参照步骤303的详细描述,此处不再赘述。
步骤407,向所述服务器发送视频获取请求,所述视频获取请求至少包括:所述目标关键帧位置、第一视频地址。
该步骤可参照步骤304的详细描述,此处不再赘述。
步骤408,接收所述服务器根据所述目标关键帧位置及第一视频地址,返回的第二视频数据。
该步骤可参照步骤305的详细描述,此处不再赘述。
可选的,所述视频转码请求还包括:预设封装格式。
步骤409,在所述第二视频数据所对应的关键帧时间戳大于或等于所述目标时间点的情况下,根据所述预设封装格式对所述第二视频数据进行解封装,并将解封后的第二视频数据进行播放,所述预设封装格式是所述客户端支持的类型。
在本公开实施例中,客户端在给服务器发送的视频转码请求中还包括有客户端支持的预设封装格式,会将转码后得到的第二视频数据按照预设封装格式进行封装,从而客户端可以按照其支持的预设封装格式对第二视频数据进行解封装,以对所述第二视频数据进行播放,实现对客户端不支持视频编码格式的播放和控制。
本公开的实施例提供的技术方案至少带来以下有益效果:
本公开实施例提供的第四种视频处理方法,应用于客户端,所述客户端与服务器通信连接,通过服务器对客户端不支持视频编码格式的视频数据进行解析并获得关键帧位置,以使得客户端根据该关键帧位置确定需要播放的目标关键帧位置,从而服务器根据该目标关键帧位置向客户端返回转码后的视频数据,实现了客户端对不支持视频编码格式的视频数据的播放控制,提高了用户体验。
图7是本公开实施例提供的一种视频处理方法的交互步骤流程图,所述方法应用于视频处理系统,所述视频处理系统包括服务器、客户端,所述服务器与所述客户端通信连接,所述方法包括:
步骤501,所述客户端接收视频播放指令,所述视频播放指令包括:第一视频数据的原视频地址。
该步骤可参照步骤401的详细描述,此处不再赘述。
步骤502,所述客户端在预设视频编码格式集合中不存在所述第一视频数据对应的视频编码格式的情况下,向所述服务器发送视频转码请求,所述视频转码请求至少包括:所述原视频地址、目标视频编码格式。
该步骤可参照步骤402的详细描述,此处不在赘述。
步骤503,所述服务器接收客户端发送的视频转码请求,所述视频转码请求至少包括:原视频地址、目标视频编码格式。
该步骤可参照步骤201的详细描述,此处不在赘述。
步骤504,所述服务器根据所述原视频地址获取第一视频数据。
该步骤可参照步骤202的详细描述,此处不在赘述。
步骤505,所述服务器解析所述第一视频数据的元数据,获取关键帧位置。
该步骤可参照步骤203的详细描述,此处不在赘述。
步骤506,所述服务器根据所述目标视频编码格式、原视频地址生成相对应的第一视频地址。
该步骤可参照步骤204的详细描述,此处不在赘述。
步骤507,所述服务器将所述关键帧位置、所述第一视频地址返回至所述客户端。
该步骤可参照步骤205的详细描述,此处不在赘述。
步骤508,所述客户端接收所述服务器根据所述原视频地址及目标视频编码格式,返回的关键帧信息及第一视频地址,所述关键帧信息至少包括关键帧时间戳及相对应的关键帧位置。
该步骤可参照步骤403的详细描述,此处不在赘述。
步骤509,所述客户端接收播放控制指令,所述播放控制指令至少包括:目标时间点、第一视频地址。
该步骤可参照步骤301的详细描述,此处不再赘述。
步骤510,所述客户端从与所述第一视频地址相对应的关键帧时间戳中,确定与所述目标时间点距离最近的目标关键帧时间戳。
该步骤可参照步骤302的详细描述,此处不再赘述。
步骤511,所述客户端确定与所述目标关键帧时间戳相对应的目标关键帧位置。
该步骤可参照步骤303的详细描述,此处不再赘述。
步骤512,所述客户端向所述服务器发送视频获取请求,所述视频获取请求至少包括:所述目标关键帧位置、第一视频地址。
该步骤可参照步骤304的详细描述,此处不在赘述。
步骤513,所述服务器接收客户端发送的视频获取请求,所述视频获取请求至少包括:第一视频地址、目标关键帧位置,所述目标关键帧位置是预先从第一视频数据获取的。
该步骤可参照步骤101的详细描述,此处不再赘述。
步骤514,所述服务器根据所述第一视频地址查询相对应的原视频地址。
该步骤可参照步骤207的详细描述,此处不再赘述。
步骤515,所述服务器从所述原视频地址获取第一视频数据。
该步骤可参照步骤208的详细描述,此处不再赘述。
步骤516,所述服务器从所述第一视频数据的所述目标关键帧位置开始进行视频编码格式转换,并将按照所述目标视频编码格式转换后的第一视频数据按照预设封装格式进行封装,得到第二视频数据,所述预设封装格式是所述客户端支持的类型,所述目标视频编码格式是所述客户端支持的类型。
该步骤可参照步骤209的详细描述,此处不再赘述。
步骤517,所述服务器返回所述第二视频数据。
该步骤可参照步骤104的详细描述,此处不再赘述。
步骤518,所述客户端接收所述服务器根据所述目标关键帧位置及第一视频地址,返回的第二视频数据。
该步骤可参照步骤305的详细描述,此处不再赘述。
可选的,所述视频转码请求还包括:预设封装格式。
步骤519,所述客户端在所述第二视频数据所对应的关键帧时间戳大于或等于所述目标时间点的情况下,根据所述预设封装格式对所述第二视频数据进行解封装,并将解封后的第二视频数据进行播放,所述预设封装格式是所述客户端支持的类型。
该步骤可参照步骤409的详细描述,此处不再赘述。
本公开的实施例提供的技术方案至少带来以下有益效果:
本公开实施例提供的第五种视频处理方法,应用于视频处理系统,所述系统包括服务器、客户端,所述客户端与所述服务器通信连接,通过服务器对客户端不支持视频编码格式的视频数据进行解析并获得关键帧位置,以使得客户端根据该关键帧位置确定需要播放的目标关键帧位置,从而服务器根据该目标关键帧位置向客户端返回转码后的视频数据,实现了客户端对不支持视频编码格式的视频数据的播放控制,提高了用户体验。
图8是根据一示例性实施例示出的第一种视频处理系统60的结构框图,所述系统包括:
服务器61,包括:
第一接收模块611,被配置为接收客户端发送的视频获取请求,所述视频获取请求至少包括:第一视频地址、目标关键帧位置,所述目标关键帧位置是预先从第一视频数据获取的;
第一获取模块612,被配置为根据所述第一视频地址获取所述第一视频数据;
转码模块613,被配置为从所述第一视频数据的所述目标关键帧位置开始进行视频编码格式转换,得到目标视频编码格式的第二视频数据,所述目标视频编码格式是所述客户端支持的类型;
第一返回模块614,被配置为返回所述第二视频数据。
可选的,所述服务器61,还包括:
第二接收模块615,被配置为接收客户端发送的视频转码请求,所述视频转码请求至少包括:原视频地址、目标视频编码格式;
第二获取模块616,被配置为根据所述原视频地址获取第一视频数据;
解析模块617,被配置为解析所述第一视频数据的元数据,获取关键帧位置;
第一生成模块618,被配置为根据所述目标视频编码格式、原视频地址生成相对应的第一视频地址;
第二返回模块619,被配置为将所述关键帧位置、所述第一视频地址返回至所述客户端。
可选的,所述第一获取模块612,还被配置为:
根据所述第一视频地址查询相对应的原视频地址;
从所述原视频地址获取第一视频数据。
可选的,所述视频转码请求还包括:预设封装格式,所述转码模块613,还被配置为:将按照所述目标视频编码格式转换后的第一视频数据按照预设封装格式进行封装,得到第二视频数据,所述预设封装格式是所述客户端支持的类型。
客户端62,包括:
第三接收模块621,被配置为接收播放控制指令,所述播放控制指令至少包括:目标时间点、第一视频地址;
第一确定模块622,被配置为从与所述第一视频地址相对应的关键帧时间戳中,确定与所述目标时间点距离最近的目标关键帧时间戳;
第二确定模块623,被配置为确定与所述目标关键帧时间戳相对应的目标关键帧位置;
第一发送模块624,被配置为向所述服务器发送视频获取请求,所述视频获取请求至少包括:所述目标关键帧位置、第一视频地址;
第四接收模块625,被配置为接收所述服务器根据所述目标关键帧位置及第一视频地址,返回的第二视频数据;
播放模块626,被配置为在所述第二视频数据所对应的关键帧时间戳大于或等于所述目标时间点的情况下,播放所述第二视频数据。
可选的,所述客户端62,还包括:
第五接收模块627,被配置为接收视频播放指令,所述视频播放指令包括:第一视频数据的原视频地址;
第二发送模块628,被配置为在预设视频编码格式集合中不存在所述第一视频数据对应的视频编码格式的情况下,向所述服务器发送视频转码请求,所述视频转码请求至少包括:所述原视频地址、目标视频编码格式;
第六接收模块629,被配置为接收所述服务器根据所述原视频地址及目标视频编码格式,返回的关键帧信息及第一视频地址,所述关键帧信息至少包括关键帧时间戳及相对应的关键帧位置。
可选的,所述视频转码请求还包括:预设封装格式,所述播放模块626,还被配置为:根据所述预设封装格式对所述第二视频数据进行解封装,并将解封后的第二视频数据进行播放,所述预设封装格式是所述客户端支持的类型。
本公开的实施例提供的技术方案至少带来以下有益效果:
本公开实施例提供的第一种视频处理系统,通过服务器对客户端不支持视频编码格式的视频数据进行解析并获得关键帧位置,以使得客户端根据该关键帧位置确定需要播放的目标关键帧位置,从而服务器根据该目标关键帧位置向客户端返回转码后的视频数据,实现了客户端对不支持视频编码格式的视频数据的播放控制,提高了用户体验。
关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
图9是根据一示例性实施例示出的一种电子设备700的框图。电子设备可以为移动终端也可以为服务器,本公开实施例中以电子设备为移动终端为例进行说明。例如,电子设备700可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图9,电子设备700可以包括以下一个或多个组件:处理组件702,存储器704,电力组件706,多媒体组件708,音频组件710,输入/输出(I/O)的接口712,传感器组件714,以及通信组件716。
处理组件702通常控制电子设备700的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件702可以包括一个或多个处理器720来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件702可以包括一个或多个模块,便于处理组件702和其他组件之间的交互。例如,处理组件702可以包括多媒体模块,以方便多媒体组件708和处理组件702之间的交互。
存储器704被配置为存储各种类型的数据以支持在电子设备700的操作。这些数据的示例包括用于在电子设备700上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器704可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电源组件706为电子设备700的各种组件提供电力。电源组件706可以包括电源管理系统,一个或多个电源,及其他与为电子设备700生成、管理和分配电力相关联的组件。
多媒体组件708包括在所述电子设备700和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件708包括一个前置摄像头和/或后置摄像头。当电子设备700处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件710被配置为输出和/或输入音频信号。例如,音频组件710包括一个麦克风(MIC),当电子设备700处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器704或经由通信组件716发送。在一些实施例中,音频组件710还包括一个扬声器,用于输出音频信号。
I/O接口712为处理组件702和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件714包括一个或多个传感器,用于为电子设备700提供各个方面的状态评估。例如,传感器组件714可以检测到电子设备700的打开/关闭状态,组件的相对定位,例如所述组件为电子设备700的显示器和小键盘,传感器组件714还可以检测电子设备700或电子设备700一个组件的位置改变,用户与电子设备700接触的存在或不存在,电子设备700方位或加速/减速和电子设备700的温度变化。传感器组件714可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件714还可以包括光传感器,如CMOS或CCD图谱传感器,用于在成像应用中使用。在一些实施例中,该传感器组件714还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件716被配置为便于电子设备700和其他设备之间有线或无线方式的通信。电子设备700可以接入基于通信标准的无线网络,如WiFi,运营商网络(如2G、5G、4G或5G),或它们的组合。在一个示例性实施例中,通信组件716经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件716还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,电子设备700可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述实施例中所述的视频处理方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器704,上述指令可由电子设备700的处理器720执行以完成上述实施例中所述的的视频处理方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
在示例性实施例中,还提供了一种计算机程序产品,当计算机程序产品中的指令由电子设备700的处理器720执行时,使得电子设备700执行上述实施例中所述的的视频处理方法。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。

Claims (16)

1.一种视频处理方法,其特征在于,所述方法应用于服务器,所述方法包括:
接收客户端发送的视频获取请求,所述视频获取请求至少包括:第一视频地址、目标关键帧位置,所述目标关键帧位置是所述客户端从与所述第一视频地址相对应的关键帧时间戳中,根据与目标时间点距离最近的目标关键帧时间戳获取的;所述第一视频地址是目标视频编码格式、原视频地址生成的;所述原视频地址对应的直播视频数据的视频编码格式是所述客户端不支持的视频编码格式;
根据所述第一视频地址获取第一视频数据;
从所述第一视频数据的所述目标关键帧位置开始进行视频编码格式转换,得到目标视频编码格式的第二视频数据,所述目标视频编码格式是所述客户端支持的类型;
返回所述第二视频数据。
2.根据权利要求1所述的方法,其特征在于,在所述接收客户端发送的视频获取请求的步骤之前,还包括:
接收客户端发送的视频转码请求,所述视频转码请求至少包括:原视频地址、目标视频编码格式;
根据所述原视频地址获取第一视频数据;
解析所述第一视频数据的元数据,获取关键帧位置;
根据所述目标视频编码格式、原视频地址生成相对应的第一视频地址;
将所述关键帧位置、所述第一视频地址返回至所述客户端。
3.根据权利要求1所述的方法,其特征在于,所述根据所述第一视频地址获取第一视频数据的步骤,包括:
根据所述第一视频地址查询相对应的原视频地址;
从所述原视频地址获取第一视频数据。
4.根据权利要求2所述的方法,其特征在于,所述视频转码请求还包括:预设封装格式,所述得到目标视频编码格式的第二视频数据的步骤,包括:
将按照所述目标视频编码格式转换后的第一视频数据按照预设封装格式进行封装,得到第二视频数据,所述预设封装格式是所述客户端支持的类型。
5.一种视频处理方法,其特征在于,所述方法应用于客户端,所述方法包括:
接收播放控制指令,所述播放控制指令至少包括:目标时间点、第一视频地址;
从与所述第一视频地址相对应的关键帧时间戳中,确定与所述目标时间点距离最近的目标关键帧时间戳;
确定与所述目标关键帧时间戳相对应的目标关键帧位置;
向服务器发送视频获取请求,所述视频获取请求至少包括:所述目标关键帧位置、第一视频地址;
接收所述服务器根据所述目标关键帧位置及第一视频地址,返回的第二视频数据;
在所述第二视频数据所对应的关键帧时间戳大于或等于所述目标时间点的情况下,播放所述第二视频数据。
6.根据权利要求5所述的方法,其特征在于,在所述接收播放控制指令的步骤之前,还包括:
接收视频播放指令,所述视频播放指令包括:第一视频数据的原视频地址;
在预设视频编码格式集合中不存在所述第一视频数据对应的视频编码格式的情况下,向所述服务器发送视频转码请求,所述视频转码请求至少包括:所述原视频地址、目标视频编码格式;
接收所述服务器根据所述原视频地址及目标视频编码格式,返回的关键帧信息及第一视频地址,所述关键帧信息至少包括关键帧时间戳及相对应的关键帧位置。
7.根据权利要求5所述的方法,其特征在于,视频转码请求还包括:预设封装格式,所述播放所述第二视频数据的步骤,包括:
根据所述预设封装格式对所述第二视频数据进行解封装,并将解封后的第二视频数据进行播放,所述预设封装格式是所述客户端支持的类型。
8.一种视频处理装置,其特征在于,所述装置应用于服务器,所述服务器与客户端通信连接,所述装置包括:
第一接收模块,被配置为接收客户端发送的视频获取请求,所述视频获取请求至少包括:第一视频地址、目标关键帧位置,所述目标关键帧位置是预先是所述客户端从与所述第一视频地址相对应的关键帧时间戳中,根据与目标时间点距离最近的目标关键帧时间戳获取的;所述第一视频地址是目标视频编码格式、原视频地址生成的;所述原视频地址对应的直播视频数据的视频编码格式是所述客户端不支持的视频编码格式;
第一获取模块,被配置为根据所述第一视频地址获取第一视频数据;
转码模块,被配置为从所述第一视频数据的所述目标关键帧位置开始进行视频编码格式转换,得到目标视频编码格式的第二视频数据,所述目标视频编码格式是所述客户端支持的类型;
第一返回模块,被配置为返回所述第二视频数据。
9.根据权利要求8所述的装置,其特征在于,所述装置,还包括:
第二接收模块,被配置为接收客户端发送的视频转码请求,所述视频转码请求至少包括:原视频地址、目标视频编码格式;
第二获取模块,被配置为根据所述原视频地址获取第一视频数据;
解析模块,被配置为解析所述第一视频数据的元数据,获取关键帧位置;
第一生成模块,被配置为根据所述目标视频编码格式、原视频地址生成相对应的第一视频地址;
第二返回模块,被配置为将所述关键帧位置、所述第一视频地址返回至所述客户端。
10.根据权利要求8所述的装置,其特征在于,所述第一获取模块,还被配置为:
根据所述第一视频地址查询相对应的原视频地址;
从所述原视频地址获取第一视频数据。
11.根据权利要求9所述的装置,其特征在于,所述视频转码请求还包括:预设封装格式,所述转码模块,还被配置为:
将按照所述目标视频编码格式转换后的第一视频数据按照预设封装格式进行封装,得到第二视频数据,所述预设封装格式是所述客户端支持的类型。
12.一种视频处理装置,其特征在于,所述装置应用于客户端,所述客户端与服务器通信连接,所述装置包括:
第三接收模块,被配置为接收播放控制指令,所述播放控制指令至少包括:目标时间点、第一视频地址;
第一确定模块,被配置为从与所述第一视频地址相对应的关键帧时间戳中,确定与所述目标时间点距离最近的目标关键帧时间戳;
第二确定模块,被配置为确定与所述目标关键帧时间戳相对应的目标关键帧位置;
第一发送模块,被配置为向所述服务器发送视频获取请求,所述视频获取请求至少包括:所述目标关键帧位置、第一视频地址;
第四接收模块,被配置为接收所述服务器根据所述目标关键帧位置及第一视频地址,返回的第二视频数据;
播放模块,被配置为在所述第二视频数据所对应的关键帧时间戳大于或等于所述目标时间点的情况下,播放所述第二视频数据。
13.根据权利要求12所述的装置,其特征在于,所述装置,还包括:
第五接收模块,被配置为接收视频播放指令,所述视频播放指令包括:第一视频数据的原视频地址;
第二发送模块,被配置为在预设视频编码格式集合中不存在所述第一视频数据对应的视频编码格式的情况下,向所述服务器发送视频转码请求,所述视频转码请求至少包括:所述原视频地址、目标视频编码格式;
第六接收模块,被配置为接收所述服务器根据所述原视频地址及目标视频编码格式,返回的关键帧信息及第一视频地址,所述关键帧信息至少包括关键帧时间戳及相对应的关键帧位置。
14.根据权利要求12所述的装置,其特征在于,视频转码请求还包括:预设封装格式,所述播放模块,还被配置为:
根据所述预设封装格式对所述第二视频数据进行解封装,并将解封后的第二视频数据进行播放,所述预设封装格式是所述客户端支持的类型。
15.一种电子设备,其特征在于,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现权利要求1至7中任一所述的视频处理方法。
16.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储计算机程序,所述计算机程序被处理器执行时实现权利要求1至7中任一所述的视频处理方法。
CN202010239641.8A 2020-03-30 2020-03-30 一种视频处理方法、装置、电子设备及存储介质 Active CN111526387B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010239641.8A CN111526387B (zh) 2020-03-30 2020-03-30 一种视频处理方法、装置、电子设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010239641.8A CN111526387B (zh) 2020-03-30 2020-03-30 一种视频处理方法、装置、电子设备及存储介质

Publications (2)

Publication Number Publication Date
CN111526387A CN111526387A (zh) 2020-08-11
CN111526387B true CN111526387B (zh) 2022-09-23

Family

ID=71910796

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010239641.8A Active CN111526387B (zh) 2020-03-30 2020-03-30 一种视频处理方法、装置、电子设备及存储介质

Country Status (1)

Country Link
CN (1) CN111526387B (zh)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113918487A (zh) * 2021-10-22 2022-01-11 北京灵汐科技有限公司 数据包处理方法、数据包处理装置
CN114245175A (zh) * 2021-12-15 2022-03-25 北京度友信息技术有限公司 视频转码方法、装置、电子设备及存储介质
CN114401445B (zh) * 2021-12-31 2024-03-22 深圳云天励飞技术股份有限公司 视频处理控制方法、装置、监控设备、客户端及存储介质
CN115942000B (zh) * 2022-11-08 2023-11-21 北京力控元通科技有限公司 H.264格式的视频流转码方法及装置、设备及介质

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105763960A (zh) * 2016-03-01 2016-07-13 青岛海信传媒网络技术有限公司 一种网络视频播放的方法和装置
CN106961613A (zh) * 2017-03-30 2017-07-18 上海七牛信息技术有限公司 一种流式实时转码点播方法及系统
CN109756749A (zh) * 2017-11-07 2019-05-14 阿里巴巴集团控股有限公司 视频数据处理方法、装置、服务器和存储介质
CN110290402A (zh) * 2019-07-31 2019-09-27 腾讯科技(深圳)有限公司 一种视频码率调整方法、装置、服务器及存储介质
CN110933517A (zh) * 2019-11-30 2020-03-27 咪咕视讯科技有限公司 码率切换方法、客户端和计算机可读存储介质

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105763960A (zh) * 2016-03-01 2016-07-13 青岛海信传媒网络技术有限公司 一种网络视频播放的方法和装置
CN106961613A (zh) * 2017-03-30 2017-07-18 上海七牛信息技术有限公司 一种流式实时转码点播方法及系统
CN109756749A (zh) * 2017-11-07 2019-05-14 阿里巴巴集团控股有限公司 视频数据处理方法、装置、服务器和存储介质
CN110290402A (zh) * 2019-07-31 2019-09-27 腾讯科技(深圳)有限公司 一种视频码率调整方法、装置、服务器及存储介质
CN110933517A (zh) * 2019-11-30 2020-03-27 咪咕视讯科技有限公司 码率切换方法、客户端和计算机可读存储介质

Also Published As

Publication number Publication date
CN111526387A (zh) 2020-08-11

Similar Documents

Publication Publication Date Title
CN111526387B (zh) 一种视频处理方法、装置、电子设备及存储介质
CN109981607B (zh) 媒体流处理方法及装置、电子设备和存储介质
KR101167432B1 (ko) 통신 방법 및 통신 시스템
WO2008061416A1 (fr) Procédé et système permettant d'accepter des données media de divers formats de codage
CN107197320B (zh) 视频直播方法、装置和系统
TWI501609B (zh) 用以儲存多重來源多媒體呈現內容之系統與方法
JP6195674B2 (ja) ネットワーク環境に基づく映像画質の調整方法、装置、プログラム、及び記録媒体
CN111092898B (zh) 报文传输方法及相关设备
CN111182328B (zh) 一种视频剪辑方法、装置、服务器、终端及存储介质
CN111385349B (zh) 通信处理方法、装置、终端、服务器及存储介质
CN110996122B (zh) 视频帧传输方法、装置、计算机设备及存储介质
KR101701742B1 (ko) 이동통신 단말기 간 실시간 스트리밍을 위한 장치 및 방법
KR100961391B1 (ko) 화상 통화 중 저장된 영상 관리 방법 및 영상 관리 장치 및그 장치를 포함하는 시스템
CN109729438B (zh) 一种发送视频包、接收视频包的方法及装置
CN112203126B (zh) 投屏方法、投屏装置及存储介质
WO2023231478A1 (zh) 音视频共享方法、设备及计算机可读存储介质
US11943492B2 (en) Method and system for adding subtitles and/or audio
US20220078456A1 (en) Method and apparatus for video transcoding
CN113422997A (zh) 一种播放音频数据的方法、装置及可读存储介质
CN110213531B (zh) 监控录像处理方法及装置
CN110290224B (zh) 资源上传、转发方法及装置、移动终端、网关和存储介质
KR20080047683A (ko) 휴대용 단말기에서 스트리밍 서비스 전송 방법 및 장치
CN104717516A (zh) 一种多媒体数据的传输方法及装置
CN111182327B (zh) 一种视频剪辑方法、装置、视频分发服务器及终端
CN113709907A (zh) 媒体数据传输方法及装置、设备、存储介质

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
GR01 Patent grant
GR01 Patent grant