00001 /********** 00002 This library is free software; you can redistribute it and/or modify it under 00003 the terms of the GNU Lesser General Public License as published by the 00004 Free Software Foundation; either version 2.1 of the License, or (at your 00005 option) any later version. (See <http://www.gnu.org/copyleft/lesser.html>.) 00006 00007 This library is distributed in the hope that it will be useful, but WITHOUT 00008 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS 00009 FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for 00010 more details. 00011 00012 You should have received a copy of the GNU Lesser General Public License 00013 along with this library; if not, write to the Free Software Foundation, Inc., 00014 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 00015 **********/ 00016 // "liveMedia" 00017 // Copyright (c) 1996-2013 Live Networks, Inc. All rights reserved. 00018 // H.264 Video RTP Sources 00019 // C++ header 00020 00021 #ifndef _H264_VIDEO_RTP_SOURCE_HH 00022 #define _H264_VIDEO_RTP_SOURCE_HH 00023 00024 #ifndef _MULTI_FRAMED_RTP_SOURCE_HH 00025 #include "MultiFramedRTPSource.hh" 00026 #endif 00027 00028 class H264VideoRTPSource: public MultiFramedRTPSource { 00029 public: 00030 static H264VideoRTPSource* 00031 createNew(UsageEnvironment& env, Groupsock* RTPgs, 00032 unsigned char rtpPayloadFormat, 00033 unsigned rtpTimestampFrequency = 90000); 00034 00035 protected: 00036 H264VideoRTPSource(UsageEnvironment& env, Groupsock* RTPgs, 00037 unsigned char rtpPayloadFormat, 00038 unsigned rtpTimestampFrequency); 00039 // called only by createNew() 00040 00041 virtual ~H264VideoRTPSource(); 00042 00043 protected: 00044 // redefined virtual functions: 00045 virtual Boolean processSpecialHeader(BufferedPacket* packet, 00046 unsigned& resultSpecialHeaderSize); 00047 virtual char const* MIMEtype() const; 00048 00049 private: 00050 friend class H264BufferedPacket; 00051 unsigned char fCurPacketNALUnitType; 00052 }; 00053 00054 class SPropRecord { 00055 public: 00056 ~SPropRecord() { delete[] sPropBytes; } 00057 00058 unsigned sPropLength; // in bytes 00059 unsigned char* sPropBytes; 00060 }; 00061 00062 SPropRecord* parseSPropParameterSets(char const* sPropParameterSetsStr, 00063 // result parameter: 00064 unsigned& numSPropRecords); 00065 // Returns the binary value of each 'parameter set' specified in a 00066 // "sprop-parameter-sets" string (in the SDP description for a H.264/RTP stream). 00067 // The value is returned as an array (length "numSPropRecords") of "SPropRecord"s. 00068 // This array is dynamically allocated by this routine, and must be delete[]d by the caller. 00069 00070 #endif
1.5.2