• 音视频的基本概念


    音视频通用的基本概念有码率、时长,而不同音视频有不同的封装格式、编码协议。其中视频关键参数有分辨率、帧率、画质、旋转角度、像素格式,而音频关键参数有采样率、声道数、声道布局、音质、采样数、采样位数、帧时长。接下来与大家详细探讨。

    音视频背景
    ISO:国际标准化组织,官方网址:ISO - International Organization for Standardization。很多音视频协议都可以从这里找到。

    MPEG:ISO与IEC下属的针对运动图像与语音压缩制定国际标准的组织,全称为运动图像专家组(Moving Picture Experts Group),官网网址:https://mpeg.chiariglione.org。

    IETF:互联网工程任务组(Internet Engineering Task Force),官方网址:https://www.ietf.org。常见的网络协议、多媒体通信协议的地址:https://tools.ietf.org/html/。

    MPEG发展历史

    带着问题寻找答案
    1) 如何计算视频平均码率和传输动态码率;

    2) 如何切换在线视频分辨率;

    3) 如何实现自适应与全屏播放;

    4) 如何实现倍速播放;

    5) 摄像头为什么能抓拍到汽车超速;

    6) 为什么有些视频默认横屏显示,有些竖屏显示;

    7) 如何得到视频的时长;

    一、视频
    1、码率
    码率,又叫比特率,单位时间内传输的数据量,单位一般为kbps(千位每秒)。需要注意的是,这里b代表bit,而不是byte。计算公式:平均码率(kbps)=文件大小(kb)*8/时间(s)。动态码率(kbps)=每秒传输数据量(kb)*8。

    恒定码率:CBR,码率稳定可控,带宽要求不高,图像变化量比较大时方块效应比较明显。

    动态码率:VBR,码率波动较大,带宽要求较高,图像变化量比较大时方块效应有所改善。发生网络抖动时,比较容易丢包,需要重传,或者FEC前向纠错,从而带来延时。

    2、分辨率
    分辨率又称为解析度,分辨率越高,像素越多,图像越清晰。

    视频分辨率:又称为图像分辨率,由视频的宽高组成,表示形式宽x高,常见的视频分辨率有480P、720P、1080P、2K(2048x1080/2160x1440)、4K(4096x2160/3840x2160),具体如下表1所示。

    屏幕分辨率:又称为显示分辨率,描述屏幕分辨率的单位是ppi(pixel per inch,每英寸的像素数)。

    位分辨率:又称为位深(BitDepth),每个像素点存储信息的位数。常见的有:8位、16位、24位、32位色彩。Android的Bitmap常见的有ALPHA_8、RGB_565、ARGB_4444、ARGB_8888。

    3、帧率
    视频帧率:测量显示帧数的量度,单位为每秒显示帧数(FPS,全称为Frame Per Second)。一般视频帧率为24fps,P制(PAL,德国提出,中国、印度、巴基斯坦等国家使用)为25fps,也就是每帧显示40ms,N制(NTSC,美国标准委员会提出,美国、日本、韩国等国家使用)为30fps。有些超高帧率的视频达到60fps。

    显示帧率:以帧为单位的位图图像连续出现在显示器的频率,也称为刷新速率。Android设备刷新率一般为60Hz,也就是帧率为60fps,每帧为16ms,超过16ms能给人的肉眼带来延迟卡顿的感觉。做性能优化方面,也就是保证从测量、布局、绘制、上传指令、与GPU交换缓冲区等一系列动作在16ms完成。Android11支持120Hz的更高帧率,一般为对帧率要求极高的应用场景,比如互动游戏。

    4、像素格式
    像素格式:像素色彩分量的排列,由每个像素使用的总位数以及各分量的位数决定。图像的像素格式一般是RGBA四个分量通道各占8bits,组成一个32位的像素。其中R代表Red、G代表Green、B代表Blue、A代表Alpha。但是,视频压缩存储的像素格式不是RGBA,而是YUV,其中Y代表亮度(Luma),U代表色度(Chroma),V代表对比度(Contrast)。

    CSDN站内私信我,或文末免费领取最新最全C++/音视频开发学习提升资料,内容包括(C/C++,Linux 服务器开发,FFmpeg ,webRTC ,rtmp ,hls ,rtsp ,ffplay ,srs)以及音视频学习路线图等等。 

    5、画质
    画质:画面质量,由清晰度、锐度、解析度、色彩纯度、色彩平衡等指标构成。

    清晰度:指图像细节纹理及其边界的清晰程度。

    锐度:反应图像平面清晰程度,以及图像边缘的锐利程度。

    解析度:指像素点的数量,与分辨率对应,分辨率越高,解析度越高。

    色彩纯度:指色彩的鲜艳程度。所有色彩都是三原色组成,其他颜色都是三原色混合而成,理论上可以混合出256种颜色。原色的纯度最高。色彩纯度是指原色在色彩中的百分比。

    色彩平衡:用来控制图像的色彩分布,使得图像整体达到色彩平衡。

    6、色域与HDR
    色域:指某种表色模式所能表达的颜色构成的范围区域,色域空间越大,所能表现的颜色越多。

    HDR:High Danamic Range,高动态范围,比普通图像提供更多动态范围和图像细节,能够更好反应真实环境的视觉效果。颜色值经过归一化后,范围一般是[0,1]。而HDR可以表达超出1的颜色值,拥有更大的颜色范围。

    7、旋转角度
    旋转角度:视频的YUV储存方向。一般的视频旋转角度是0°,对应的是横屏显示。后置摄像头竖屏拍的视频,旋转角度为90°,对应的是竖屏显示。Android中可以通过MediaMetaDataRetriever获取旋转角度。

    8、时长
    视频所有图像播放所需要的时间称为视频时长。计算公式:时长(s)=帧数x每帧时长=帧数x(1/帧率)。假设一个视频帧数为1000,帧率为25fps,那么时长为40s。

    9、封装格式
    视频的封装格式,由特定格式头+媒体信息+音视频轨(字幕)数据+视频轨索引组成。常见的封装格式有:mp4、mkv、webm、avi、3gp、mov、wmv、flv、mpeg、asf、rmvb等。

    10、编码协议
    视频经过解封装得到的视频轨数据,是经过编码的,所以显示视频帧前需要解码。不同编码算法组成不同编码协议,常见的有:H264(AVC,一般使用x264编码)、H265(HEVC,一般使用x265编码)、VP8、VP9、MPEG4、MJPEG、WMV3等。

    二、音频
    1、采样率
    采样率:对声音信号每秒的采样次数,采样率越高,声音的还原越真实。采样率单位为Hz,常见的采样率有:8000Hz、16000Hz、44100Hz、48000Hz。人类一般能够听到的声音范围:20Hz~20000Hz。根据奈奎斯特采样定理:当采样频率大于信号中最高频率的2倍时,采样后的数字信号能够完整保留原始信号的信息。

    2、声道
    声道:指声音在录制或播放时,在不同空间位置采集或回放的相互独立音频信号。声道数指在录音时的音源数量,或者在播放时的扬声器数量。

    3、声道布局
    不同声道数对应不同声道布局。常见的声道布局有单声道(mono)、立体声道(stereo)、四声环绕、5.1声道。

    单声道:只有一个声道,优点数据量小,amr_nb和amr_wb默认为单声道,缺点是缺乏对声音位置定位。

    立体声道:一般为两个声道,由左声道、右声道组成,改善对声音位置定位的状况。

    四声环绕:由前左、前右、后左、后右组成,形成立体环绕。4.1声道是在四声环绕基础上,增加一个低音。

    5.1声道:在4.1基础上,增加一个中场声道,杜比AC3就是采用5.1声道,也就是影院宣传的杜比音效。

    4、音质
    音质:声音的质量,经过编码压缩后的音频信号保真度,由音量、音高和音色组成。

    音量:音频的强度,数值范围0-100,静音时为0,最大值为100。Android中有提供音量增强LoudnessEnhancer,调节声音分贝值。

    音高:声音的音调,即音频频率或每秒变化次数。

    音色:音频泛音,又称为音品,不同声音表现在波形方面与众不同的特性。

    5、封装格式
    音频的封装格式,与视频封装格式类似,由特定格式头+媒体信息+音频轨数据组成。常见的封装格式有:mp3、m4a、ogg、amr、wma、wav、flac、aac、ape等。

    6、编码协议
    音频经过解封装得到的音频轨数据,也是经过编码的。常见的音频编码协议有:mp3、aac、amr_nb、amr_wb、ac3、vorbis、opus、flac、wmav2等。

    7、采样数
    采样数,即每帧采样的数量。在FFmpeg的AVFrame中,定义为nb_samples。

    8、采样位数
    采样位数,即每个采样占用多少位。在RIFF(Resource Interchange File Format)资源交换文件格式有个字段bits_per_sample表示采样位数,在FFmpeg也是用这个字段表示采样位数。

    9、存储空间
    音频的每秒存储空间由:采样率、声道数、每个采样位数。假设采样率为44.1k,声道数为2,采样位数为16。那么,每秒所占存储空间字节数=44100 * 2 * 16 / 8

    10、帧时长
    音频的帧时长=采样数 / 采样率。假设采样率为44.1k,采样数为1024。那么每帧时长约等于23ms。

    11、采样格式
    音频的采样格式分为大端存储和小端存储。按照符号划分有:有符号与无符号。按照类型划分有:整型与浮点型。按照存储位数划分有:8位、16位、32位、64位,都是8的倍数。在FFmpeg的AVSampleFormat枚举如下:

    1. enum AVSampleFormat {
    2. AV_SAMPLE_FMT_NONE = -1,
    3. AV_SAMPLE_FMT_U8, // unsigned 8 bits
    4. AV_SAMPLE_FMT_S16, // signed 16 bits
    5. AV_SAMPLE_FMT_S32, // signed 32 bits
    6. AV_SAMPLE_FMT_FLT, // float
    7. AV_SAMPLE_FMT_DBL, // double
    8. AV_SAMPLE_FMT_U8P, // unsigned 8 bits, planar
    9. AV_SAMPLE_FMT_S16P, // signed 16 bits, planar
    10. AV_SAMPLE_FMT_S32P, // signed 32 bits, planar
    11. AV_SAMPLE_FMT_FLTP, // float, planar
    12. AV_SAMPLE_FMT_DBLP, // double, planar
    13. AV_SAMPLE_FMT_S64, // signed 64 bits
    14. AV_SAMPLE_FMT_S64P, // signed 64 bits, planar
    15. AV_SAMPLE_FMT_NB // Number of sample formats
    16. };

     

     

     

  • 相关阅读:
    数据库到底是什么?举例MySQL给你讲明白
    Win11怎么修改关机界面颜色?Win11修改关机界面颜色的方法
    分享几个简单实用的 JavaScript 优雅小技巧!
    如何在电脑上设置新的蓝牙耳机
    逆向-还原代码之split (Intel 32)
    持续交付中流水线构建完成后就大功告成了吗?别忘了质量保障
    深度学习入门(四十三)计算机视觉——锚框
    【Unity3D】选中物体描边特效
    PS软件 点击 “另存为 Web 所用格式” ,提示错误 无法完成操作 系统找不到指定路径
    【完美世界】被骂国漫之耻,石昊人设战力全崩,现在真成恋爱世界了
  • 原文地址:https://blog.csdn.net/yinshipin007/article/details/127778138