博客
关于我
基于librtmp客户端记录(H264+AAC)
阅读量:363 次
发布时间:2019-03-04

本文共 2532 字,大约阅读时间需要 8 分钟。

  基于librtmp开发rtmp客户端的demo,主要是按照雷神的demo(见5.1)来修改,修改后的demo能将获取到的音视频数据写成h264文件及aac文件。

1、flv格式

  介绍flv格式的博客有很多,个人觉得5.2及5.3结合起来看比较好,其中5.2的script tag应该得值是12才是对的。摘录些重要的。

在这里插入图片描述
  flv的tag类型有三种,video(9), audio(8), script_data(12)。
  tag的组成如下:
在这里插入图片描述
  如果视频格式是AVC(h264)的话,VideoTagHeader会多出4个字节的信息分别是一字节的AVCPacketType 和3字节的CompositionTime。
来自参考5.3的video tag及audio tag的图。
在这里插入图片描述
在这里插入图片描述

2、注意

  h264的sps及pps数据在发送视频帧之前会首先单独发送过来,需要做保存,因为有些rtmp serevr不会在每一个I帧前添加这些信息。

  收到的AAC音频需要根据解析到AAC格式信息添加adts头部,代表AAC音频采样率的2bit其值总是3

3、添加ADTS头部

/* *注意,这里的packetLen参数为raw aac Packet Len + 7; 7 bytes adts header */static void addADTStoPacket(char* packet, int packetLen, int frequence) {      int profile = 2;  //AAC LC,MediaCodecInfo.CodecProfileLevel.AACObjectLC;      int freqIdx = -1;  //48K, 见后面注释avpriv_mpeg4audio_sample_rates中32000对应的数组下标,来自ffmpeg源码      int chanCfg = 2;  //见后面注释channel_configuration,Stero双声道立体声     int avpriv_mpeg4audio_sample_rates[] = {          96000, 88200, 64000, 48000, 44100, 32000,                  24000, 22050, 16000, 12000, 11025, 8000, 7350      };      for(int i = 0; i < 13 ; ++i)      {          if(frequence == avpriv_mpeg4audio_sample_rates[i])          {              freqIdx = i;              break;          }      }          if(freqIdx == -1)     {         printf("Invaild frequence [%d] \n", frequence);         return ;     }      /*int avpriv_mpeg4audio_sample_rates[] = {          96000, 88200, 64000, 48000, 44100, 32000,                  24000, 22050, 16000, 12000, 11025, 8000, 7350      };      channel_configuration: 表示声道数chanCfg      0: Defined in AOT Specifc Config      1: 1 channel: front-center      2: 2 channels: front-left, front-right      3: 3 channels: front-center, front-left, front-right      4: 4 channels: front-center, front-left, front-right, back-center      5: 5 channels: front-center, front-left, front-right, back-left, back-right      6: 6 channels: front-center, front-left, front-right, back-left, back-right, LFE-channel      7: 8 channels: front-center, front-left, front-right, side-left, side-right, back-left, back-right, LFE-channel      8-15: Reserved      */      // fill in ADTS data      packet[0] = 0xFF;      packet[1] = 0xF1;      packet[2] = (char)(((profile-1)<<6) + (freqIdx<<2) +(chanCfg>>2));      packet[3] = (char)(((chanCfg&3)<<6) + (packetLen>>11));      packet[4] = (char)((packetLen&0x7FF) >> 3);      packet[5] = (char)(((packetLen&7)<<5) + 0x1F);      packet[6] = 0xFC;}

4、

  centos6.9上实现的demo,能同时写下flv,h264及AAC文件(只针对48KHZ ,AAC-LC,16bit采样位数)

5、参考

《1》、

《2》、
《3》、
《4》、
《5》、
《6》、
《7》

转载地址:http://htoe.baihongyu.com/

你可能感兴趣的文章
Nginx配置实例-负载均衡实例:平均访问多台服务器
查看>>
Nginx配置文件nginx.conf中文详解(总结)
查看>>
Nginx配置自带的stub状态实现活动监控指标
查看>>
nginx配置详解、端口重定向和504
查看>>
Nginx配置负载均衡到后台网关集群
查看>>
Nginx配置限流,技能拉满!
查看>>
Nginx配置静态代理/静态资源映射时root与alias的区别,带前缀映射用alias
查看>>
Nginx面试三连问:Nginx如何工作?负载均衡策略有哪些?如何限流?
查看>>
Nginx:NginxConfig可视化配置工具安装
查看>>
ngModelController
查看>>
ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
查看>>
ngrok内网穿透可以实现资源共享吗?快解析更加简洁
查看>>
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_java.net.SocketException:_Too many open files 打开的文件太多_实际操作---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>