| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef MEDIA_FORMATS_MP2T_ES_PARSER_ADTS_H_ | 5 #ifndef MEDIA_FORMATS_MP2T_ES_PARSER_MPEG1AUDIO_H_ |
| 6 #define MEDIA_FORMATS_MP2T_ES_PARSER_ADTS_H_ | 6 #define MEDIA_FORMATS_MP2T_ES_PARSER_MPEG1AUDIO_H_ |
| 7 | 7 |
| 8 #include <list> | 8 #include <list> |
| 9 #include <utility> | 9 #include <utility> |
| 10 | 10 |
| 11 #include "base/callback.h" | 11 #include "base/callback.h" |
| 12 #include "base/compiler_specific.h" | 12 #include "base/compiler_specific.h" |
| 13 #include "base/memory/scoped_ptr.h" | 13 #include "base/memory/scoped_ptr.h" |
| 14 #include "base/time/time.h" | 14 #include "base/time/time.h" |
| 15 #include "media/base/audio_decoder_config.h" | 15 #include "media/base/audio_decoder_config.h" |
| 16 #include "media/base/media_export.h" | 16 #include "media/base/media_export.h" |
| 17 #include "media/formats/mp2t/es_parser.h" | 17 #include "media/formats/mp2t/es_parser.h" |
| 18 | 18 |
| 19 namespace media { | 19 namespace media { |
| 20 class AudioTimestampHelper; | 20 class AudioTimestampHelper; |
| 21 class BitReader; | 21 class BitReader; |
| 22 class OffsetByteQueue; | 22 class OffsetByteQueue; |
| 23 class StreamParserBuffer; | 23 class StreamParserBuffer; |
| 24 } | 24 } |
| 25 | 25 |
| 26 namespace media { | 26 namespace media { |
| 27 namespace mp2t { | 27 namespace mp2t { |
| 28 | 28 |
| 29 class MEDIA_EXPORT EsParserAdts : public EsParser { | 29 class MEDIA_EXPORT EsParserMpeg1Audio : public EsParser { |
| 30 public: | 30 public: |
| 31 typedef base::Callback<void(const AudioDecoderConfig&)> NewAudioConfigCB; | 31 typedef base::Callback<void(const AudioDecoderConfig&)> NewAudioConfigCB; |
| 32 | 32 |
| 33 EsParserAdts(const NewAudioConfigCB& new_audio_config_cb, | 33 EsParserMpeg1Audio(const NewAudioConfigCB& new_audio_config_cb, |
| 34 const EmitBufferCB& emit_buffer_cb, | 34 const EmitBufferCB& emit_buffer_cb); |
| 35 bool sbr_in_mimetype); | 35 virtual ~EsParserMpeg1Audio(); |
| 36 virtual ~EsParserAdts(); | |
| 37 | 36 |
| 38 // EsParser implementation. | 37 // EsParser implementation. |
| 39 virtual void Flush() OVERRIDE; | 38 virtual void Flush() OVERRIDE; |
| 40 | 39 |
| 41 private: | 40 private: |
| 42 struct AdtsFrame; | 41 // Used to link a PTS with a byte position in the ES stream. |
| 42 typedef std::pair<int64, base::TimeDelta> EsPts; |
| 43 typedef std::list<EsPts> EsPtsList; |
| 44 |
| 45 struct Mpeg1AudioFrame; |
| 43 | 46 |
| 44 // EsParser implementation. | 47 // EsParser implementation. |
| 45 virtual bool ParseFromEsQueue() OVERRIDE; | 48 virtual bool ParseFromEsQueue() OVERRIDE; |
| 46 virtual void ResetInternal() OVERRIDE; | 49 virtual void ResetInternal() OVERRIDE; |
| 47 | 50 |
| 48 // Synchronize the stream on an ADTS syncword (consuming bytes from | 51 // Synchronize the stream on a Mpeg1 audio syncword (consuming bytes from |
| 49 // |es_queue_| if needed). | 52 // |es_queue_| if needed). |
| 50 // Returns true when a full ADTS frame has been found: in that case | 53 // Returns true when a full Mpeg1 audio frame has been found: in that case |
| 51 // |adts_frame| structure is filled up accordingly. | 54 // |mpeg1audio_frame| structure is filled up accordingly. |
| 52 // Returns false otherwise (no ADTS syncword found or partial ADTS frame). | 55 // Returns false otherwise (no Mpeg1 audio syncword found or partial Mpeg1 |
| 53 bool LookForAdtsFrame(AdtsFrame* adts_frame); | 56 // audio frame). |
| 54 | 57 bool LookForMpeg1AudioFrame(Mpeg1AudioFrame* mpeg1audio_frame); |
| 55 // Skip an ADTS frame in the ES queue. | |
| 56 void SkipAdtsFrame(const AdtsFrame& adts_frame); | |
| 57 | 58 |
| 58 // Signal any audio configuration change (if any). | 59 // Signal any audio configuration change (if any). |
| 59 // Return false if the current audio config is not | 60 // Return false if the current audio config is not |
| 60 // a supported ADTS audio config. | 61 // a supported Mpeg1 audio config. |
| 61 bool UpdateAudioConfiguration(const uint8* adts_header); | 62 bool UpdateAudioConfiguration(const uint8* mpeg1audio_header); |
| 63 |
| 64 void SkipMpeg1AudioFrame(const Mpeg1AudioFrame& mpeg1audio_frame); |
| 62 | 65 |
| 63 // Callbacks: | 66 // Callbacks: |
| 64 // - to signal a new audio configuration, | 67 // - to signal a new audio configuration, |
| 65 // - to send ES buffers. | 68 // - to send ES buffers. |
| 66 NewAudioConfigCB new_audio_config_cb_; | 69 NewAudioConfigCB new_audio_config_cb_; |
| 67 EmitBufferCB emit_buffer_cb_; | 70 EmitBufferCB emit_buffer_cb_; |
| 68 | 71 |
| 69 // True when AAC SBR extension is signalled in the mimetype | |
| 70 // (mp4a.40.5 in the codecs parameter). | |
| 71 bool sbr_in_mimetype_; | |
| 72 | |
| 73 // Interpolated PTS for frames that don't have one. | 72 // Interpolated PTS for frames that don't have one. |
| 74 scoped_ptr<AudioTimestampHelper> audio_timestamp_helper_; | 73 scoped_ptr<AudioTimestampHelper> audio_timestamp_helper_; |
| 75 | 74 |
| 76 // Last audio config. | 75 // Last audio config. |
| 77 AudioDecoderConfig last_audio_decoder_config_; | 76 AudioDecoderConfig last_audio_decoder_config_; |
| 78 | 77 |
| 79 DISALLOW_COPY_AND_ASSIGN(EsParserAdts); | 78 DISALLOW_COPY_AND_ASSIGN(EsParserMpeg1Audio); |
| 80 }; | 79 }; |
| 81 | 80 |
| 82 } // namespace mp2t | 81 } // namespace mp2t |
| 83 } // namespace media | 82 } // namespace media |
| 84 | 83 |
| 85 #endif | 84 #endif // MEDIA_FORMATS_MP2T_ES_PARSER_MPEG1AUDIO_H_ |
| OLD | NEW |