青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

ortp庫使用入門

轉載自:http://ticktick.blog.51cto.com/823160/345642

    我們知道, RTP(Real-timeTransportProtocol)是用于Internet上針對多媒體數據流的一種傳輸協議,做流媒體傳輸方面的應用離不開RTP協議的實現及使用,為了更加快速地在項目中應用RTP協議實現流媒體的傳輸,我們一般會選擇使用一些RTP庫,例如使用c++語言編寫的JRTPLIB庫,網上關于RTP協議以及JRTPLIB庫的介紹已經很多了,在此我也不再贅述,文本主要介紹實現了RTP協議的另一種開源庫——ORTP庫,這個庫是純使用c語言編寫,由于我們的項目是基于Linux下的c語言編程,故我們選擇了ortp作為我們的第三方庫,在此我也對該庫進行一個簡單地介紹,希望對其他ortp的初學者有所幫助。

一、簡介

ORTP是一個支持RTP以及RFC3550協議的庫,有如下的特性:
(1)使用C語言編寫,可以工作于windows, Linux, 以及 Unix平臺
(2)實現了RFC3550協議,提供簡單易用的API。支持多種配置,RFC3551為默認的配置。
(3)支持單線程下的多個RTP會話,支持自適應抖動處理。
(4)基于GPL版權聲明。

