⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mpeg4latmaudiortpsource.hh

📁 流媒体传输协议的实现代码,非常有用.可以支持rtsp mms等流媒体传输协议
💻 HH
字号:
/**********This library is free software; you can redistribute it and/or modify it underthe terms of the GNU Lesser General Public License as published by theFree Software Foundation; either version 2.1 of the License, or (at youroption) any later version. (See <http://www.gnu.org/copyleft/lesser.html>.)This library is distributed in the hope that it will be useful, but WITHOUTANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESSFOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License formore details.You should have received a copy of the GNU Lesser General Public Licensealong with this library; if not, write to the Free Software Foundation, Inc.,59 Temple Place, Suite 330, Boston, MA  02111-1307  USA**********/// "liveMedia"// Copyright (c) 1996-2004 Live Networks, Inc.  All rights reserved.// MPEG-4 audio, using LATM multiplexing// C++ header#ifndef _MPEG4_LATM_AUDIO_RTP_SOURCE_HH#define _MPEG4_LATM_AUDIO_RTP_SOURCE_HH#ifndef _MULTI_FRAMED_RTP_SOURCE_HH#include "MultiFramedRTPSource.hh"#endifclass MPEG4LATMAudioRTPSource: public MultiFramedRTPSource {public:  static MPEG4LATMAudioRTPSource*  createNew(UsageEnvironment& env, Groupsock* RTPgs,	    unsigned char rtpPayloadFormat,	    unsigned rtpTimestampFrequency);protected:  virtual ~MPEG4LATMAudioRTPSource();private:  MPEG4LATMAudioRTPSource(UsageEnvironment& env, Groupsock* RTPgs,			  unsigned char rtpPayloadFormat,			  unsigned rtpTimestampFrequency);      // called only by createNew()private:  // redefined virtual functions:  virtual Boolean processSpecialHeader(BufferedPacket* packet,                                       unsigned& resultSpecialHeaderSize);  virtual char const* MIMEtype() const; };// A utility for parsing a "StreamMuxConfig" stringBooleanparseStreamMuxConfigStr(char const* configStr,			// result parameters:			Boolean& audioMuxVersion,			Boolean& allStreamsSameTimeFraming,			unsigned char& numSubFrames,			unsigned char& numProgram,			unsigned char& numLayer,			unsigned char*& audioSpecificConfig,			unsigned& audioSpecificConfigSize);    // Parses "configStr" as a sequence of hexadecimal digits, representing    // a "StreamMuxConfig" (as defined in ISO.IEC 14496-3, table 1.21).    // Returns, in "audioSpecificConfig", a binary representation of    // the enclosed "AudioSpecificConfig" structure (of size    // "audioSpecificConfigSize" bytes).  The memory for this is allocated    // dynamically by this function; the caller is responsible for    // freeing it.  Other values, that precede "AudioSpecificConfig",    // are returned in the other parameters.    // Returns True iff the parsing succeeds.    // IMPORTANT NOTE: The implementation of this function currently assumes    // that everything after the first "numLayer" field is an    // "AudioSpecificConfig".  Therefore, it will not work properly if    // "audioMuxVersion" != 0, "numProgram" > 0, or "numLayer" > 0.    // Also, any 'other data' or CRC info will be included at    // the end of "audioSpecificConfig".unsigned char* parseStreamMuxConfigStr(char const* configStr,				       // result parameter:				       unsigned& audioSpecificConfigSize);    // A variant of the above that returns just the "AudioSpecificConfig" data    // (or NULL) if the parsing failed, without bothering with the other    // result parameters.unsigned char* parseGeneralConfigStr(char const* configStr,				     // result parameter:				     unsigned& configSize);    // A routine that parses an arbitrary config string, returning    // the result in binary form.#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -