直播:现有的ISMA方式,流程如下:
视频采集-->视频编码-->RTP打包-->UDP组播;
音频采集-->音频编码-->RTP打包-->UDP组播;
上面是MP4live的工作流程。
直播:MPEG TS流方式,流程如下:
视频采集-->视频编码-->
音频采集-->音频编码-->TS打包-->RTP打包-->UDP组播
上面是TS流的工作流程。
点播:ISMA方式
分别读取文件中的音频和视频数据,分别打包到RTP,分别发送出去。
点播:TS流方式
分别读取文件中的音频和视频数据,打包成TS流,封装到RTP中,然后发送出去。
现在有如下事情需要做:
1. 2010年9月30日搭建环境,测试Darwin服务器是否支持TS流,测试环境如下:
VLC-->Darwin-->VLC
a. 我们分成两步达到这个目标:首先试验VLC1-->VLC2
VLC流化的配置,可以通过图形界面配置,也可以通过命令行控制。
VLC1从Darwin服务器请求了媒体数据,然后打包成为TS流,并发送出去,VLC2接收TS流数据,播放;
整个过程走的通,抓包证明中间确实是TS流。
当然,也存在问题,就是图形会出现马赛克,猜测是因为B帧的PTS,和DTS有问题。
还有一个问题是:不能生成sdp文件,因为我们要实现第二步。
b. VLC-->Darwin-->VLC
Darwin服务器需要一个SDP文件来描述媒体源。
2. 问题:VLC在流化过程中,不能生成sdp文件,需要解决这个问题?
错误的写法:
vlc -vvv --extraintf=logger rtsp://115.182.51.78/tv/XingKongDianYing.sdp :sout=#duplicate{dst=rtp{dst=224.1.2.3,mux=ts,port=1234,sdp="file://c:/test.sdp"}}
正确的写法:
vlc -vvv --extraintf=logger rtsp://115.182.51.78/tv/XingKongDianYing.sdp :sout=#duplicate{dst=rtp{dst=224.1.2.3,mux=ts,port=1234,sdp="file://10.57.26.88/guoq/test_100.sdp"}}
3. 问题:VLC在流化过程中,图像质量很差,定位问题?
查看日志,发现:
mux_ts warning: packet with too strange dts (dts=23955930833,old=23956030944,pcr=23956030944)
mux_ts warning: packet with too strange dts (dts=23956097687,old=23956197798,pcr=23956197798)
mux_ts warning: packet with too strange dts (dts=23956231175,old=23956364663,pcr=23956364663)
mux_ts warning: packet with too strange dts (dts=23956398030,old=23956531518,pcr=23956531518)
mux_ts warning: packet with too strange dts (dts=23956564885,old=23956698373,pcr=23956698373)
mux_ts warning: packet with too strange dts (dts=23956731739,old=23956831861,pcr=23956831861)
mux_ts warning: packet with too strange dts (dts=23956898593,old=23956998715,pcr=23956998715)
mux_ts warning: packet with too strange dts (dts=23956278439,old=23957011060,pcr=23956931970)
mux_ts warning: packet with too strange dts (dts=23957044802,old=23957132191,pcr=23957132191)
问题如何解决,现在还不知道。
而且,使用图形界面配置串流的时候,图像有马赛克。可能有问题。
4. 直播的方案:
a) 如果解决了问题3,那么直播流化TS,可以通过架设方案完成;
b) 如果不能解决问题3,那么直播流化TS,需要开发方案;可以考虑在MP4live中间加TS流化的代码。
建议采用方案b,因为我们要改写pid等一些信息,需要符合联通的要求,这些是无法通过配置vlc来解决的。
5. 点播文件的方案:
a) MP4文件转化为TS文件,然后看Darwin是否能够读取并流化;
b) MP4文件给Darwin,Darwin读取,然后转为TS流,流化;
经过试验证实:Darwin服务器不支持流化TS类型。在RTSP命令中Describe阶段,返回514错误码:unsupported media type.
Request: DESCRIBE rtsp://10.57.26.88/test.ts RTSP/1.0/r/n
Method: DESCRIBE
URL: rtsp://10.57.26.88/test.ts
Response: RTSP/1.0 415 Unsupported Media Type/r/n
Status: 415
那么现在的方案有如下两个选择:
a) 读MP4,出TS流;
b) 读TS文件,出TS流;
6. 研究TS流的开源代码
a) MPEG4IP中的mpeg2t;
提取TS流的。
b) VLC中的mux_ts;
c) Live555中有没有可供借鉴的?
testMPEG2TransportStreamer.cpp
d) libtsmux,一个开源的C库
e) MP4Box,GPAC。
Mp4fileàTS file, or RTP, or UDP.
f) tstools
esmerge.c
7. 直播TS流方案
视频采集-->视频编码-->
音频采集-->音频编码-->TS打包-->RTP打包-->UDP组播
8. 点播TS流方案
Darwin服务器读取TS文件,打包成为RTP数据,发送出去。
9. MP4文件转换为TS文件
vlc -vvv --extraintf=logger d:/11.mp4 :sout=#std{access=file,mux=ts,dst=d:/11.ts}
10. MP4文件转换为TS流
vlc -vvv --extraintf=logger d:/11.mp4:sout=#duplicate{dst=rtp{dst=224.1.2.3,mux=ts,port=1234,sdp="file://10.57.26.88/guoq/test_100.sdp"},dst=display}
11. 做一个测试程序
从MP4文件中读出视频数据,音频数据,打包到TS流,并封装成RTP包,发送出去;使用VLC可以接收并播放。
在《IPTV支持TS流的开发过程》中,会描述这个测试程序是如何开发的。
目标:从MP4文件中读出音视频数据,打包到TS流,保存成为TS文件。使用VLC或者暴风影音可以播放该文件。
1. 读取MP4文件,取得其中的音视频数据;
可以使用MPEG4IP中的库,引入头文件mp4.h,连接libmp4v2.so;写法可以参考MP4creator。
顺序取得音频帧,和视频帧,对它们按照播放时间做两路归并排序。
播放时间的计算:
audio_play_time = audio_timestamp*1000/audio_timescale;
video_play_time = video_timestamp*1000/video_timescale;
2. 这时候取到的是ES流,ES打包成为PES包,PES打包成为TS包。其实,我们漏下了一点东西要说,ES在打包成为PES之前,需要做一点事情:
视频ES,如果是第一帧,那么需要加入VideoStreamHeader,每一种编码格式,比如H.264,或者MP4,都不相同。每一种编码格式都需要取得自己独特的VideoStreamHeader。
音频ES,每一帧的音频,都需要加入AudioStreamHeader,每一种编码格式,比如AAC,都需要单独取得。
a. H.264,定义个uchar H264_delimeter[4]={0x00, 0x00, 0x00, 0x01};
第一个是H264_delimeter[4],0x09, 0xE0;
第二个是H264_delimeter[4],SeqHeader;
第三个是H264_delimeter[4],PictHeader;
b. mp4, mp2, mp1,MP4GetTrackESConfiguration;
c. AAC音频,放置7个字节的ADTS固定头信息;其中要设置每一帧音频数据的长度,所以每一帧都需要改变。
3. ES-->PES
需要构造PES头,需要打标PTS和DTS;
4. PES-->TS
需要构造TS头,需要打标PCR,需要对PES分成小于188的几块,长度通常是184,或者184-8;8个字节是PCR信息。
当然,对整个TS流来说,需要一个PAT表,告诉我们有几路节目program;
还需要几个PMT表,PMT表告诉我们,这个节目里面包含的几个ES流。