Android4.x的RTSP框架学习

                                                                   ——NuPlayer介绍

本文介绍如下内容:

            播放框架介绍

            RTSP源介绍

            HTTP流媒体的区别

            要研究的点

 

NuPlayer框图:

概述:

1.        整个播放框架是基于ALooper、AHandler和Amessage实现的消息机制的。

2.        从MediaPlayerService看,有RTSP和http且为m3u8的url会用NuPlayerDriver,前者就走RTSPSource后者走HTTPLiveSource(还没看呢)。

3.        分播放框架和RTSP源两部分来介绍,他们之间耦合很低,可以分开看代码。

播放框架:

1.        NuPlayerDriver是对NuPlayer的封装,前者继承MediaPlayerInterface接口,后者实现播放的功能。

2.        NuPlayer通过RTSPSource接口得到数据流的信息和解码数据本身,RTSPSource的接口有start、getFormat、getDuration、seekTo、dequeueAccessUnit、feedMoreTSData和stop。后面会对NuPlayer做详细介绍。

3.        Decoder的核心是ACodec,后者相当于stagefright的OMXCodec,实例化一个OMX的Client,调用OMX组件,实现Decode功能。

4.        ACodec有几个跟OMX状态对应的内部类,这里有个状态机的概念。如果一个msg的Handler为Acodec,那么他对应的处理函数就对应其所在状态的onMessageReceived实现。看ACodec代码要了解OMX的一些概念,否则找不到调用关系了,有些流程是要靠OMX回调来串联的。

5.        Render,奇怪,我始终没能找到google组件软解的显示是在哪里实现的,期待debug。

6.        Android4.0引入了SurfaceTexture的概念,在给组件分配输出buffer时有两种方式可选,分配一段内存buffer,或是从显示模块分配buffer,后者显然更高效。前者还需要再做一次格式转换,后者貌似由OMX完成。

7.        OMX组件,在qcom平台上有两套组件plugin,qcom的和google的,qcom在libstagefrighthw.so中。google的组件和库命名规则为"OMX.google.aac.decaac.decoder"//对应动态库libstagefright_soft_aacdec.so

 

RTSP源:

1.        RTSPSource的与播放框架接口,是播放框架的数据源。其主要接口有:

2.        AnotherPacketSource在RTSPSource中作为mAudioTrack和mVideoTrack,他虽然继承了MediaSource接口,但是并没有使用read来读数据,而是通过dequeueAccessUnit接口,Server端的压缩流通过queueAccessUnit保存到这里。

3.        MyHandler是核心,其中包含ARTSPConnection和ARTPConnection两大部分。MyHandler负责向Server端发送Request和处理Response。

4.        ARTSPConnection负责维护RTSP socket,发送Request,循环接收Server端数据,响应Server的Request。这里只是接收Response,真正的处理在MyHandler侧。

           

5.        代码使用的RTSP请求有DESCRIBE,其Response中有SDP信息,接下来是SETUP,将本端的端口信息等发给服务器,然后是PLAY。为了保持RTSP链接,还要周期性发OPTIONS。

6.        ARTPConnection负责RTP和RTCP两个socket,接收RTP和RTCP包,周期性发送RTCP包。

            Public接口:

           

Private接口:

           

7.        每个RTP数据流都有一个ARTPSource,后者会创建一个ARTPAssembler。依据处理数据流的压缩格式,实例化对应格式的Assembler。

            ARTPAssembler的Public接口:

           

            ARTPAssembler的Private接口:

           

8.        ARTPAssembler对ARTPConnection接收到的数据进行处理,如AVC数据,他会把单一NAL,NAL分片和复合NAL分别处理后,都以单独NAL的形式回调传给RTSPSource,存放在AnotherPacketSource中,供decoder端使用。

 

HTTP的比较:

1.      HTTPLive还没看。

2.      普通的http和rtsp最大的区别是什么呢?

            HTTP流媒体是本地解析,而RTSP流媒体是server段解析。HTTP流媒体通过HTTP协议,下载一定buffer量的server端文件到本地,利用本地的parser,像播放文件一样解析,播放。而RTSP流媒体,从server端得到的就是可解码流。

            HTTP在实现seek时,是丢掉当前所有buffer内容的。

 

要研究的点:

1, RTSP协议,request和response数据包的解析。

2, RTSP播放过程的管理。

            Seek过程为,先向Server端发一个PAUSE,带响应后再发一个带时间点的PLAY请求。

3, SDP协议。

4, RTP和RTCP协议,要了解接收到的RTP包头字段的信息。

5, RTSP协议,要了解接收到RTCPSR(SendReprot)和发送出的RR(ReceiveReport)信息。

6, 如AVC要了解NAL单元信息。