音视频入门基础:FLV专题(12)——FFmpeg源码中,解析DOUBLE类型的ScriptDataValue的实现

一、引言

从《音视频入门基础:FLV专题(9)------Script Tag简介》中可以知道,根据《video_file_format_spec_v10_1.pdf》第80到81页,SCRIPTDATAVALUE类型由一个8位(1字节)的Type和一个ScriptDataValue组成。其中Type属性用来指定ScriptDataValue的类型,根据Type值的不同,ScriptDataValue的类型也不同。当Type的值为0时,ScriptDataValue为DOUBLE类型:

根据《swf-file-format-spec.pdf》第16页,DOUBLE类型为IEEE-754双精度浮点数。存贮DOUBLE类型数据需要占用8个字节:

FFmpeg源码中通过av_int2double函数解析DOUBLE类型的ScriptDataValue。

二、av_int2double函数的定义

av_int2double函数定义在FFmpeg源码(本文演示用的FFmpeg源码版本为7.0.1)的头文件libavutil/intfloat.h中:

cpp 复制代码
/**
 * Reinterpret a 64-bit integer as a double.
 */
static av_always_inline double av_int2double(uint64_t i)
{
    union av_intfloat64 v;
    v.i = i;
    return v.f;
}

该函数的作用是将64位整数重新解释为double类型。C、C++中使用到的双精度浮点数(double)类型是在IEEE二进制浮点数算术标准(IEEE-754)中定义的。双精度浮点数(Double)用来表示带有小数部分的实数,一般用于计算机编程中定义变量,占用8个字节存储空间。所以av_int2double函数的作用就是从内存中读取8个字节(形参i存贮的64位整数),将其转换为double类型返回。

形参i:输入型参数,需要被重新解释的64位整数。

返回值:转换得到的double类型数据。

联合体av_intfloat64声明在libavutil/intfloat.h中:

cpp 复制代码
union av_intfloat64 {
    uint64_t i;
    double   f;
};

三、av_int2double函数的实际用法

比如想要将下图红框中的64位数据"0x40 0x29 0xCC 0xCC 0xCC 0xCC 0xCC 0xCD"转换为double类型数据:

通过Windows自带的计算器可以算出"0x40 0x29 0xCC 0xCC 0xCC 0xCC 0xCC 0xCD"对应的十进制整数为:4623451672453893325:

执行语句:

cpp 复制代码
   double num_val = av_int2double(4623451672453893325);

num_val即可得到转换得到的double类型数据,即12.9。

相关推荐
ai产品老杨1 天前
打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程的智慧工业开源了
人工智能·开源·音视频·能源
非凡ghost1 天前
FxSound:提升音频体验,让音乐更动听
前端·学习·音视频·生活·软件需求
Ai工具分享1 天前
视频画质差怎么办?AI优化视频清晰度技术原理与实战应用
人工智能·音视频
萌虎不虎2 天前
【鸿蒙(openHarmony)自定义音频播放器的开发使用说明】
华为·音视频·harmonyos
Hi202402172 天前
Orin-Apollo园区版本:订阅多个摄像头画面拼接与硬编码RTMP推流
ffmpeg·apollo·orin·图像拼接·图传
知来者逆2 天前
视觉语言模型应用开发——Qwen 2.5 VL模型视频理解与定位能力深度解析及实践指南
人工智能·语言模型·自然语言处理·音视频·视觉语言模型·qwen 2.5 vl
max5006002 天前
图像处理:实现多图点重叠效果
开发语言·图像处理·人工智能·python·深度学习·音视频
Antonio9152 天前
【音视频】WebRTC 音视频延时、同步分析以及超低延时优化
音视频·webrtc
9527华安2 天前
Xilinx系列FPGA实现DP1.4视频收发,支持4K60帧分辨率,提供2套工程源码和技术支持
fpga开发·音视频·dp1.4·4k60帧