| Index: media/base/android/audio_decoder_job.h
|
| diff --git a/media/base/android/audio_decoder_job.h b/media/base/android/audio_decoder_job.h
|
| index 4a37038c430cd5055a34c94bd89ec4953413d06f..6df7f1f3690a352d880b97deb7b95fc884ac95e8 100644
|
| --- a/media/base/android/audio_decoder_job.h
|
| +++ b/media/base/android/audio_decoder_job.h
|
| @@ -6,6 +6,7 @@
|
| #define MEDIA_BASE_ANDROID_AUDIO_DECODER_JOB_H_
|
|
|
| #include <jni.h>
|
| +#include <vector>
|
|
|
| #include "media/base/android/media_decoder_job.h"
|
|
|
| @@ -17,33 +18,23 @@ class AudioTimestampHelper;
|
| // Class for managing audio decoding jobs.
|
| class AudioDecoderJob : public MediaDecoderJob {
|
| public:
|
| - virtual ~AudioDecoderJob();
|
| -
|
| // Creates a new AudioDecoderJob instance for decoding audio.
|
| - // |audio_codec| - The audio format the object needs to decode.
|
| - // |sample_rate| - The sample rate of the decoded output.
|
| - // |channel_count| - The number of channels in the decoded output.
|
| - // |extra_data|, |extra_data_size| - Extra data buffer needed for initializing
|
| - // the decoder.
|
| - // |media_crypto| - Handle to a Java object that handles the encryption for
|
| - // the audio data.
|
| // |request_data_cb| - Callback used to request more data for the decoder.
|
| - static AudioDecoderJob* Create(
|
| - const AudioCodec audio_codec, int sample_rate, int channel_count,
|
| - const uint8* extra_data, size_t extra_data_size, jobject media_crypto,
|
| - const base::Closure& request_data_cb);
|
| + // |on_demuxer_config_changed_cb| - Callback used to inform the caller that
|
| + // demuxer config has changed.
|
| + AudioDecoderJob(const base::Closure& request_data_cb,
|
| + const base::Closure& on_demuxer_config_changed_cb);
|
| + ~AudioDecoderJob();
|
| +
|
| + virtual bool HasStream() const OVERRIDE;
|
|
|
| + // Set the volume of the audio output.
|
| void SetVolume(double volume);
|
|
|
| // Sets the base timestamp for |audio_timestamp_helper_|.
|
| void SetBaseTimestamp(base::TimeDelta base_timestamp);
|
|
|
| private:
|
| - AudioDecoderJob(scoped_ptr<AudioTimestampHelper> audio_timestamp_helper,
|
| - scoped_ptr<AudioCodecBridge> audio_decoder_bridge,
|
| - int bytes_per_frame,
|
| - const base::Closure& request_data_cb);
|
| -
|
| // MediaDecoderJob implementation.
|
| virtual void ReleaseOutputBuffer(
|
| int output_buffer_index,
|
| @@ -51,16 +42,30 @@ class AudioDecoderJob : public MediaDecoderJob {
|
| bool render_output,
|
| base::TimeDelta current_presentation_timestamp,
|
| const ReleaseOutputCompletionCallback& callback) OVERRIDE;
|
| -
|
| virtual bool ComputeTimeToRender() const OVERRIDE;
|
| -
|
| - // number of bytes per audio frame;
|
| + virtual bool IsDemuxerConfigChanged(
|
| + const DemuxerConfigs& configs) const OVERRIDE;
|
| + virtual void UpdateDemuxerConfigs(const DemuxerConfigs& configs) OVERRIDE;
|
| + virtual bool CreateMediaCodecBridgeInternal() OVERRIDE;
|
| +
|
| + // Helper method to set the audio output volume.
|
| + void SetVolumeInternal();
|
| +
|
| + // Audio configs from the demuxer.
|
| + AudioCodec audio_codec_;
|
| + int num_channels_;
|
| + int sampling_rate_;
|
| + std::vector<uint8> audio_extra_data_;
|
| + double volume_;
|
| int bytes_per_frame_;
|
|
|
| - scoped_ptr<AudioCodecBridge> audio_codec_bridge_;
|
| + // Base timestamp for the |audio_timestamp_helper_|.
|
| + base::TimeDelta base_timestamp_;
|
|
|
| // Object to calculate the current audio timestamp for A/V sync.
|
| scoped_ptr<AudioTimestampHelper> audio_timestamp_helper_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(AudioDecoderJob);
|
| };
|
|
|
| } // namespace media
|
|
|