RtpEvent.cxx
上传用户:sy_wanhua
上传日期:2013-07-25
资源大小:3048k
文件大小:7k
源码类别:

流媒体/Mpeg4/MP4

开发平台:

C/C++

  1. /* ====================================================================
  2.  * The Vovida Software License, Version 1.0 
  3.  * 
  4.  * Copyright (c) 2000 Vovida Networks, Inc.  All rights reserved.
  5.  * 
  6.  * Redistribution and use in source and binary forms, with or without
  7.  * modification, are permitted provided that the following conditions
  8.  * are met:
  9.  * 
  10.  * 1. Redistributions of source code must retain the above copyright
  11.  *    notice, this list of conditions and the following disclaimer.
  12.  * 
  13.  * 2. Redistributions in binary form must reproduce the above copyright
  14.  *    notice, this list of conditions and the following disclaimer in
  15.  *    the documentation and/or other materials provided with the
  16.  *    distribution.
  17.  * 
  18.  * 3. The names "VOCAL", "Vovida Open Communication Application Library",
  19.  *    and "Vovida Open Communication Application Library (VOCAL)" must
  20.  *    not be used to endorse or promote products derived from this
  21.  *    software without prior written permission. For written
  22.  *    permission, please contact vocal@vovida.org.
  23.  *
  24.  * 4. Products derived from this software may not be called "VOCAL", nor
  25.  *    may "VOCAL" appear in their name, without prior written
  26.  *    permission of Vovida Networks, Inc.
  27.  * 
  28.  * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED
  29.  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  30.  * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND
  31.  * NON-INFRINGEMENT ARE DISCLAIMED.  IN NO EVENT SHALL VOVIDA
  32.  * NETWORKS, INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT DAMAGES
  33.  * IN EXCESS OF $1,000, NOR FOR ANY INDIRECT, INCIDENTAL, SPECIAL,
  34.  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  35.  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  36.  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
  37.  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  38.  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
  39.  * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
  40.  * DAMAGE.
  41.  * 
  42.  * ====================================================================
  43.  * 
  44.  * This software consists of voluntary contributions made by Vovida
  45.  * Networks, Inc. and many individuals on behalf of Vovida Networks,
  46.  * Inc.  For more information on Vovida Networks, Inc., please see
  47.  * <http://www.vovida.org/>.
  48.  *
  49.  */
  50. static const char* const RtpEvent_cxx_Version =
  51.     "$Id: RtpEvent.cxx,v 1.8 2001/02/27 00:55:25 larryt Exp $";
  52. #include "cpLog.h"
  53. #include "Rtp.hxx"
  54. #include "RtpEvent.hxx"
  55. #include "RtpPacket.hxx"
  56. RtpEvent::RtpEvent()
  57. {
  58.     _DTMFInterface = 0;
  59.     _DTMFType = rtpPayloadDTMF_RFC2833;
  60.     _keyEvent = KeyEventNULL;
  61.     _DTMFEvent = DTMFEventNULL;
  62.     return ;
  63. }
  64. RtpEvent::~RtpEvent()
  65. {
  66.     return ;
  67. }
  68. void RtpEvent::setDTMFType( const RtpPayloadType DTMFType )
  69. {
  70.     switch( DTMFType )
  71.     {
  72.         case( rtpPayloadDTMF_RFC2833 ):
  73.         case( rtpPayloadCiscoRtp ):
  74.             _DTMFType = DTMFType;
  75.         default:
  76.             cpLog(LOG_ERR, "Can't set RtpEvent to type %d", DTMFType );
  77.             return;
  78.     }
  79.     return;
  80. }
  81. void RtpEvent::sendEvent( const DTMFEvent event )
  82. {
  83.     switch( _DTMFType )
  84.     {
  85.         case( rtpPayloadDTMF_RFC2833 ):
  86.             sendEventRFC2833( event );
  87.             break;
  88.         case( rtpPayloadCiscoRtp ):
  89.             //sendEventCiscoRTP( event );
  90.             break;
  91.         default:
  92.             cpLog(LOG_ERR, "Unknown rtp payload event");
  93.             return ;
  94.     }
  95.     return;
  96. }
  97. void RtpEvent::sendEventRFC2833( const DTMFEvent event )
  98. {
  99.     return;
  100. }
  101. void RtpEvent::recvEvent( RtpPacket* p )
  102. {
  103.     if ( _DTMFInterface == 0 )
  104.         return ;
  105.     switch( p->getPayloadType() )
  106.     {
  107.         case( rtpPayloadDTMF_RFC2833 ):
  108.             recvEventRFC2833( p );
  109.             break;
  110.         case( rtpPayloadCiscoRtp ):
  111.             recvEventCiscoRTP( p );
  112.             break;
  113.         default:
  114.             cpLog(LOG_ERR, "Unknown rtp payload event");
  115.             return ;
  116.     }
  117.     return ;
  118. }
  119. void RtpEvent::recvEventRFC2833( RtpPacket* p )
  120. {
  121.     assert(p->getPayloadType() == rtpPayloadDTMF_RFC2833);
  122.     RtpEventDTMFRFC2833* e = NULL;
  123.     if ( p->getPayloadUsage() != 0 )
  124.         e = reinterpret_cast < RtpEventDTMFRFC2833* > (p->getPayloadLoc());
  125.     if ( e == NULL )
  126.     {
  127.         if ( _keyEvent == KeyEventOn )
  128.         {
  129.             // off detection
  130.             cpLog(LOG_DEBUG_STACK, "DTMF off detected: %d", _DTMFEvent);
  131.             sendToDTMFInterface ( _DTMFEvent );
  132.             _keyEvent = KeyEventNULL;
  133.         }
  134.     }
  135.     else if ( _keyEvent != KeyEventOn && !e->edge )
  136.     {
  137.         // on detection
  138.         _keyEvent = KeyEventOn;
  139.         _DTMFEvent = DTMFToEvent( e->event );
  140.         cpLog(LOG_DEBUG_STACK, "DTMF on detected: %d", _DTMFEvent);
  141.     }
  142.     return ;
  143. }
  144. void RtpEvent::recvEventCiscoRTP( RtpPacket* p )
  145. {
  146.     assert(p->getPayloadType() == rtpPayloadCiscoRtp);
  147.     RtpEventDTMFCiscoRtp* e = reinterpret_cast < RtpEventDTMFCiscoRtp* > (p->getPayloadLoc());
  148.     if ( _keyEvent != KeyEventOn && e->digitType == 1 )
  149.     {
  150.         // on detection
  151.         _keyEvent = KeyEventOn;
  152.         _DTMFEvent = DTMFToEvent(e->digitCode);
  153.         cpLog(LOG_DEBUG_STACK, "DTMF on detected: %d", _DTMFEvent);
  154.     }
  155.     else if ( _keyEvent == KeyEventOn && e->digitType == 0 && e->edge == 0 )
  156.     {
  157.         // off detection
  158.         cpLog(LOG_DEBUG_STACK, "DTMF off detected: %d", _DTMFEvent);
  159.         sendToDTMFInterface( _DTMFEvent );
  160.         _keyEvent = KeyEventNULL;
  161.     }
  162.     return ;
  163. }
  164. void RtpEvent::sendToDTMFInterface( const DTMFEvent e )
  165. {
  166.     cpLog(LOG_DEBUG_STACK, "Adding event %d to fifo", e);
  167.     if ( _DTMFInterface != 0 )
  168.         _DTMFInterface->sendDTMF( e, 20 );
  169.     return ;
  170. }
  171. DTMFEvent RtpEvent::DTMFToEvent( int event )
  172. {
  173.     DTMFEvent result;
  174.     switch ( event )
  175.     {
  176.         case 0:
  177.         result = DTMFEventDigit0;
  178.         break;
  179.         case 1:
  180.         result = DTMFEventDigit1;
  181.         break;
  182.         case 2:
  183.         result = DTMFEventDigit2;
  184.         break;
  185.         case 3:
  186.         result = DTMFEventDigit3;
  187.         break;
  188.         case 4:
  189.         result = DTMFEventDigit4;
  190.         break;
  191.         case 5:
  192.         result = DTMFEventDigit5;
  193.         break;
  194.         case 6:
  195.         result = DTMFEventDigit6;
  196.         break;
  197.         case 7:
  198.         result = DTMFEventDigit7;
  199.         break;
  200.         case 8:
  201.         result = DTMFEventDigit8;
  202.         break;
  203.         case 9:
  204.         result = DTMFEventDigit9;
  205.         break;
  206.         case 10:
  207.         result = DTMFEventDigitStar;
  208.         break;
  209.         case 11:
  210.         result = DTMFEventDigitHash;
  211.         break;
  212.         default:
  213.         cpLog(LOG_ERR, "Unknown DTMF event during conversion");
  214.         result = DTMFEventNULL;
  215.     }
  216.     return result;
  217. }