MPEG1or2VideoRTPSink.hh 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. /**********
  2. This library is free software; you can redistribute it and/or modify it under
  3. the terms of the GNU Lesser General Public License as published by the
  4. Free Software Foundation; either version 3 of the License, or (at your
  5. option) any later version. (See <http://www.gnu.org/copyleft/lesser.html>.)
  6. This library is distributed in the hope that it will be useful, but WITHOUT
  7. ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  8. FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
  9. more details.
  10. You should have received a copy of the GNU Lesser General Public License
  11. along with this library; if not, write to the Free Software Foundation, Inc.,
  12. 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  13. **********/
  14. // "liveMedia"
  15. // Copyright (c) 1996-2019 Live Networks, Inc. All rights reserved.
  16. // RTP sink for MPEG video (RFC 2250)
  17. // C++ header
  18. #ifndef _MPEG_1OR2_VIDEO_RTP_SINK_HH
  19. #define _MPEG_1OR2_VIDEO_RTP_SINK_HH
  20. #ifndef _VIDEO_RTP_SINK_HH
  21. #include "VideoRTPSink.hh"
  22. #endif
  23. class MPEG1or2VideoRTPSink: public VideoRTPSink {
  24. public:
  25. static MPEG1or2VideoRTPSink* createNew(UsageEnvironment& env, Groupsock* RTPgs);
  26. protected:
  27. MPEG1or2VideoRTPSink(UsageEnvironment& env, Groupsock* RTPgs);
  28. // called only by createNew()
  29. virtual ~MPEG1or2VideoRTPSink();
  30. private: // redefined virtual functions:
  31. virtual Boolean sourceIsCompatibleWithUs(MediaSource& source);
  32. virtual void doSpecialFrameHandling(unsigned fragmentationOffset,
  33. unsigned char* frameStart,
  34. unsigned numBytesInFrame,
  35. struct timeval framePresentationTime,
  36. unsigned numRemainingBytes);
  37. virtual Boolean allowFragmentationAfterStart() const;
  38. virtual
  39. Boolean frameCanAppearAfterPacketStart(unsigned char const* frameStart,
  40. unsigned numBytesInFrame) const;
  41. virtual unsigned specialHeaderSize() const;
  42. private:
  43. // MPEG video-specific state, used to decide how to fill out the
  44. // video-specific header, and when to include multiple 'frames' in a
  45. // single outgoing RTP packet. Eventually we should somehow get this
  46. // state from the source (MPEG1or2VideoStreamFramer) instead, as the source
  47. // already has this info itself.
  48. struct {
  49. unsigned temporal_reference;
  50. unsigned char picture_coding_type;
  51. unsigned char vector_code_bits; // FBV,BFC,FFV,FFC from RFC 2250, sec. 3.4
  52. } fPictureState;
  53. Boolean fPreviousFrameWasSlice;
  54. // used to implement frameCanAppearAfterPacketStart()
  55. Boolean fSequenceHeaderPresent;
  56. Boolean fPacketBeginsSlice, fPacketEndsSlice;
  57. };
  58. #endif