You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

57 lines
2.4KB

  1. /*
  2. * audio interleaving prototypes and declarations
  3. *
  4. * Copyright (c) 2009 Baptiste Coudurier <baptiste dot coudurier at gmail dot com>
  5. *
  6. * This file is part of FFmpeg.
  7. *
  8. * FFmpeg is free software; you can redistribute it and/or
  9. * modify it under the terms of the GNU Lesser General Public
  10. * License as published by the Free Software Foundation; either
  11. * version 2.1 of the License, or (at your option) any later version.
  12. *
  13. * FFmpeg is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  16. * Lesser General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU Lesser General Public
  19. * License along with FFmpeg; if not, write to the Free Software
  20. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  21. */
  22. #ifndef AVFORMAT_AUDIOINTERLEAVE_H
  23. #define AVFORMAT_AUDIOINTERLEAVE_H
  24. #include "libavutil/fifo.h"
  25. #include "avformat.h"
  26. typedef struct AudioInterleaveContext {
  27. AVFifoBuffer *fifo;
  28. unsigned fifo_size; ///< size of currently allocated FIFO
  29. int64_t n; ///< number of generated packets
  30. int64_t nb_samples; ///< number of generated samples
  31. uint64_t dts; ///< current dts
  32. int sample_size; ///< size of one sample all channels included
  33. int samples_per_frame; ///< samples per frame if fixed, 0 otherwise
  34. AVRational time_base; ///< time base of output audio packets
  35. } AudioInterleaveContext;
  36. int ff_audio_interleave_init(AVFormatContext *s, const int samples_per_frame, AVRational time_base);
  37. void ff_audio_interleave_close(AVFormatContext *s);
  38. /**
  39. * Rechunk audio PCM packets per AudioInterleaveContext->samples_per_frame
  40. * and interleave them correctly.
  41. * The first element of AVStream->priv_data must be AudioInterleaveContext
  42. * when using this function.
  43. *
  44. * @param get_packet function will output a packet when streams are correctly interleaved.
  45. * @param compare_ts function will compare AVPackets and decide interleaving order.
  46. */
  47. int ff_audio_rechunk_interleave(AVFormatContext *s, AVPacket *out, AVPacket *pkt, int flush,
  48. int (*get_packet)(AVFormatContext *, AVPacket *, AVPacket *, int),
  49. int (*compare_ts)(AVFormatContext *, const AVPacket *, const AVPacket *));
  50. #endif /* AVFORMAT_AUDIOINTERLEAVE_H */