1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef MEDIA_BASE_AUDIO_SPLICER_H_
6 #define MEDIA_BASE_AUDIO_SPLICER_H_
10 #include "base/memory/ref_counted.h"
11 #include "media/base/audio_timestamp_helper.h"
12 #include "media/base/media_export.h"
16 class AudioDecoderConfig
;
19 // Helper class that handles filling gaps and resolving overlaps.
20 class MEDIA_EXPORT AudioSplicer
{
22 AudioSplicer(int bytes_per_frame
, int samples_per_second
);
25 // Resets the splicer state by clearing the output buffers queue,
26 // and resetting the timestamp helper.
29 // Adds a new buffer full of samples or end of stream buffer to the splicer.
30 // Returns true if the buffer was accepted. False is returned if an error
32 bool AddInput(const scoped_refptr
<DataBuffer
>& input
);
34 // Returns true if the splicer has a buffer to return.
35 bool HasNextBuffer() const;
37 // Removes the next buffer from the output buffer queue and returns it.
38 // This should only be called if HasNextBuffer() returns true.
39 scoped_refptr
<DataBuffer
> GetNextBuffer();
42 void AddOutputBuffer(const scoped_refptr
<DataBuffer
>& buffer
);
44 AudioTimestampHelper output_timestamp_helper_
;
46 // Minimum gap size needed before the splicer will take action to
47 // fill a gap. This avoids periodically inserting and then dropping samples
48 // when the buffer timestamps are slightly off because of timestamp rounding
49 // in the source content.
52 std::deque
<scoped_refptr
<DataBuffer
> > output_buffers_
;
53 bool received_end_of_stream_
;
55 DISALLOW_IMPLICIT_CONSTRUCTORS(AudioSplicer
);