参照openRTSP写的一个RTSP client 加了一些注解

转载 2012年03月25日 03:32:16
  1. #include "liveMedia.hh"  
  2. #include "BasicUsageEnvironment.hh"  
  3. #include "GroupsockHelper.hh"  
  4. UsageEnvironment* env;  
  5. portNumBits tunnelOverHTTPPortNum = 0;  
  6. const char * url="rtsp://127.0.0.1:1935/vod/Extremists.m4v";  
  7. #if defined(__WIN32__) || defined(_WIN32)  
  8. #define snprintf _snprintf  
  9. #endif  
  10. int main(int argc,const char ** argv)  
  11. {  
  12.     //创建BasicTaskScheduler对象  
  13.     TaskScheduler* scheduler = BasicTaskScheduler::createNew();  
  14.     //创建BisicUsageEnvironment对象  
  15.     env = BasicUsageEnvironment::createNew(*scheduler);  
  16.     //创建RTSPClient对象  
  17.     RTSPClient * rtspClient= RTSPClient::createNew(*env);  
  18.     //由RTSPClient对象向服务器发送OPTION消息并接受回应  
  19.     char* optionsResponse=rtspClient->sendOptionsCmd(url);  
  20.     delete [] optionsResponse;  
  21.     //产生SDPDescription字符串(由RTSPClient对象向服务器发送DESCRIBE消息并接受回应,根据回应的信息产生SDPDescription字符串,其中包括视音频数据的协议和解码器类型)  
  22.     char* sdpDescription =rtspClient->describeURL(url);  
  23.     //创建MediaSession对象(根据SDPDescription在MediaSession中创建和初始化MediaSubSession子会话对象)  
  24.     MediaSession* session = MediaSession::createNew(*env, sdpDescription);  
  25.     delete[] sdpDescription;  
  26. /* 
  27. while循环中配置所有子会话对象 
  28. */  
  29.     MediaSubsessionIterator iter(*session);  
  30.     MediaSubsession *subsession;  
  31.     while ((subsession = iter.next()) != NULL) {  
  32.         // Creates a "RTPSource" for this subsession. (Has no effect if it's  
  33.         // already been created.)  Returns True iff this succeeds.  
  34.         if (!subsession->initiate()) {  
  35.             *env << "Unable to create receiver for /"" << subsession->mediumName()  
  36.                 << "/" << subsession->codecName()  
  37.                 << "/" subsession: " << env->getResultMsg() << "/n";  
  38.         } else {  
  39.             *env << "Created receiver for /"" << subsession->mediumName()  
  40.                 << "/" << subsession->codecName()  
  41.                 << "/" subsession (client ports " << subsession->clientPortNum()  
  42.                 << "-" << subsession->clientPortNum()+1 << ")/n";  
  43.             if (subsession->rtpSource() != NULL) {  
  44.                 // Because we're saving the incoming data, rather than playing  
  45.                 // it in real time, allow an especially large time threshold  
  46.                 // (1 second) for reordering misordered incoming packets:  
  47.                 unsigned const thresh = 1000000; // 1 second  
  48.                 subsession->rtpSource()->setPacketReorderingThresholdTime(thresh);  
  49.                 // Set the RTP source's OS socket buffer size as appropriate - either if we were explicitly asked (using -B),  
  50.                 // or if the desired FileSink buffer size happens to be larger than the current OS socket buffer size.  
  51.                 // (The latter case is a heuristic, on the assumption that if the user asked for a large FileSink buffer size,  
  52.                 // then the input data rate may be large enough to justify increasing the OS socket buffer size also.)  
  53.                 int socketNum = subsession->rtpSource()->RTPgs()->socketNum();  
  54.                 unsigned curBufferSize = getReceiveBufferSize(*env, socketNum);  
  55.                 unsigned newBufferSize = setReceiveBufferTo(*env, socketNum, 100000);  
  56.   
  57.             }  
  58.         }  
  59.     }  
  60.     //由RTSPClient对象向服务器发送SETUP消息并接受回应  
  61.     iter.reset();  
  62.     while ((subsession = iter.next()) != NULL) {  
  63.         if (subsession->clientPortNum() == 0) continue// port # was not set  
  64.         if (!rtspClient->setupMediaSubsession(*subsession)) {  
  65.             *env << "Failed to setup /"" << subsession->mediumName()  
  66.                 << "/" << subsession->codecName()  
  67.                 << "/" subsession: " << env->getResultMsg() << "/n";  
  68.         } else {  
  69.             *env << "Setup /"" << subsession->mediumName()  
  70.                 << "/" << subsession->codecName()  
  71.                 << "/" subsession (client ports " << subsession->clientPortNum()  
  72.                 << "-" << subsession->clientPortNum()+1 << ")/n";  
  73.         }  
  74.         if (subsession->rtpSource() != NULL) {  
  75.             // Because we're saving the incoming data, rather than playing  
  76.             // it in real time, allow an especially large time threshold  
  77.             // (1 second) for reordering misordered incoming packets:  
  78.             unsigned const thresh = 1000000; // 1 second  
  79.             subsession->rtpSource()->setPacketReorderingThresholdTime(thresh);  
  80.         }  
  81.     }  
  82.     iter.reset();  
  83.     while ((subsession = iter.next()) != NULL) {  
  84.         if (subsession->readSource() == NULL) continue// was not initiated  
  85.         char outFileName[1000];  
  86.         static unsigned streamCounter = 0;  
  87.         snprintf(outFileName, sizeof outFileName, "%s-%s-%d",  
  88.             subsession->mediumName(),  
  89.             subsession->codecName(), ++streamCounter);  
  90.         FileSink* fileSink;  
  91.         if (strcmp(subsession->mediumName(), "audio") == 0 &&  
  92.             (strcmp(subsession->codecName(), "AMR") == 0 ||  
  93.             strcmp(subsession->codecName(), "AMR-WB") == 0)) {  
  94.                 // For AMR audio streams, we use a special sink that inserts AMR frame hdrs:  
  95.                 fileSink = AMRAudioFileSink::createNew(*env, outFileName);  
  96.         } else if (strcmp(subsession->mediumName(), "video") == 0 &&  
  97.             (strcmp(subsession->codecName(), "H264") == 0)) {  
  98.                 // For H.264 video stream, we use a special sink that insert start_codes:  
  99.                 unsigned int num=0;  
  100.                 SPropRecord * sps=parseSPropParameterSets(subsession->fmtp_spropparametersets(),num);  
  101.                 fileSink = H264VideoFileSink::createNew(*env, outFileName,100000);  
  102.                 struct timeval tv={0,0};  
  103.                 unsigned char start_code[4] = {0x00, 0x00, 0x00, 0x01};  
  104.                 fileSink->addData(start_code, 4, tv);  
  105.                 fileSink->addData(sps[0].sPropBytes,sps[0].sPropLength,tv);  
  106.                 fileSink->addData(start_code, 4, tv);  
  107.                 fileSink->addData(sps[1].sPropBytes,sps[1].sPropLength,tv);  
  108.                 delete[] sps;  
  109.         } else {  
  110.             // Normal case:  
  111.             fileSink = FileSink::createNew(*env, outFileName);  
  112.         }  
  113.         subsession->sink = fileSink;  
  114.         subsession->sink->startPlaying(*(subsession->readSource()),NULL,NULL);  
  115.     }  
  116.     rtspClient->playMediaSession(*session, 0.0f, 0.0f, (float)1.0);  
  117.     env->taskScheduler().doEventLoop(); // does not return  
  118.     return 0; // only to prevent compiler warning  
  119. }  




转自 http://blog.csdn.net/zblue78/article/details/5968941

RTSPClient工具EasyRTSPClient支持H.265,支持海思等各种芯片平台

EasyRTSPClient是EasyDarwin开源流媒体团队开发、提供的一套非常稳定、易用、支持重连的RTSPClient工具,接口调用非常简单,再也不用像调用live555那样处理整个RTSP ...
  • xiejiashu
  • xiejiashu
  • 2016年04月28日 00:51
  • 4938

restlet2.1 学习笔记(二) 分别处理Get Post Put请求

servlet只支持GET与POST两种请求。 但是restlet除了支持GET与POST请求外还支持Delete  Put  OPTIONS 等多种请求 。 第一步,编写资源类 (可以将资源类想...
  • is_zhoufeng
  • is_zhoufeng
  • 2013年08月02日 17:49
  • 9667

从头写一个rtsp服务器

1)rtsp的应答少了一个\r\n,费了我一天, :( 2)h.264的rtp发送 int    CStreamer::SendRtpPacket(char * packet, int nLe...
  • ljh081231
  • ljh081231
  • 2014年02月14日 17:21
  • 1815

参照openRTSP写的一个RTSP client 加了一些注解

转载  http://blog.csdn.net/gavinr/article/category/942245   [cpp] view plaincopy #inclu...
  • a7281080
  • a7281080
  • 2012年05月22日 21:45
  • 2229

参照openRTSP写的一个RTSP client 加了一些注解

#include "liveMedia.hh" #include "BasicUsageEnvironment.hh" #include "GroupsockHelper.hh" UsageEn...
  • gokartscomeon
  • gokartscomeon
  • 2015年03月18日 14:22
  • 371

参照openRTSP写的一个RTSP client

#include "liveMedia.hh"   #include "BasicUsageEnvironment.hh"   #include "GroupsockHelper.hh"   U...
  • vishtvro
  • vishtvro
  • 2011年11月21日 16:50
  • 1880

[RTSP]live555-openRTSP客户端流程

1、创建TaskScheduler和BasicUsageEnvironment类; 2、命令行解析,获取流媒体地址和其他选项; 3、创建RTSPClient对象; 4、如果需要,RTSPClie...
  • faihung
  • faihung
  • 2017年06月03日 07:21
  • 584

一个好玩的模拟手写书信效果,加了一些修改

  • 2014年07月07日 10:24
  • 83KB
  • 下载

mystar源代码-加了注解

  • 2008年08月28日 10:21
  • 676KB
  • 下载

以下是computer vision:algorithm and application计算机视觉算法与应用这本书中附录里关于计算机视觉的一些测试数据集和源码站点,我整理了下,加了点中文注解

以下是computer vision:algorithm and application计算机视觉算法与应用这本书中附录里的关于计算机视觉的一些测试数据集和源码站点,我整理了下,加了点中文注解。 ...
  • liqiming100
  • liqiming100
  • 2017年06月27日 20:39
  • 903
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:参照openRTSP写的一个RTSP client 加了一些注解
举报原因:
原因补充:

(最多只允许输入30个字)