ORTP可以在其官方網站上(http://www.linphone.org/index.php/eng/code_review/ortp)下載,下載解壓后得到ORTP的源碼包和示例程序(tests)。其幫助文檔在docs目錄下,也可以在http://download.savannah.gnu.org/releases/linphone/ortp/docs/在線查看。


關于ORTP的資料并不多,主要是其源碼、幫助文檔以及示例程序,關于示例程序說明如下:
rtprecv.c 和rtpsend.c 展示了如何接收和發送單RTP數據流。
mrtprecv.c mrtpsend.c 展示了如何同時接收和發送多個RTP數據流。

二、主要函數介紹

 rtp_session_init

函數原型:void rtp_session_init (RtpSession * session, int mode)
函數功能:執行rtp會話的一些必要的初始化工作
參數含義:
session: rtp會話結構體,含有一些rtp會話的基本信息
mode   傳輸模式,有以下幾種,決定本會話的一些特性。
RTP_SESSION_RECVONLY:只進行rtp數據的接收
RTP_SESSION_SENDONLY:只進行rtp數據的發送
RTP_SESSION_SENDRECV:可以進行rtp數據的接收和發送
 
執行的操作:
1.       設置rtp包緩沖隊列的最大長度
2.       根據傳輸模式設置標志變量的值
3.       隨機產生SSRC和同步源描述信息
4.       傳入全局的av_profile,即使用默認的profile配置
5.       初始化rtp包緩沖區隊列
6.       發送負載類型默認設置為0(pcmu音頻),接收負載類型默認設置為-1(未定義)
7.       session的其他成員的值均設置一個默認值。
 
rtp_session_set_scheduling_mode
函數原型:void rtp_session_set_scheduling_mode (RtpSession * session, int yesno)
函數功能: RtpScheduler管理多個session的調度和收發的控制,本函數設置是否使用該session調度管理功能。
參數含義:
session rtp會話結構體
yesno:   是否使用rtp session的系統調度功能
說明:
如果yesno為1,則表明使用系統的session調度管理功能,意味著可以使用以下功能:
1. 可以使用session_set_select在多個rtp會話之間進行選擇,根據時間戳判定某個會話是否到達了收發的時間。
2. 可以使用rtp_session_set_blocking_mode()設置是否使用阻塞模式來進行rtp包的發送和接收。
如果yesno為0,則表明該會話不受系統管理和調度。
關于rtp session的管理和調度,由全局的變量RtpScheduler *__ortp_scheduler來負責,該變量必須通過ortp_scheduler_init() 來進行初始化操作。
 
rtp_session_set_blocking_mode
函數原型:void rtp_session_set_blocking_mode (RtpSession * session, int yesno)
函數功能:設置是否使用阻塞模式,
參數含義:
session rtp會話結構體
yesno:  是否使用阻塞模式
說明:
阻塞模式只有在scheduling mode被開啟的情況下才能使用,本函數決定了rtp_session_recv_with_ts() 和 rtp_session_send_with_ts()兩個函數的行為,如果啟用了阻塞模式,則rtp_session_recv_with_ts()會一直阻塞直到接收RTP包的時間點到達(這個時間點由該函數參數中所定義的時間戳來決定),當接收完RTP數據包后,該函數才會返回。同樣,rtp_session_send_with_ts()也會一直阻塞直到需要被發送的RTP包的時間點到達,發送結束后,函數才返回。
 
rtp_session_signal_connect
函數原型:int rtp_session_signal_connect (RtpSession * session, const char *signal,   RtpCallback cb, unsigned long user_data)
函數功能:本函數提供一種方式,用于通知應用程序各種可能發生的RTP事件(信號)??赡芡ㄟ^注冊回調函數的形式來實現本功能。
參數含義:
session rtp會話結構體
signal: 信號的名稱
cb     回調函數
user_data傳遞給回調函數的數據
返回值:0表示成功,-EOPNOTSUPP表示信號名稱不存在,-1表示回調函數綁定錯誤
說明:
信號的名稱必須是以下字符串中的一種:
"ssrc_changed" : 數據流的同步源標識改變
"payload_type_changed" : 數據流的負載類型改變
"telephone-event_packet" : telephone-event RTP包(RFC2833)被接收
"telephone-event" : telephone event 發生
"network_error" : 網絡錯誤產生,傳遞給回調函數的是描述錯誤的字符串(const char *型)或者錯誤碼(int型)
"timestamp_jump" : 接收到的數據包發生了時間戳的跳躍。
要取消事件(信號)的監聽,可以使用下面這個函數
int rtp_session_signal_disconnect_by_callback ( RtpSession * session, const char * signal_name, RtpCallback cb )
 
rtp_session_set_local_addr
函數原型:int rtp_session_set_local_addr( RtpSession * session, const char * addr,int port)
函數功能:設置本地rtp數據監聽地址
參數含義:
session rtp會話結構體
addr: 本地IP地址,例如127.0.0.1,如果為NULL,則系統分配0.0.0.0
port   監聽端口,如果設置為-1,則系統為其自動分配端口
返回值: 0表示成功
說明:
如果是RTP_SESSION_SENDONLY(只發送)型會話,則不需要進行本設置,而必須設置rtp_session_set_remote_addr() 來設置遠程目的地址。
如果采用了系統自動分配監聽端口,則可以通過int rtp_session_get_local_port(const RtpSession *session) 來獲取系統分配的監聽端口號。
 
rtp_session_set_remote_addr
函數原型:int rtp_session_set_remote_addr (RtpSession * session, const char * addr, int port)
函數功能:設置RTP發送的目的地址
參數含義:
session rtp會話結構體
addr: 目的IP地址
port   目的地址的監聽端口號
返回值: 0表示成功
 
rtp_session_set_send_payload_type
函數原型:int rtp_session_set_send_payload_type (RtpSession * session, int paytype)
函數功能:設置RTP發送數據的負載類型
參數含義:
session rtp會話結構體
paytype負載類型
返回值: 0表示成功,-1表示負載未定義
說明:
負載類型在payloadtype.h文件中有詳細的定義,RTP接收端有著類似的負載類型設置函數,int rtp_session_set_recv_payload_type ( RtpSession * session, int paytype ) ,注意,發送的負載類型必須與接收的負載類型一致才能正常完成收發。
 
rtp_session_send_with_ts
函數原型:int rtp_session_send_with_ts (RtpSession * session, const char * buffer, int len,uint32_t userts)
函數功能:發送RTP數據包
參數含義:
session rtp會話結構體
buffer 需要發送的RTP數據的緩沖區
len    需要發送的RTP數據的長度
userts 本RTP數據包的時間戳
返回值: 成功發送到網絡中的字節數
說明:
發送RTP數據需要自己管理時間戳的遞增,每調用一次本函數,請根據實際情況對userts進行遞增,具體遞增的規則見RTP協議中的說明。
例如:如果發送的是采樣率為90000Hz的視頻數據包,每秒25幀,則時間戳的增量為:90000/25 = 3600
時間戳的起始值為隨機值,建議設置為0 。
 
rtp_session_recv_with_ts
函數原型:int rtp_session_recv_with_ts (RtpSession * session, char * buffer,int len, uint32_t time, int * have_more)
函數功能:接收RTP數據包
參數含義:
session rtp會話結構體
buffer 存放接收的RTP數據的緩沖區
len    期望接收的RTP數據的長度
time   期望接收的RTP數據的時間戳
have_more標識接收緩沖區是否還有數據沒有傳遞完。當用戶給出的緩沖區不夠大時,為了標識緩沖區數據未取完,則have_more指向的數據為1,期望用戶以同樣的時間戳再次調用本函數;否則為0,標識取完。

rtp_session_destroy
【原型】: void rtp_session_destroy(RtpSession *session)
【功能】:摧毀rtp會話對象,釋放資源
【參數】:session已經創建的RTP會話對象
 

三、程序示例

      下面,我簡單地通過程序演示了怎么使用ortp進行rtp數據包的發送,接收端的程序待以后有時間再整理出來吧。

       注:示例代碼我已經整理出來了,見博文: 《ortp編程示例代碼》

  1. //////////////////////////////////////////////////////////////////////////     
  2. /// COPYRIGHT NOTICE     
  3.  // Copyright (c) 2009, 華中科技大學ticktick Group     
  4. /// All rights reserved.      
  5. ///      
  6. /// @file    ortpSend.c       
  7. /// @brief   ortpSend的測試     
  8. ///     
  9. /// 本文件示例使用ortp庫進行rtp數據包的發送    
  10. ///      
  11. /// @version 1.0        
  12. /// @author  tickTick   
  13. /// @date    2010/07/07      
  14. /// @E-mail  lujun.hust@gmail.com     
  15. ///     
  16. /// 修訂說明:創建文件    
  17. //////////////////////////////////////////////////////////////////////////      
  18.  
  19. #include <ortp/ortp.h>  
  20. #include <signal.h>  
  21. #include <stdlib.h>  
  22.  
  23. #ifndef _WIN32   
  24. #include <sys/types.h>  
  25. #include <sys/time.h>  
  26. #include <stdio.h>  
  27. #endif  
  28.  
  29. // 時間戳增量
  30. #define TIME_STAMP_INC  160   
  31. #define BYTES_PER_COUNT 65535
  1. // 時間戳   
  2. uint32_t g_user_ts;  
  3.  
  4. /**  初始化     
  5.  *       
  6.  *   主要用于對ortp以及其它參數進行初始化    
  7.  *   @param:  char * ipStr 目的端IP地址描述串     
  8.  *   @param:  iint port 目的端RTP監聽端口     
  9.  *   @return:  RtpSession * 返回指向RtpSession對象的指針,如果為NULL,則初始化失敗     
  10.  *   @note:       
  11.  */   
  12. RtpSession * rtpInit(char * ipStr,int port)  
  13. {  
  14.     // Rtp會話對象    
  15.     RtpSession *session;  
  16.     char *ssrc;  
  17.       
  18.     // 時間戳初始化    
  19.     g_user_ts = 0;  
  20.  
  21.     // ortp的一些基本初始化操作   
  22.     ortp_init();  
  23.     ortp_scheduler_init();  
  24.     // 創建新的rtp會話對象  
  25.     session=rtp_session_new(RTP_SESSION_SENDONLY);    
  26.       
  27.     rtp_session_set_scheduling_mode(session,1);  
  28.     rtp_session_set_blocking_mode(session,1);  
  29.     // 設置遠程RTP客戶端的的IP和監聽端口(即本rtp數據包的發送目的地址)   
  30.     rtp_session_set_remote_addr(session,ipStr,port);  
  31.     // 設置負載類型    
  32.     rtp_session_set_payload_type(session,0);  
  33.       
  34.     // 獲取同步源標識    
  35.     ssrc=getenv("SSRC");  
  36.     if (ssrc!=NULL)   
  37.     {  
  38.         printf("using SSRC=%i.\n",atoi(ssrc));  
  39.         rtp_session_set_ssrc=\'#\'"  
  40.     }  
  41.       
  42.     return session;  
  43.  
  44. }  
  45.  
  46. /**  發送rtp數據包     
  47.  *       
  48.  *   主要用于發送rtp數據包     
  49.  *   @param:  RtpSession *session RTP會話對象的指針     
  50.  *   @param:  const char *buffer 要發送的數據的緩沖區地址      
  51.  *   @param: int len 要發送的數據長度     
  52.  *   @return:  int 實際發送的數據包數目     
  53.  *   @note:     如果要發送的數據包長度大于BYTES_PER_COUNT,本函數內部會進行分包處理     
  54.  */ 
  55. int rtpSend(RtpSession *session,const char *buffer, int len)  
  56. {  
  57.     int curOffset = 0;  
  58.     int sendBytes = 0;  
  59.     int clockslide=500;   
  60.     // 發送包的個數  
  61.     int sendCount = 0;  
  62.  
  63.     ortp_message("send data len %i\n ",len);  
  64.  
  65.     // 是否全部發送完畢    
  66.     while(curOffset < len )  
  67.     {  
  68.      // 如果需要發送的數據長度小于等于闕值,則直接發送  
  69.         if( len <= BYTES_PER_COUNT )  
  70.         {  
  71.             sendBytes = len;  
  72.         }  
  73.         else 
  74.         {  
  75.             // 如果當前偏移 + 閾值 小于等于 總長度,則發送閾值大小的數據  
  76.             if( curOffset + BYTES_PER_COUNT <= len )  
  77.             {  
  78.                 sendBytes = BYTES_PER_COUNT;  
  79.             }  
  80.             // 否則就發送剩余長度的數據  
  81.             else 
  82.             {  
  83.                 sendBytes = len - curOffset;  
  84.             }  
  85.         }  
  86.           
  87.         ortp_message("send data bytes %i\n ",sendBytes);  
  88.           
  89.         rtp_session_send_with_ts(session,(char *)(buffer+curOffset),sendBytes,g_user_ts);  
  90.           
  91.         // 累加  
  92.         sendCount ++;  
  93.         curOffset += sendBytes;                   
  94.         g_user_ts += TIME_STAMP_INC;  
  95.       
  96.         // 發送一定數據包后休眠一會  
  97.         if (sendCount%10==0)   
  98.         {  
  99.             usleep(20000);  
  100.         }     
  101.     }  
  102.     return 0;  
  103. }  
  104.  
  105. /**  結束ortp的發送,釋放資源     
  106.  *      
  107.  *   @param:  RtpSession *session RTP會話對象的指針     
  108.  *   @return:  0表示成功     
  109.  *   @note:         
  110.  */ 
  111. int rtpExit(RtpSession *session)  
  112. {  
  113.     g_user_ts = 0;  
  114.       
  115.     rtp_session_destroy(session);  
  116.     ortp_exit();  
  117.     ortp_global_stats_display();  
  118.  
  119.     return 0;  
  120. }  
  121.  
  122. // 主函數,進行測試  
  123. int main()  
  124. {  
  125.     // 待發送的數據緩沖區  
  126.     char * pBuffer = "123445356234134234532523654323413453425236244123425234";  
  127.       
  128.     RtpSession * pRtpSession = NULL;  
  129.     // 向(192.201.0.51,8000)目的地址發送rtp包  
  130.     pRtpSession = rtpInit("192.201.0.51",8000);  
  131.     if(pRtpSession==NULL)  
  132.     {  
  133.         printf("error rtpInit");  
  134.         return 0;  
  135.     }  
  136.       
  137.     // 循環發送  
  138.     while(1)  
  139.     {  
  140.         if( rtpSend(pRtpSession,pBuffer,20) != 0)  
  141.         {  
  142.             printf("error rtpInit");  
  143.             break;  
  144.         }  
  145.         usleep(10000);  
  146.         printf("sleep");  
  147.     }  
  148.       
  149.     // 退出  
  150.     rtpExit(pRtpSession);  
  151.       
  152.     return 0;  

 

本文出自 “對影成三人” 博客,請務必保留此出處http://ticktick.blog.51cto.com/823160/345642


posted on 2013-09-03 02:36 楊粼波 閱讀(2030) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            在线不卡免费欧美| 国产精品自拍视频| 亚洲欧美怡红院| 美女主播一区| 国产精品99久久99久久久二8 | 99热免费精品| 久久天堂精品| 亚洲欧美日韩中文在线制服| 一区二区三区在线不卡| 欧美网站在线观看| 另类av一区二区| 香蕉成人久久| 亚洲夜间福利| 日韩视频不卡| 欧美国产精品人人做人人爱| 午夜精品短视频| av成人老司机| 亚洲日韩第九十九页| 国产一区二区精品久久| 国产精品久久久久毛片软件| 欧美日韩国产麻豆| 久久久国产一区二区| 亚洲欧美视频在线观看视频| 欧美一区二区三区四区在线观看| 一本久久精品一区二区| 亚洲欧洲一级| 国产一区二区精品久久91| 黄色国产精品| 国产丝袜美腿一区二区三区| 国产精品伊人日日| 国内精品久久久久影院 日本资源| 国产精品外国| 国产日韩视频| 亚洲国产欧美不卡在线观看| 伊人成人网在线看| 99国产精品久久久久久久| 亚洲精品视频在线观看网站 | 亚洲精品乱码视频| 欧美成人一区二区三区片免费| 亚洲东热激情| 亚洲人成人一区二区三区| 亚洲午夜精品久久| 久久久免费观看视频| 久久影院亚洲| 国产精品成人在线| 国产精品男gay被猛男狂揉视频| 好男人免费精品视频| 亚洲剧情一区二区| 亚洲激情在线视频| 西瓜成人精品人成网站| 香蕉尹人综合在线观看| 欧美第一黄网免费网站| 亚洲美女诱惑| 久久久人成影片一区二区三区 | 久久精品国产第一区二区三区| 午夜精品区一区二区三| 麻豆精品视频在线| 亚洲国产三级| 在线一区二区三区做爰视频网站| 亚洲网站在线观看| 欧美h视频在线| 欧美电影免费观看高清| 欧美日韩国产成人在线免费| 国产专区欧美专区| 亚洲一线二线三线久久久| 亚洲欧美日韩在线高清直播| 欧美高清在线视频| 香蕉成人伊视频在线观看 | 亚洲国产欧美一区二区三区同亚洲| 亚洲一区999| 亚洲综合色视频| 久久精品91久久香蕉加勒比| 免费视频一区二区三区在线观看| 国产精品中文字幕在线观看| 中文欧美日韩| 最近看过的日韩成人| 久久综合九色99| 国产亚洲成av人在线观看导航| 亚洲尤物影院| 亚洲精品久久久久久下一站| 另类综合日韩欧美亚洲| 欧美日韩你懂的| 国产嫩草影院久久久久| 亚洲成人自拍视频| 亚洲一区999| 美女视频黄a大片欧美| 亚洲欧美日韩区| 国产精品成人久久久久| 亚洲小说区图片区| 亚洲日本va午夜在线电影| 免费成人美女女| 影音先锋日韩资源| 久久综合精品一区| 欧美在线观看日本一区| 欧美视频不卡| 亚洲第一区在线| 老司机免费视频一区二区| 新67194成人永久网站| 国产免费成人av| 欧美一级视频精品观看| 亚洲一区二区影院| 国产精品一区二区三区乱码| 亚洲欧美国产制服动漫| 国产精品99久久久久久宅男| 欧美系列精品| 午夜在线a亚洲v天堂网2018| 亚洲在线观看视频| 亚洲韩国日本中文字幕| 欧美国产日本| 欧美一级午夜免费电影| 亚洲女优在线| 国产亚洲欧洲一区高清在线观看 | 欧美日韩天天操| 一区二区国产精品| 你懂的视频欧美| 亚洲欧美日韩综合aⅴ视频| 国产麻豆91精品| 久久精品视频播放| 久久免费黄色| 国产色综合网| 美女免费视频一区| 欧美成人中文字幕| aⅴ色国产欧美| 一本色道久久综合亚洲91| 国产精品青草久久久久福利99| 久久精品91久久香蕉加勒比| 久久香蕉精品| 亚洲视频久久| 欧美伊久线香蕉线新在线| 在线国产精品一区| 亚洲精品影院| 欧美女同视频| 日韩一区二区精品| 亚洲色图综合久久| 红桃视频一区| 最新国产乱人伦偷精品免费网站| 欧美日韩国产精品一卡| 欧美一区国产在线| 亚洲欧美影音先锋| 亚洲精品123区| 制服诱惑一区二区| 一区国产精品| 一区二区三区四区国产精品| 国内成人在线| 亚洲精品国久久99热| 国产日韩欧美精品一区| 免费日本视频一区| 国产精品伦理| 亚洲国产mv| 国产无一区二区| 亚洲日本理论电影| 国产亚洲一区二区三区在线播放| 亚洲国产合集| 国产区亚洲区欧美区| 91久久精品一区| 国产一区二区三区奇米久涩| 亚洲精品三级| 在线观看亚洲视频| 亚洲午夜免费视频| 亚洲精品女人| 久久国内精品自在自线400部| 一本色道久久99精品综合| 欧美在线亚洲| 亚洲淫性视频| 欧美国产日韩一二三区| 久久久99国产精品免费| 久久亚洲国产精品日日av夜夜| 亚洲一区二区欧美| 欧美91大片| 久久免费视频一区| 欧美福利视频网站| 久久婷婷人人澡人人喊人人爽| 欧美午夜无遮挡| 亚洲第一二三四五区| 国产综合精品一区| 亚洲丝袜av一区| 一本高清dvd不卡在线观看| 久久久噜噜噜久久中文字免| 欧美一区二区三区的| 欧美性一区二区| 91久久国产精品91久久性色| 在线观看一区二区精品视频| 亚洲欧美综合v| 亚洲欧美日韩国产综合在线| 欧美日韩国产一区二区| 亚洲第一网站免费视频| 一区二区三区在线视频免费观看 | 国产精品日韩在线一区| 日韩视频在线一区| 亚洲精品中文字幕女同| 葵司免费一区二区三区四区五区| 久久久久久久精| 国产视频久久| 午夜在线a亚洲v天堂网2018| 性8sex亚洲区入口| 国产精品一区久久久| 亚洲视频电影图片偷拍一区| 亚洲一级免费视频| 国产精品国产三级国产aⅴ无密码| 亚洲另类自拍|