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-2012 Live Networks, Inc. All rights reserved. 00018 // RTP sink for MPEG video (RFC 2250) 00019 // C++ header 00020 00021 #ifndef _MPEG_1OR2_VIDEO_RTP_SINK_HH 00022 #define _MPEG_1OR2_VIDEO_RTP_SINK_HH 00023 00024 #ifndef _VIDEO_RTP_SINK_HH 00025 #include "VideoRTPSink.hh" 00026 #endif 00027 00028 class MPEG1or2VideoRTPSink: public VideoRTPSink { 00029 public: 00030 static MPEG1or2VideoRTPSink* createNew(UsageEnvironment& env, Groupsock* RTPgs); 00031 00032 protected: 00033 MPEG1or2VideoRTPSink(UsageEnvironment& env, Groupsock* RTPgs); 00034 // called only by createNew() 00035 00036 virtual ~MPEG1or2VideoRTPSink(); 00037 00038 private: // redefined virtual functions: 00039 virtual Boolean sourceIsCompatibleWithUs(MediaSource& source); 00040 00041 virtual void doSpecialFrameHandling(unsigned fragmentationOffset, 00042 unsigned char* frameStart, 00043 unsigned numBytesInFrame, 00044 struct timeval framePresentationTime, 00045 unsigned numRemainingBytes); 00046 virtual Boolean allowFragmentationAfterStart() const; 00047 virtual 00048 Boolean frameCanAppearAfterPacketStart(unsigned char const* frameStart, 00049 unsigned numBytesInFrame) const; 00050 virtual unsigned specialHeaderSize() const; 00051 00052 private: 00053 // MPEG video-specific state, used to decide how to fill out the 00054 // video-specific header, and when to include multiple 'frames' in a 00055 // single outgoing RTP packet. Eventually we should somehow get this 00056 // state from the source (MPEG1or2VideoStreamFramer) instead, as the source 00057 // already has this info itself. 00058 struct { 00059 unsigned temporal_reference; 00060 unsigned char picture_coding_type; 00061 unsigned char vector_code_bits; // FBV,BFC,FFV,FFC from RFC 2250, sec. 3.4 00062 } fPictureState; 00063 Boolean fPreviousFrameWasSlice; 00064 // used to implement frameCanAppearAfterPacketStart() 00065 Boolean fSequenceHeaderPresent; 00066 Boolean fPacketBeginsSlice, fPacketEndsSlice; 00067 }; 00068 00069 #endif
1.5.2