本发明涉及视频监控
技术领域:
,特别涉及一种多媒体文件封装、播放方法及装置。
背景技术:
:通常情况下,摄像机或服务器将采集到的多媒体数据按照国际标准(iso14496-12)封装成dash(dynamicadaptivestreamingoverhttp,基于http的动态自适应流)协议指定的格式数据(该格式数据以gop为单位),同时针对每一gop的数据,生成其对应的mpd(mediapresentationdescription,媒体表示描述)文件,mpd文件中包括该gop数据的索引信息,如编码方式、媒体时长、媒体类型、可供选择的多种码率、url等信息。客户端在获取每一gop的数据之前,先从摄像机或服务器获取该gop的数据对应的mpd文件,对mpd文件进行解析,并根据客户端的缓冲区等级或客户端所在的网络的带宽,从mpd文件中包括的可供选择的多种码率中选择合适的码率。客户端将选择的针对于该gop数据的码率发送给摄像机或服务器,以使摄像机或服务器将该gop数据发送给客户端,客户端以该码率将该gop数据进行解码播放。在视频监控
技术领域:
,使用价值较大的通常都是变化剧烈或者与一般情况有较大差异的异常多媒体数据,比如深夜楼道监控中突然出现的人物,十字路口出现的大面积拥堵或围观等多媒体数据。应用上述方案,摄像机或服务器生成的各gop数据对应的mpd文件中,并不涉及能够反映多媒体内容的信息,因而客户端在获取了mpd文件后,无法根据待播放的多媒体内容,确定多媒体数据的播放码率。技术实现要素:本发明实施例的目的在于提供一种多媒体文件封装、播放方法及装置,以解决现有mpd文件不包含反映多媒体内容的信息,无法根据多媒体内容确定播放码率的问题。为达到上述目的,本发明实施例公开了一种多媒体文件封装方法,应用于摄像机或服务器,包括:针对采集的每个图像组gop的多媒体数据,确定所述gop对应的视频内容 变化参数和/或音量参数,其中根据所述gop的多媒体数据中视频数据的每一参考帧的数据量和/或运动矢量变化总量,确定所述gop对应的视频内容变化参数;根据所述gop的多媒体数据中音频数据的音量的平均值和/或音量变化强度,确定所述gop对应的音量参数;根据每个gop对应的视频内容变化参数和/或音量参数,采用第一预设规则,确定每个gop对应的判定参数;对每个gop的多媒体数据进行封装,并将确定的每个gop对应的判定参数添加到对应的每个媒体表示描述mpd文件中。可选的,当根据每个gop对应的视频内容变化参数和音量参数,采用第一预设规则,确定每个gop对应的判定参数时,可以包括:根据下式确定每个gop对应的判定参数:gop对应的判定参数=所述gop对应的视频内容变化参数*第一权重值+所述gop对应的音量参数*第二权重值,其中第一权重值和第二权重值相同或不同。可选的,所述根据所述gop的多媒体数据中每一参考帧的数据量和运动矢量变化总量,确定所述gop对应的视频内容变化参数,可以包括:根据所述gop的多媒体数据中每一参考帧的数据量和运动矢量变化总量,确定所述gop中所有参考帧的数据量的和以及运动矢量变化总量的和;根据所述gop中包含的参考帧的数量,及所述所有参考帧的数据量的和以及运动矢量变化总量的和,确定所述gop对应的平均数据量和平均运动矢量变化总量;根据所述平均数据量和所述平均运动矢量变化总量,确定所述平均数据量的等级值和所述平均运动矢量变化总量的等级值;根据所述平均数据量的等级值和所述平均运动矢量变化总量的等级值,确定所述gop对应的视频内容变化参数。可选的,所述根据所述gop的多媒体数据中每一参考帧的数据量和/或运动矢量变化总量,确定所述gop对应的视频内容变化参数,可以包括:根据所述gop的多媒体数据中每一参考帧的数据量和运动矢量变化总量,确定每一参考帧的数据量的等级值和运动矢量变化总量的等级值;根据所述gop中包含的参考帧的数量,及每一参考帧的数据量的等级值和/或运动矢量变化总量的等级值,确定所述gop对应的视频内容变化参数。可选的,所述根据所述gop中包含的参考帧的数量,及每一参考帧的数据量的等级值和运动矢量变化总量的等级值,确定所述gop对应的视频内容变化参数,可以包括:根据所述gop中包含的参考帧的数量,及每一参考帧的数据量的等级值和运动矢量变化总量的等级值,确定数据量的等级值的平均值和运动矢量变化总量的等级值的平均值,根据每个平均值对应的权重值,确定所述gop对应的视频内容变化参数。可选的,所述根据所述gop的多媒体数据中音频数据的音量的平均值和/或音量变化强度,确定所述gop对应的音量参数,可以包括:根据所述gop的多媒体数据中音频数据的音量的平均值和音量变化强度,确定所述音频数据的音量的等级值和音量变化强度的等级值;根据所述音量的等级值和/或音量变化强度的等级值,确定所述gop对应的音量参数。可选的,所述根据所述音量的等级值和音量变化强度的等级值,确定所述gop对应的音量参数,可以包括:根据所述音量的等级值和音量变化强度的等级值,及所述音量的等级值和音量变化强度的等级值对应的权重值,确定所述gop对应的音量参数。可选的,所述根据所述gop的多媒体数据中视频数据的每一参考帧的数据量和/或运动矢量变化总量,确定所述gop对应的视频内容变化参数,可以包括:针对每个参考帧,确定所述参考帧的数据量和运动矢量变化总量;当所述参考帧非所述gop中的最后一个参考帧时,根据所述参考帧的数据量和运动矢量变化总量,确定所述参考帧的数据量和运动矢量变化总量的等级值;并根据确定的所述等级值,及基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值;当所述参考帧为该gop中的最后一个参考帧时,根据所述参考帧的数据量和运动矢量变化总量,确定所述参考帧的数据量和运动矢量变化总量的等级值;并根据确定的所述等级值,及基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值;根据更新后的所述等级值的均值,确定所述gop对应的视频内容变化参数,并将所述视频 内容变化参数添加到基于dash分片索引box中视频内容变化参数对应的字段中。可选的,所述根据所述gop的多媒体数据中音频数据的音量的平均值和/或音量变化强度,确定所述gop对应的音量参数,可以包括:将所述gop的多媒体数据中的音频数据划分成时长相等的多个时间段;针对每一时间段,确定所述时间段的音量的平均值和音量变化强度;当所述时间段非所述gop中的最后一个时间段时,根据所述时间段的音量的平均值和音量变化强度,确定所述时间段的音量的平均值和音量变化强度的等级值;并根据确定的所述等级值,及基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值;当所述时间段为该gop中的最后一个时间段时,根据所述时间段的音量的平均值和音量变化强度,确定所述时间段的音量的平均值和音量变化强度的等级值;并根据确定的所述等级值,及基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值;根据更新后的所述等级值的均值,确定所述gop对应的音量参数,并将所述音量参数添加到基于dash分片索引box中音量参数对应的字段中。为达到上述目的,本发明实施例还公开了一种多媒体文件播放方法,应用于客户端,所述客户端与所述摄像机或服务器通讯连接,包括:向所述摄像机或服务器发送获取请求,以使所述摄像机或服务器将一个gop的多媒体数据对应的媒体表示描述mpd文件发送给所述客户端;接收所述mpd文件,读取所述mpd文件中的所述gop对应的判定参数;根据所述gop对应的判定参数,确定所述gop的多媒体数据的第一播放码率;将所述第一播放码率发送给所述摄像机或服务器,并以所述第一播放码率对所述摄像机或服务器发送的所述gop的多媒体数据进行解码播放。可选的,所述根据所述gop对应的判定参数,确定所述gop的多媒体数据的第一播放码率,可以包括:根据网络带宽和缓冲区等级中至少一个及所述gop对应的判定参数,确定 所述gop的多媒体数据的第一播放码率。可选的,所述根据网络带宽和缓冲区等级中至少一个及所述gop对应的判定参数,确定所述gop的多媒体数据的第一播放码率,可以包括:根据所述gop对应的判定参数、网络带宽和缓冲区等级,及所述gop对应的判定参数、网络带宽和缓冲区等级对应的权重值,确定所述gop的多媒体数据的第一播放码率。可选的,所述将所述第一播放码率发送给所述摄像机或服务器之前,还可以包括:提取保存的所述gop之前的设定数量个gop的多媒体数据的理论播放码率;判断所述第一播放码率与设定数量个理论播放码率的差值是否都小于预设阈值;如果是,执行所述将所述第一播放码率发送给所述摄像机或服务器的步骤;如果否,将所述设定数量个理论播放码率中最前面一个理论播放码率确定为调整后的第一播放码率,并执行将调整后的第一播放码率发送给摄像机或服务器的步骤,将所述第一播放码率保存为所述gop的多媒体数据的理论播放码率,并将所述调整后的第一播放码率保存为所述gop的多媒体数据的实际播放码率。为达到上述目的,本发明实施例还公开了一种多媒体文件封装装置,应用于摄像机或服务器,包括:第一确定模块、第二确定模块和封装模块,其中,所述第一确定模块,用于针对采集的每个图像组gop的多媒体数据,确定所述gop对应的视频内容变化参数和/或音量参数,其中根据所述gop的多媒体数据中视频数据的每一参考帧的数据量和/或运动矢量变化总量,确定所述gop对应的视频内容变化参数;根据所述gop的多媒体数据中音频数据的音量的平均值和/或音量变化强度,确定所述gop对应的音量参数;所述第二确定模块,用于根据每个gop对应的视频内容变化参数和/或音量参数,采用第一预设规则,确定每个gop对应的判定参数;所述封装模块,用于对每个gop的多媒体数据进行封装,并将确定的每个gop对应的判定参数添加到对应的每个媒体表示描述mpd文件中。可选的,所述第二确定模块,具体可以用于根据下式确定每个gop对应的判定参数:gop对应的判定参数=所述gop对应的视频内容变化参数*第一权重值+所述gop对应的音量参数*第二权重值,其中第一权重值和第二权重值相同或不同。可选的,所述第一确定模块,可以包括:第一确定子模块、第二确定子模块、第三确定子模块和第四确定子模块,其中,所述第一确定子模块,用于根据所述gop的多媒体数据中每一参考帧的数据量和运动矢量变化总量,确定所述gop中所有参考帧的数据量的和以及运动矢量变化总量的和;所述第二确定子模块,用于根据所述gop中包含的参考帧的数量,及所述所有参考帧的数据量的和以及运动矢量变化总量的和,确定所述gop对应的平均数据量和平均运动矢量变化总量;所述第三确定子模块,用于根据所述平均数据量和所述平均运动矢量变化总量,确定所述平均数据量的等级值和所述平均运动矢量变化总量的等级值;所述第四确定子模块,用于根据所述平均数据量的等级值和所述平均运动矢量变化总量的等级值,确定所述gop对应的视频内容变化参数。可选的,所述第一确定模块,可以包括:第五确定子模块和第六确定子模块,其中,所述第五确定子模块,用于根据所述gop的多媒体数据中每一参考帧的数据量和运动矢量变化总量,确定每一参考帧的数据量的等级值和运动矢量变化总量的等级值;和/或,根据所述gop的多媒体数据中音频数据的音量的平均值和音量变化强度,确定所述音频数据的音量的等级值和音量变化强度的等级值;所述第六确定子模块,用于根据所述gop中包含的参考帧的数量,及每一参考帧的数据量的等级值和/或运动矢量变化总量的等级值,确定所述gop对应的视频内容变化参数;和/或,根据所述音量的等级值和/或音量变化强度的等级值,确定所述gop对应的音量参数。可选的,所述第六确定子模块,具体可以用于:根据所述gop中包含的参考帧的数量,及每一参考帧的数据量的等级值和运动矢量变化总量的等级值,确定数据量的等级值的平均值和运动矢量变化总量的等级值的平均值,根据每个平均值对应的权重值,确定所述gop对应的视 频内容变化参数;和/或,根据所述音量的等级值和音量变化强度的等级值,及所述音量的等级值和音量变化强度的等级值对应的权重值,确定所述gop对应的音量参数。可选的,所述第一确定模块,具体可以用于:针对每个参考帧,确定所述参考帧的数据量和运动矢量变化总量;当所述参考帧非所述gop中的最后一个参考帧时,根据所述参考帧的数据量和运动矢量变化总量,确定所述参考帧的数据量和运动矢量变化总量的等级值;并根据确定的所述等级值,及基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值;当所述参考帧为该gop中的最后一个参考帧时,根据所述参考帧的数据量和运动矢量变化总量,确定所述参考帧的数据量和运动矢量变化总量的等级值;并根据确定的所述等级值,及基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值,根据更新后的所述等级值的均值,确定所述gop对应的视频内容变化参数,并将所述视频内容变化参数添加到基于dash分片索引box中视频内容变化参数对应的字段中;和/或,将所述gop的多媒体数据中的音频数据划分成时长相等的多个时间段;针对每一时间段,确定所述时间段的音量的平均值和音量变化强度;当所述时间段非所述gop中的最后一个时间段时,根据所述时间段的音量的平均值和音量变化强度,确定所述时间段的音量的平均值和音量变化强度的等级值;并根据确定的所述等级值,及基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值;当所述时间段为该gop中的最后一个时间段时,根据所述时间段的音量的平均值和音量变化强度,确定所述时间段的音量的平均值和音量变化强度的等级值;并根据确定的所述等级值,及基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值, 根据更新后的所述等级值的均值,确定所述gop对应的音量参数,并将所述音量参数添加到基于dash分片索引box中音量参数对应的字段中。为达到上述目的,本发明实施例还公开了一种多媒体文件播放装置,应用于客户端,所述客户端与所述摄像机或服务器通讯连接,包括:发送模块、读取模块、第三确定模块和播放模块,其中,所述发送模块,用于向所述摄像机或服务器发送获取请求,以使所述摄像机或服务器将一个gop的多媒体数据对应的媒体表示描述mpd文件发送给所述客户端;所述读取模块,用于接收所述mpd文件,读取所述mpd文件中的所述gop对应的判定参数;所述第三确定模块,用于根据所述gop对应的判定参数,确定所述gop的多媒体数据的第一播放码率;所述播放模块,用于将所述第一播放码率发送给所述摄像机或服务器,并以所述第一播放码率对所述摄像机或服务器发送的所述gop的多媒体数据进行解码播放。可选的,所述第三确定模块,具体可以用于根据网络带宽和缓冲区等级中至少一个及所述gop对应的判定参数,确定所述gop的多媒体数据的第一播放码率。可选的,所述第三确定模块,具体可以用于根据所述gop对应的判定参数、网络带宽和缓冲区等级,及所述gop对应的判定参数、网络带宽和缓冲区等级对应的权重值,确定所述gop的多媒体数据的第一播放码率。可选的,还可以包括:提取模块、判断模块、第四确定模块和保存模块,其中,所述提取模块,用于提取保存的所述gop之前的设定数量个gop的多媒体数据的理论播放码率;所述判断模块,用于判断所述第一播放码率与设定数量个理论播放码率的差值是否都小于预设阈值,如果是,触发所述播放模块,如果否,触发所述第四确定模块;所述第四确定模块,用于将所述设定数量个理论播放码率中最前面一个理论播放码率确定为调整后的第一播放码率,并触发所述播放模块;所述保存模块,用于将所述第一播放码率保存为所述gop的多媒体数据的 理论播放码率,并将所述调整后的第一播放码率保存为所述gop的多媒体数据的实际播放码率。由上述的技术方案可见,摄像机或服务器在每个gop的多媒体数据对应的媒体表示描述mpd文件中加入该gop对应的判定参数,该判定参数能够反映该gop的多媒体数据包含的多媒体内容的变化强度。客户端根据该gop的多媒体数据对应的媒体表示描述mpd文件中加入的该gop对应的判定参数,确定该gop的多媒体数据的播放码率,以使摄像机或服务器将该gop的多媒体数据发送给客户端,客户端以该播放码率将该gop的多媒体数据进行解码播放。由此可见,本发明实施例的封装方法中将gop对应的判定参数添加到对应的每个媒体表示描述mpd文件中,该gop对应的判定参数根据视频内容和/或音频内容的变化确定,其中视频内容变化越大对应的判定参数越大,音频内容变化越大对应的判定参数越大,从而使接收到mpd文件的客户端,可以根据该mpd文件中记录的gop对应的判定参数,确定多媒体数据的播放码率。当然,实施本发明的任一产品或方法必不一定需要同时达到以上所述的所有优点。附图说明为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。图1为本发明实施例提供的多媒体文件封装方法的第一种流程示意图;图2为本发明实施例提供的多媒体文件封装方法的第二种流程示意图;图3为本发明实施例提供的多媒体文件封装方法的第三种流程示意图;图4为本发明实施例提供的多媒体文件播放方法的第一种流程示意图;图5为本发明实施例提供的多媒体文件播放方法的第二种流程示意图;图6为本发明实施例提供的多媒体文件封装装置的第一种结构示意图;图7为本发明实施例提供的多媒体文件播放装置的第一种结构示意图;图8为本发明实施例提供的多媒体文件播放装置的第二种结构示意图。具体实施方式下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是 全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。为了解决现有技术问题,本发明实施例提供了一种应用于摄像机或服务器的多媒体文件封装方法及装置,还提供了一种应用于客户端的多媒体文件播放方法及装置。下面首先对本发明实施例提供的一种应用于摄像机或服务器的多媒体文件封装方法进行详细说明。图1为本发明实施例提供的多媒体文件封装方法的第一种流程示意图,包括:s101a:针对采集的每个图像组gop的多媒体数据,根据所述gop的多媒体数据中视频数据的每一参考帧的数据量和/或运动矢量变化总量,确定所述gop对应的视频内容变化参数。作为本发明的一种实施方式,采集到的多媒体数据按照iso14496-12国际标准规范以gop为单位进行封装。每一gop的多媒体数据中包括视频数据和音频数据,其中视频数据包括一个i帧和多个p帧、b帧,i帧可以独立解码成一个完整的画面,p帧、b帧记录的是相对于i帧的变化,p帧、b帧即为参考帧。在本发明所示实施例中,不涉及b帧的封装,一个gop由首帧i帧和若干p帧组成,p帧中存储每个像素点相对于i帧的运动矢量(mv)的变化向量。假设p帧中有3个像素点相对于i帧发生了变化,p帧中存储的是像素点a的mv变化向量(3,5)、像素点b的mv变化向量(4,6)、像素点c的mv变化向量(7,9)。由此可见,p帧的数据量和mv变化总量均能侧面反映p帧视频内容是否存在剧烈变化:p帧的数据量或mv变化总量越大,说明发生变化的像素点越多,或者像素点变化的向量越大。s102a:根据每个gop对应的视频内容变化参数,采用第一预设规则,确定每个gop对应的判定参数。其中视频内容变化参数越大对应的判定参数越大。在本发明所示实施例中,可以根据gop对应的视频内容变化参数,确定该gop对应的判定参数。例如可以直接将gop对应的视频内容变化参数,确定为该gop对应的判定参数。s103:对每个gop的多媒体数据进行封装,并将确定的每个gop对应的判定参数添加到对应的每个媒体表示描述mpd文件中。具体的,针对采集的每个图像组gop的多媒体数据,根据所述gop的多媒 体数据中每一参考帧的数据量和/或运动矢量变化总量,确定所述gop对应的视频内容变化参数时,可以包括:第一种方式,根据所述gop的多媒体数据中每一参考帧的数据量和运动矢量变化总量,确定所述gop中所有参考帧的数据量的和以及运动矢量变化总量的和;根据所述gop中包含的参考帧的数量,及所述所有参考帧的数据量的和以及运动矢量变化总量的和,确定所述gop对应的平均数据量和平均运动矢量变化总量;根据所述平均数据量和所述平均运动矢量变化总量,确定所述平均数据量的等级值和所述平均运动矢量变化总量的等级值;根据所述平均数据量的等级值和所述平均运动矢量变化总量的等级值,确定所述gop对应的视频内容变化参数。假设所述gop的多媒体数据中包含5个p帧,根据每一p帧的数据量和运动矢量变化总量,确定所述gop中包含的5个p帧的数据量的和以及运动矢量变化总量的和。将上述5个p帧的数据量的和除以5,得到所述gop对应的平均数据量;将上述5个p帧的运动矢量变化总量的和除以5,得到所述gop对应的平均运动矢量变化总量。根据平均数据量,及每个等级值对应的数据量区间,确定平均数据量的等级值;根据平均运动矢量变化总量,及每个等级值对应的运动运动矢量变化总量区间,确定平均运动矢量变化总量的等级值。即,对平均数据量和平均运动矢量变化总量进行量化,量化规则可以如表1所示。第二种方式,根据所述gop的多媒体数据中每一参考帧的数据量和运动矢量变化总量,确定每一参考帧的数据量的等级值和运动矢量变化总量的等级值;根据所述gop中包含的参考帧的数量,及每一参考帧的数据量的等级值和/或运动矢量变化总量的等级值,确定所述gop对应的视频内容变化参数。根据所述gop的多媒体数据中每一参考帧的数据量和运动矢量变化总量,确定每一参考帧的数据量的等级值和运动矢量变化总量的等级值,即,对每一参考帧的数据量和运动矢量变化总量进行量化。假设量化规则如表1所示:表1数值<min>=min&&<=max>max&&<=1.5max>1.5max等级值0123其中,表1中记录有数值范围与等级值的对应关系,数值范围即为数据量或运动矢量变化总量的对应范围,[min,max]为对应参数在当前时间段的正常 数值范围。如果该数值为参考帧的数据量,参考帧的数据量在当前时间段的正常数值范围为[min=200,max=500]。根据上述表1可知,如果该参考帧的数据量小于200,则该参考帧的数据量的等级值为0,如果该参考帧的数据量大于200且小于500,则该参考帧的数据量的等级值为1;如果该参考帧的数据量大于500且小于500*1.5=750,则该参考帧的数据量的等级值为2,如果该参考帧的数据量大于500*1.5=750,则该参考帧的数据量的等级值为3。当应用第二种方式确定所述gop对应的视频内容变化参数时,根据所述gop中包含的参考帧的数量,及每一参考帧的数据量的等级值和运动矢量变化总量的等级值,确定所述gop对应的视频内容变化参数,可以包括:假设该gop中包含5个p帧,分别用a、b、c、d、e来表示,利用表1得到该5个p帧的数据量的等级值分别为1、2、2、3、1(按照a、b、c、d、e的顺序),该5个p帧的运动矢量变化总量的等级值分别为1、1、2、2、1(按照a、b、c、d、e的顺序)。第一种方案:根据所述gop中包含的参考帧的数量,及每一参考帧的数据量的等级值,确定数据量的等级值的平均值,将所述数据量的等级值的平均值确定为所述gop对应的视频内容变化参数。a、b、c、d、e这5个p帧的数据量的等级值分别为1、2、2、3、1,数据量的等级值的平均值为(1+2+2+3+1)/5=1.8,所述gop对应的视频内容变化参数即为1.8。第二种方案:根据所述gop中包含的参考帧的数量,及每一参考帧的运动矢量变化总量的等级值,确定运动矢量变化总量的等级值的平均值,将所述运动矢量变化总量的等级值的平均值确定为所述gop对应的视频内容变化参数。a、b、c、d、e这5个p帧的mv变化总量的等级值分别为1、1、2、2、1,mv变化总量的等级值的平均值为(1+1+2+1+1)/5=1.2,所述gop对应的视频内容变化参数即为1.2。第三种方案:根据所述gop中包含的参考帧的数量,及每一参考帧的数据量的等级值和运动矢量变化总量的等级值,确定数据量的等级值的平均值和运动矢量变化总量的等级值的平均值,根据每个平均值对应的权重值,确定所述gop对应的视频内容变化参数。数据量的等级值的平均值为1.8,mv变化总量的等级值的平均值为1.2,假设数据量的等级值的平均值对应的权重为40%,mv变化总量的等级值的平均 值对应的权重为60%,则视频内容变化参数=40%*1.8+60%*1.2=1.44。根据每个gop对应的视频内容变化参数,采用第一预设规则,确定每个gop对应的判定参数。在本实施例中,将视频内容变化参数1.44,确定为该gop对应的判定参数。对每个gop的多媒体数据进行封装,并将确定的每个gop对应的判定参数1.44添加到对应的每个媒体表示描述mpd文件中。具体的,在本发明实施例中,当确定了gop对应的判定参数后,可以将该判定参数添加到该gop对应的dash分片索引的ciml(或styp/free/udta)box中。该cimlbox保存有一些成员变量,可以在该cimlbox中增加一个成员变量important_level,该成员变量important_level用于存储该gop对应的判定参数。为了便于计算,由于该cimlbox保存有一些成员变量,可以采用这些成员变量存储上述过程中确定的该gop中每一参考帧的数据量的等级值和/或运动矢量变化总量的等级值。当对多媒体文件进行封装时,针对该gop获取该gop对应的dash分片索引的cimlbox中保存的成员变量important_level存储的参数,将该参数作为该gop对应的判定参数添加到该gop对应的mpd文件中。在本实施例中,根据所述gop的多媒体数据中视频数据的每一参考帧的数据量和/或运动矢量变化总量,确定所述gop对应的视频内容变化参数,可以包括:针对每个参考帧,确定所述参考帧的数据量和运动矢量变化总量;当所述参考帧非所述gop中的最后一个参考帧时,根据所述参考帧的数据量和运动矢量变化总量,确定所述参考帧的数据量和运动矢量变化总量的等级值;并根据确定的所述等级值,及基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值;当所述参考帧为该gop中的最后一个参考帧时,根据所述参考帧的数据量和运动矢量变化总量,确定所述参考帧的数据量和运动矢量变化总量的等级值;并根据确定的所述等级值,及基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值,根据更新后的所述等级值的均值,确定所述gop对应的视频内容变化参数,并将所述视 频内容变化参数添加到基于dash分片索引box中视频内容变化参数对应的字段中。在对gop的多媒体数据的封装过程中,数据量的等级值的均值和/或运动矢量变化总量的等级值的均值及视频内容变化参数保存在基于dash分片索引box中相应的字段中,即上述的各成员变量对应的字段中。以上述第三种方案进行说明,数据量的等级值的均值保存在n1字段中,mv变化总量的等级值的均值保存在n2字段中,视频内容变化参数保存在m字段中。每封装一个p帧,对n1和n2字段中保存的均值进行迭代更新。例如,n1字段中保存的等级值的均值为2.2,n2字段中保存的等级值的均值为2.3,当前待封装的p帧的数据量的等级值为1.8,mv变化总量的等级值为1.7,则将n1字段中保存的等级值的均值更新为(2.2+1.8)/2=2,将n2字段中保存的等级值的均值更新为(2.3+1.7)/2=2。如此循环,直至封装到该gop中的最后一个p帧。根据此时n1字段和n2字段中保存的等级值的均值,确定该gop对应的视频内容变化参数。还以上述第三种方案中的例子进行说明,假设数据量的等级值的均值对应的权重为40%,mv变化总量的等级值的均值对应的权重为60%,此时n1字段中保存的数据量的等级值的均值为1.8,n2字段中保存的mv变化总量的等级值的均值为1.2,则视频内容变化参数=40%*1.8+60%*1.2=1.44,将该视频内容变化参数1.44添加到基于dash分片索引box中视频内容变化参数对应的字段中,即m字段中。需要说明的是,量化等级填充字段可以为32bit,采用大端对齐方式。dash数据分片生成以后,由于m字段位于分片索引box中,可直接读取并将其填充到mpd文件中的<segmenttemplatemedia="$bandwidth%/$time$.mp4vimportance="$level$">level字段即可。应用本发明图1所示实施例,根据所述gop的多媒体数据中视频数据的每一参考帧的数据量和/或运动矢量变化总量,确定所述gop对应的视频内容变化参数;根据每个gop对应的视频内容变化参数,采用第一预设规则,确定每个gop对应的判定参数;对每个gop的多媒体数据进行封装,并将确定的每个gop对应的判定参数添加到对应的每个媒体表示描述mpd文件中。参考帧的数据量、运动矢量变化总量均能反应多媒体内容的变化强度,因而,根据gop对应的判定参数能够判断该gop对应的多媒体数据是否包含使用价值较大的多 媒体内容。图2为本发明实施例提供的多媒体文件封装方法的第二种流程示意图,包括:s101b:针对采集的每个图像组gop的多媒体数据,根据所述gop的多媒体数据中音频数据的音量的平均值和/或音量变化强度,确定所述gop对应的音量参数。作为本发明的一种实施方式,采集到的多媒体数据按照iso14496-12国际标准规范以gop为单位进行封装。每一gop的多媒体数据中包括视频数据和音频数据,其中,音频数据紧跟在视频数据后面共同构成一段完整的多媒体数据。音量的剧烈变化或者异常的高分贝音量往往伴随着激烈的视频变化和物体运动,因此,音量的平均值和/或音量变化强度均能反应该音频数据对应的多媒体内容是否存在剧烈变化。s102b:根据每个gop对应的音量参数,采用第一预设规则,确定每个gop对应的判定参数量。其中音量参数越大对应的判定参数越大。在本发明所示实施例中,可以根据gop对应的音量参数,确定该gop对应的判定参数。例如可以直接将gop对应的音量参数,确定为该gop对应的判定参数。s103:对每个gop的多媒体数据进行封装,并将确定的每个gop对应的判定参数添加到对应的每个媒体表示描述mpd文件中。具体的,针对采集的每个图像组gop的多媒体数据,根据所述gop的多媒体数据中音频数据的音量的平均值和/或音量变化强度,确定所述gop对应的音量参数时,可以包括:根据所述gop的多媒体数据中音频数据的音量的平均值和音量变化强度,确定所述音频数据的音量的等级值和音量变化强度的等级值;根据所述音量的等级值和/或音量变化强度的等级值,确定所述gop对应的音量参数。根据所述gop的多媒体数据中音频数据的音量的平均值,及每个等级值对应的音量的平均值区间,确定所述音频数据的音量的等级值;根据音量变化强度,及每个等级值对应的音量变化强度区间,确定所述音频数据的音量变化强度的等级值。即,对音频数据的音量的平均值和/或音量变化强度进行量化。量化规则可以与本发明图1所示实施例中的表1所示的量化规则相同。其中,表1中 记录有数值范围与等级值的对应关系,数值范围即为音量的平均值或音量变化强度的对应范围,[min,max]为对应参数在当前时间段的正常数值范围。作为本发明的一种实施方式,根据所述音量的等级值和音量变化强度的等级值,确定所述gop对应的音量参数,可以包括:第一种方案,将所述音量的等级值确定为所述gop对应的音量参数。假设根据上述表1的量化规则得到的该gop中音频数据的音量的等级值为2,则该gop对应的音量参数为2。第二种方案,将所述音量变化强度的等级值确定为所述gop对应的音量参数。假设根据上述表1的量化规则得到的该gop中音频数据的音量变化强度的等级值为2.2,则该gop对应的音量参数为2.2。第三种方案,根据所述音量的等级值和音量变化强度的等级值,及所述音量的等级值和音量变化强度的等级值对应的权重值,确定所述gop对应的音量参数。假设根据上述表1的量化规则得到的该gop中音频数据的音量的等级值为2,音量的等级值对应的权重为70%;根据上述表1的量化规则得到的该gop中音频数据的音量变化强度的等级值为2.2,音量变化强度的等级值对应的权重为30%,则该gop对应的音量参数=2*70%+2.2*30%=2.06。根据每个gop对应的音量参数,采用第一预设规则,确定每个gop对应的判定参数,其中音量参数越大对应的判定参数越大。在本实施例中,将音量参数2.06,确定为该gop对应的判定参数。对每个gop的多媒体数据进行封装,并将确定的每个gop对应的判定参数2.06添加到对应的每个媒体表示描述mpd文件中。具体的,在本发明实施例中,当确定了gop对应的判定参数后,可以将该判定参数添加到该gop对应的dash分片索引的ciml(或styp/free/udta)box中。该cimlbox保存有一些成员变量,可以在该cimlbox中增加一个成员变量important_level,该成员变量important_level用于存储该gop对应的判定参数。为了便于计算,由于该cimlbox保存有一些成员变量,可以采用这些成员变量存储上述过程中确定的该gop中每一参考帧对应的时间段的音量的等级值和/或音量变化强度的等级值。当对多媒体文件进行封装时,针对该gop获取该gop对应的dash分片索引 的cimlbox中保存的成员变量important_level存储的参数,将该参数作为该gop对应的判定参数添加到该gop对应的mpd文件中。在本实施例中,根据所述gop的多媒体数据中音频数据的音量的平均值和/或音量变化强度,确定所述gop对应的音量参数,可以包括:将所述gop的多媒体数据中的音频数据划分成时长相等的多个时间段;针对每一时间段,确定所述时间段的音量的平均值和音量变化强度;当所述时间段非所述gop中的最后一个时间段时,根据所述时间段的音量的平均值和音量变化强度,确定所述时间段的音量的平均值和音量变化强度的等级值;并根据确定的所述等级值,及基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值;当所述时间段为该gop中的最后一个时间段时,根据所述时间段的音量的平均值和音量变化强度,确定所述时间段的音量的平均值和音量变化强度的等级值;并根据确定的所述等级值,及基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值,根据更新后的所述等级值的均值,确定所述gop对应的音量参数,并将所述音量参数添加到基于dash分片索引box中音量参数对应的字段中。在dash分片的封装过程中,音量的平均值和/或音量变化强度的等级值的均值及音量参数保存在基于dash分片索引box中相应的字段中。以上述第三种方案进行说明,音量的等级值的均值保存在n3字段中,音量变化强度的等级值的均值保存在n4字段中,音量参数保存在m字段中。每封装一个时间段的音频数据,对n3和n4字段中保存的均值进行迭代更新。例如,n3字段中保存的等级值的均值为1.5,n4字段中保存的等级值的均值为1.6,当前待封装的时间段的音量的等级值为1.7,音量变化强度的等级值为1.8,则将n3字段中保存的等级值的均值更新为(1.5+1.7)/2=1.6,将n4字段中保存的等级值的均值更新为(1.6+1.8)/2=1.7。如此循环,直至封装到该gop中的最后一个时间段的音频数据。根据此时n3字段和n4字段中保存的等级值的均值,确定该gop对应的音量参数。还以上述第三种方案中的例子进行说明,假设音量的等级值的均值对应的 权重为70%,音量变化强度的等级值的的均值对应的权重为60%,此时n3字段中保存的音量的等级值的均值为1.6,n4字段中保存的音量变化强度的等级值的均值为1.7,则音量参数=70%*1.6+30%*1.7=1.63,将该音量参数1.63添加到基于dash分片索引box中音量参数对应的字段中,即m字段中。需要说明的是,量化等级填充字段可以为32bit,采用大端对齐方式。dash数据分片生成以后,由于m字段位于分片索引box中,可直接读取并将其填充到mpd文件中的<segmenttemplatemedia="$bandwidth%/$time$.mp4vimportance="$level$">level字段即可。应用本发明图2所示实施例,根据所述gop的多媒体数据中音频数据的音量的平均值和/或音量变化强度,确定所述gop对应的音量参数;根据每个gop对应的音量参数,采用第一预设规则,确定每个gop对应的判定参数。其中音量参数越大对应的判定参数越大;对每个gop的多媒体数据进行封装,并将确定的每个gop对应的判定参数添加到对应的每个媒体表示描述mpd文件中。音频数据的音量的平均值、音量变化强度均能反应多媒体内容的变化强度,因而,根据gop对应的判定参数能够判断该gop对应的多媒体数据是否包含使用价值较大的多媒体内容。图3为本发明实施例提供的多媒体文件封装方法的第三种流程示意图,包括:s101c:针对采集的每个图像组gop的多媒体数据,根据所述gop的多媒体数据中视频数据的每一参考帧的数据量和/或运动矢量变化总量,确定所述gop对应的视频内容变化参数,和,根据所述gop的多媒体数据中音频数据的音量的平均值和/或音量变化强度,确定所述gop对应的音量参数。作为本发明的一种实施方式,采集到的多媒体数据按照iso14496-12国际标准规范以gop为单位进行封装。每一gop的多媒体数据中包括视频数据和音频数据,其中视频数据包括一个i帧和多个p帧、b帧,i帧是一个完整的画面,p帧、b帧记录的是相对于i帧的变化,p帧、b帧即为参考帧。在本发明所示实施例中,仅以p帧为例进行说明。可以按照每一p帧的时长,将所述gop的多媒体数据中的音频数据划分成时长相等的多个时间段。s102c:根据每个gop对应的视频内容变化参数和音量参数,采用第一预设规则,确定每个gop对应的判定参数。其中视频内容变化参数越大对应的判定参数越大,音量参数越大对应的判定参数越大。在本发明所示实施例中,根据下式确定每个gop对应的判定参数:gop对应的判定参数=所述gop对应的视频内容变化参数*第一权重值+所述gop对应的音量参数*第二权重值,其中第一权重值和第二权重值相同或不同。s103:对每个gop的多媒体数据进行封装,并将确定的每个gop对应的判定参数添加到对应的每个媒体表示描述mpd文件中。具体的,在本发明实施例中,当确定了gop对应的判定参数后,可以将该判定参数添加到该gop对应的dash分片索引的ciml(或styp/free/udta)box中。该cimlbox保存有一些成员变量,可以在该cimlbox中增加一个成员变量important_level,该成员变量important_level用于存储该gop对应的判定参数。为了便于计算,由于该cimlbox保存有一些成员变量,可以采用这些成员变量存储上述过程中确定的该gop中每一参考帧的数据量的等级值、运动矢量变化总量的等级值,每一时间段的音量的等级值、音量变化强度的等级值。当对多媒体文件进行封装时,针对该gop获取该gop对应的dash分片索引的cimlbox中保存的成员变量important_level存储的参数,将该参数作为该gop对应的判定参数添加到该gop对应的mpd文件中。在dash分片的封装过程中,每一参考帧的数据量的等级值的均值、运动矢量变化总量的等级值的均值,每一时间段的音量的等级值的均值、音量变化强度的等级值的均值,及该gop对应的视频内容变化参数、音量参数均保存在基于dash分片索引box中相应的字段中。假设如表2所示,数据量的等级值的均值保存在n1字段中,mv变化总量的等级值的均值保存在n2字段中,音量的等级值的均值保存在n3字段中,音量变化强度的等级值的均值保存在n4字段中,m字段中保存的是该gop对应的判定参数,该gop对应的判定参数=所述gop对应的视频内容变化参数*第一权重值+所述gop对应的音量参数*第二权重值。每封装一个p帧及该p帧对应的时间段的音频数据,对n1-n4字段中保存的均值进行迭代更新,更新的方式可以采用本发明图1和图2所示实施例中公开的方案,在此不做赘述。表2n1n2n3n4m当封装到该gop中的最后一个p帧及该p帧对应的时间段的音频数据时,根据此时n1-n4字段中保存的等级值的均值,确定该gop对应的判定参数。假设根据本发明图1和图2所示实施例中公开的方案,得到该gop对应的视频内容变化参数为1.44,该gop对应的音量参数为2.06,则该gop对应的判定参数=所述gop对应的视频内容变化参数*第一权重值+所述gop对应的音量参数*第二权重值,假设第一权重值为70%,第二权重值为30%,则该gop对应的判定参数=1.44*70%+2.06*30%=1.626。将该gop对应的判定参数1.626添加到基于dash分片索引box中gop对应的判定参数对应的字段中,即m字段中。需要说明的是,量化等级填充字段可以为32bit,采用大端对齐方式。dash数据分片生成以后,由于m字段位于分片索引box中,可直接读取并将其填充到mpd文件中的<segmenttemplatemedia="$bandwidth%/$time$.mp4vimportance="$level$">level字段即可。应用本发明图3所示实施例,根据所述gop的多媒体数据中视频数据的每一参考帧的数据量和/或运动矢量变化总量,确定所述gop对应的视频内容变化参数;根据所述gop的多媒体数据中音频数据的音量的平均值和/或音量变化强度,确定所述gop对应的音量参数;根据每个gop对应的视频内容变化参数和音量参数,采用第一预设规则,确定每个gop对应的判定参数。其中视频内容变化参数越大对应的判定参数越大,音量参数越大对应的判定参数越大;对每个gop的多媒体数据进行封装,并将确定的每个gop对应的判定参数添加到对应的每个媒体表示描述mpd文件中。参考帧的数据量、运动矢量变化总量、音频数据的音量的平均值、音量变化强度均能反应多媒体内容的变化强度,因而,根据gop对应的判定参数能够判断该gop对应的多媒体数据是否包含使用价值较大的多媒体内容。下面对本发明实施例提供的一种应用于客户端的多媒体文件播放方法进行详细说明。图4为本发明实施例提供的多媒体文件播放方法的第一种流程示意图,包括:s201:向摄像机或服务器发送获取请求,以使所述摄像机或服务器将一个gop的多媒体数据对应的媒体表示描述mpd文件发送给所述客户端。客户端在获取每一gop的多媒体数据之前,先向摄像机或服务器发送获取请求,从摄像机或服务器获取该gop对应的mpd文件。应用本发明图1-图3 所示实施例的摄像机或服务器生成的mpd文件中包括该gop对应的判定参数。s202:接收mpd文件,读取mpd文件中的gop对应的判定参数。客户端接收上述摄像机或服务器发送的mpd文件,读取mpd文件中的该gop对应的判定参数。s203:根据所述gop对应的判定参数,确定所述gop的多媒体数据的第一播放码率。其中,所述gop对应的判定参数越大所述第一播放码率越大。根据gop对应的判定参数能够判断该gop对应的多媒体数据是否包含使用价值较大的多媒体内容。gop对应的判定参数越大,该gop对应的多媒体数据中包含的多媒体内容使用价值越大,因而,该gop对应的多媒体数据的播放码率应该越大。s204:将第一播放码率发送给所述摄像机或服务器,并以第一播放码率对摄像机或服务器发送的所述gop的多媒体数据进行解码播放。作为本发明的一种实施方式,可以建立gop对应的判定参数的范围与播放码率的判定表,如表3所示:表3判定参数<0.5>=0.5&&<=1>1&&<=3>3播放码率1m2m4m8m假设客户端接收的mpd文件中的gop对应的判定参数为1.66,则确定该gop的多媒体数据的第一播放码率为4m,将第一播放码率4m发送给摄像机或服务器,并以第一播放码率4m对摄像机或服务器发送的该gop的多媒体数据进行解码播放。上述方案适用于对视频细节内容要求很高的场景,在一般场景中,通常根据网络带宽和缓冲区等级中至少一个及所述gop对应的判定参数,确定所述gop的多媒体数据的第一播放码率。也就是说,确定所述gop的多媒体数据的播放码率,在考虑所述gop对应的判定参数的同时,也要考虑网络带宽、缓冲区等级等其他参数。具体的,可以根据所述gop对应的判定参数、网络带宽和缓冲区等级,及所述gop对应的判定参数、网络带宽和缓冲区等级对应的权重值,确定所述gop的多媒体数据的第一播放码率。作为本发明的一种实施方式,可以根据不同的场景,对不同参数的权重值进行设定。对视频细节内容要求较高的场景,该gop对应的判定参数占的权重 可以较大一些,而希望视频数据播放流畅的场景,网络带宽占的权重可以较大一些。具体的,也可以对网络带宽和缓冲区等级进行量化,可以利用本发明图1所示实施例中表1所示的量化规则,假设得到的网络带宽的等级值为1.4,缓冲区等级对等级值为1.6,网络带宽对应的权重为30%,缓冲区等级对应的权重为30%,另外,gop对应的判定参数为1.66,gop对应的判定参数对应的权重为40%,则综合判定值=1.4*30%+1.6*30%+1.66*40%=1.564。作为本发明的一种实施方式,可以建立综合判定值与播放码率的对应表,如表4所示,表4中记录有综合判定值范围与播放码率的对应关系:表4综合判定值<0.5>=0.5&&<=1>1&&<=3>3播放码率1m2m4m8m则确定该gop的多媒体数据的第一播放码率为4m,将第一播放码率4m发送给摄像机或服务器,并以第一播放码率4m对摄像机或服务器发送的该gop的多媒体数据进行解码播放。应用本发明图4所示实施例,客户端根据所述gop对应的判定参数,确定所述gop的多媒体数据的第一播放码率,以使摄像机或服务器将所述gop的多媒体数据发送给客户端,客户端以该第一播放码率将该gop的多媒体数据进行解码播放摄像机或服务器。客户端根据gop对应的判定参数能够判断该gop对应的多媒体数据是否包含使用价值较大的多媒体内容,能够实现根据多媒体内容,确定多媒体数据的播放码率。图5为本发明实施例提供的多媒体文件播放方法的第二种流程示意图,本发明图5所示实施例在图4所示实施例的基础上,在s204之前,增加如下步骤:s205:提取保存的所述gop之前的设定数量个gop的多媒体数据的理论播放码率;s206:判断第一播放码率与设定数量个理论播放码率的差值是否都小于预设阈值,如果是,执行s204,如果否,执行s207。s207:将所述设定数量个理论播放码率中最前面一个理论播放码率确定为调整后的第一播放码率,并执行s204。在s204之后增加s208。s208:将所述第一播放码率保存为所述gop的多媒体数据的理论播放码率, 并将所述调整后的第一播放码率保存为所述gop的多媒体数据的实际播放码率。假设确定的当前gop的第一播放码率为4m,提取保存的该gop之前的2个gop的多媒体数据的理论播放码率均为1m,假设预设阈值为0.5m,第一播放码率与该2个理论播放码率的差值3m大于预设阈值0.5m,即确定的该gop的播放码率相比于之前的2个gop的播放码率差别较大,这种情况可能只是短暂的网络异常,当然也有可能是视频内容出现了剧烈变化。此时,并不立刻切换多媒体数据的播放码率,而是将之前的2个gop的多媒体数据的理论播放码率中最前面一个理论播放码率1m确定为调整后的第一播放码率,将调整后的第一播放码率1m发送给摄像机或服务器,仍以1m的播放码率对摄像机或服务器发送的该gop的多媒体数据进行解码播放。另外,将确定的第一播放码率4m保存为所述gop的多媒体数据的理论播放码率,将该调整后的第一播放码率1m保存为该gop的多媒体数据的实际播放码率。如果确定的下一gop的第一播放码率仍为4m,保存的该gop之前2个gop的理论播放码率分别为1m和4m,该gop的第一播放码率与该2个第二播放码率的差值为3m和0m,不都小于预设阈值,将之前的2个gop的多媒体数据的理论播放码率中最前面一个理论播放码率1m确定为调整后的第一播放码率,将调整后的第一播放码率1m发送给摄像机或服务器,仍以1m的播放码率对摄像机或服务器发送的该gop的多媒体数据进行解码播放。另外,将确定的第一播放码率4m保存为所述gop的多媒体数据的理论播放码率,将该调整后的第一播放码率1m保存为该gop的多媒体数据的实际播放码率。如果确定的再下一gop的第一播放码率仍为4m,保存的该gop之前2个gop的第二播放码率均为4m,该gop的第一播放码率与该2个理论播放码率的差值均为0m,都小于预设阈值,此时,已经连续3个gop的确定的播放码率为4m,说明出现的情况不是短暂的网络异常,而是视频内容出现了剧烈变化,此时将确定的第一播放码率4m发送给摄像机或服务器,以4m的播放码率对摄像机或服务器发送的该gop的多媒体数据进行解码播放。另外,保存所述gop的多媒体数据的理论播放码率和实际播放码率,所述gop的多媒体数据的理论播放码率和实际播放码率均为4m。应用本发明图5所示实施例,当播放码率出现突变时,并不立刻切换播放码率,而是在此后连续几个gop的播放码率都比较稳定的情况下才切换码率,避 免了仅仅因为短暂的网络异常而切换播放码率所造成的画面卡顿和抖动现象。与上述的方法实施例相对应,本发明实施例还提供一种应用于摄像机或服务器的多媒体文件封装装置和一种应用于客户端的多媒体文件播放装置。下面首先对本发明实施例提供的一种应用于摄像机或服务器的多媒体文件封装装置进行详细说明。图6为本发明实施例提供的多媒体文件封装装置的第一种结构示意图,包括:第一确定模块301、第二确定模块302和封装模块303,其中,第一确定模块301,用于针对采集的每个图像组gop的多媒体数据,确定所述gop对应的视频内容变化参数和/或音量参数,其中根据所述gop的多媒体数据中视频数据的每一参考帧的数据量和/或运动矢量变化总量,确定所述gop对应的视频内容变化参数;根据所述gop的多媒体数据中音频数据的音量的平均值和/或音量变化强度,确定所述gop对应的音量参数;第二确定模块302,用于根据每个gop对应的视频内容变化参数和/或音量参数,采用第一预设规则,确定每个gop对应的判定参数;封装模块303,用于对每个gop的多媒体数据进行封装,并将确定的每个gop对应的判定参数添加到对应的每个媒体表示描述mpd文件中。具体的,第二确定模块302,具体用于根据下式确定每个gop对应的判定参数:gop对应的判定参数=所述gop对应的视频内容变化参数*第一权重值+所述gop对应的音量参数*第二权重值,其中第一权重值和第二权重值相同或不同。作为本发明的一种实施方式,第一确定模块301,可以包括:第一确定子模块、第二确定子模块、第三确定子模块和第四确定子模块(图中未示出),其中,第一确定子模块,用于根据所述gop的多媒体数据中每一参考帧的数据量和运动矢量变化总量,确定所述gop中所有参考帧的数据量的和以及运动矢量变化总量的和;第二确定子模块,用于根据所述gop中包含的参考帧的数量,及所述所有参考帧的数据量的和以及运动矢量变化总量的和,确定所述gop对应的平均数据量和平均运动矢量变化总量;第三确定子模块,用于根据所述平均数据量和所述平均运动矢量变化总量,确定所述平均数据量的等级值和所述平均运动矢量变化总量的等级值;第四确定子模块,用于根据所述平均数据量的等级值和所述平均运动矢量变化总量的等级值,确定所述gop对应的视频内容变化参数。作为本发明的一种实施方式,第一确定模块301,可以包括:第五确定子模块和第六确定子模块(图中未示出),其中,第五确定子模块,用于根据所述gop的多媒体数据中每一参考帧的数据量和运动矢量变化总量,确定每一参考帧的数据量的等级值和运动矢量变化总量的等级值;和/或,根据所述gop的多媒体数据中音频数据的音量的平均值和音量变化强度,确定所述音频数据的音量的等级值和音量变化强度的等级值;第六确定子模块,用于根据所述gop中包含的参考帧的数量,及每一参考帧的数据量的等级值和/或运动矢量变化总量的等级值,确定所述gop对应的视频内容变化参数;和/或,根据所述音量的等级值和/或音量变化强度的等级值,确定所述gop对应的音量参数。作为本发明的一种实施方式,第六确定子模块,具体可以用于:根据所述gop中包含的参考帧的数量,及每一参考帧的数据量的等级值,确定数据量的等级值的平均值,将所述数据量的等级值的平均值确定为所述gop对应的视频内容变化参数;或,根据所述gop中包含的参考帧的数量,及每一参考帧的运动矢量变化总量的等级值,确定运动矢量变化总量的等级值的平均值,将所述运动矢量变化总量的等级值的平均值确定为所述gop对应的视频内容变化参数;或,根据所述gop中包含的参考帧的数量,及每一参考帧的数据量的等级值和运动矢量变化总量的等级值,确定数据量的等级值的平均值和运动矢量变化总量的等级值的平均值,根据每个平均值对应的权重值,确定所述gop对应的视频内容变化参数;和/或,将所述音量的等级值确定为所述gop对应的音量参数;或,将所述音量变化强度的等级值确定为所述gop对应的音量参数;或,根据所述音量的等级值和音量变化强度的等级值,及所述音量的等级值和音量变化强度的等级值对应的权重值,确定所述gop对应的音量参数。作为本发明的一种实施方式,第一确定模块301,具体可以用于:针对每个参考帧,确定所述参考帧的数据量和运动矢量变化总量;当所述参考帧非所述gop中的最后一个参考帧时,根据所述参考帧的数据量和运动矢量变化总量,确定所述参考帧的数据量和运动矢量变化总量的等级值;并根据确定的所述等级值,及基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值;当所述参考帧为该gop中的最后一个参考帧时,根据所述参考帧的数据量和运动矢量变化总量,确定所述参考帧的数据量和运动矢量变化总量的等级值;并根据确定的所述等级值,及基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中数据量和/或运动矢量变化总量对应的字段中保存的等级值的均值,根据更新后的所述等级值的均值,确定所述gop对应的视频内容变化参数,并将所述视频内容变化参数添加到基于dash分片索引box中视频内容变化参数对应的字段中;和/或,将所述gop的多媒体数据中的音频数据划分成时长相等的多个时间段;针对每一时间段,确定所述时间段的音量的平均值和音量变化强度;当所述时间段非所述gop中的最后一个时间段时,根据所述时间段的音量的平均值和音量变化强度,确定所述时间段的音量的平均值和音量变化强度的等级值;并根据确定的所述等级值,及基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值;当所述时间段为该gop中的最后一个时间段时,根据所述时间段的音量的平均值和音量变化强度,确定所述时间段的音量的平均值和音量变化强度的等级值;并根据确定的所述等级值,及基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值,更新所述基于dash分片索引box中音量的平均值和/或音量变化强度对应的字段中保存的等级值的均值,根据更新后的所述等级值的均值,确定所述gop对应的音量参数,并将所述音量参数添加到基于dash分片索引box中音量参数对应的字段中。应用本发明图6所示实施例,根据所述gop的多媒体数据中视频数据的每一参考帧的数据量和/或运动矢量变化总量,确定所述gop对应的视频内容变化参数;根据所述gop的多媒体数据中音频数据的音量的平均值和/或音量变化强度, 确定所述gop对应的音量参数;根据每个gop对应的视频内容变化参数和音量参数,采用第一预设规则,确定每个gop对应的判定参数。对每个gop的多媒体数据进行封装,并将确定的每个gop对应的判定参数添加到对应的每个媒体表示描述mpd文件中。参考帧的数据量、运动矢量变化总量、音频数据的音量的平均值、音量变化强度均能反应多媒体内容的变化强度,因而,根据gop对应的判定参数能够判断该gop对应的多媒体数据是否包含使用价值较大的多媒体内容。下面对本发明实施例提供的一种应用于客户端的多媒体文件播放装置进行详细说明。图7为本发明实施例提供的多媒体文件播放装置的第一种结构示意图,包括:发送模块401、读取模块402、第三确定模块403和播放模块404,其中,发送模块401,用于向所述摄像机或服务器发送获取请求,以使所述摄像机或服务器将一个gop的多媒体数据对应的媒体表示描述mpd文件发送给所述客户端;读取模块402,用于接收所述mpd文件,读取所述mpd文件中的所述gop对应的判定参数;第三确定模块403,用于根据所述gop对应的判定参数,确定所述gop的多媒体数据的第一播放码率;具体的,第三确定模块403,具体可以用于根据网络带宽和缓冲区等级中至少一个及所述gop对应的判定参数,确定所述gop的多媒体数据的第一播放码率。作为本发明的一种实施方式,第三确定模块403,具体可以用于根据所述gop对应的判定参数、网络带宽和缓冲区等级,及所述gop对应的判定参数、网络带宽和缓冲区等级对应的权重值,确定所述gop的多媒体数据的第一播放码率。播放模块404,用于将所述第一播放码率发送给所述摄像机或服务器,并以所述第一播放码率对所述摄像机或服务器发送的所述gop的多媒体数据进行解码播放。应用本发明图7所示实施例,客户端根据所述gop对应的判定参数,确定所述gop的多媒体数据的第一播放码率,以使摄像机或服务器将所述gop的多媒体数据发送给客户端,客户端以该第一播放码率将该gop的多媒体数据进行解 码播放摄像机或服务器。客户端根据gop对应的判定参数能够判断该gop对应的多媒体数据是否包含使用价值较大的多媒体内容,能够实现根据多媒体内容,确定多媒体数据的播放码率。图8为本发明实施例提供的多媒体文件播放装置的第二种结构示意图,本发明图8所示实施例在图7所示实施例的基础上,还可以包括:提取模块405、判断模块406、第四确定模块407和保存模块408,其中,提取模块405,用于提取保存的所述gop之前的设定数量个gop的多媒体数据的理论播放码率;判断模块406,用于判断所述第一播放码率与设定数量个理论播放码率的差值是否都小于预设阈值,如果是,触发播放模块404,如果否,触发第四确定模块407;第四确定模块407,用于将所述设定数量个理论播放码率中最前面一个理论播放码率确定为调整后的第一播放码率,并触发播放模块404;保存模块408,用于将所述第一播放码率保存为所述gop的多媒体数据的理论播放码率,并将所述调整后的第一播放码率保存为所述gop的多媒体数据的实际播放码率。应用本发明图8所示实施例,当播放码率出现突变时,并不立刻切换播放码率,而是在此后连续几个gop的播放码率都比较稳定的情况下才切换码率,避免了仅仅因为短暂的网络异常而切换播放码率所造成的画面卡顿和抖动现象。需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。本说明书中的各个实施例均采用相关的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于装置实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。本领域普通技术人员可以理解实现上述方法实施方式中的全部或部分步骤是可以通过程序来指令相关的硬件来完成,所述的程序可以存储于计算机可读取存储介质中,这里所称得的存储介质,如:rom/ram、磁碟、光盘等。以上所述仅为本发明的较佳实施例而已,并非用于限定本发明的保护范围。凡在本发明的精神和原则之内所作的任何修改、等同替换、改进等,均包含在本发明的保护范围内。当前第1页12