summaryrefslogtreecommitdiffstats
path: root/chromium/media/cast/audio_sender/audio_encoder.h
diff options
context:
space:
mode:
Diffstat (limited to 'chromium/media/cast/audio_sender/audio_encoder.h')
-rw-r--r--chromium/media/cast/audio_sender/audio_encoder.h34
1 files changed, 9 insertions, 25 deletions
diff --git a/chromium/media/cast/audio_sender/audio_encoder.h b/chromium/media/cast/audio_sender/audio_encoder.h
index 4a22d1983bd..2297672b74b 100644
--- a/chromium/media/cast/audio_sender/audio_encoder.h
+++ b/chromium/media/cast/audio_sender/audio_encoder.h
@@ -8,6 +8,7 @@
#include "base/memory/ref_counted.h"
#include "base/memory/scoped_ptr.h"
#include "base/threading/thread_checker.h"
+#include "media/base/audio_bus.h"
#include "media/cast/cast_config.h"
#include "media/cast/cast_environment.h"
@@ -16,47 +17,30 @@ class TimeTicks;
}
namespace media {
-class AudioBus;
-}
-
-namespace media {
namespace cast {
-class AudioEncoder : public base::RefCountedThreadSafe<AudioEncoder> {
+class AudioEncoder {
public:
- typedef base::Callback<void(scoped_ptr<EncodedAudioFrame>,
- const base::TimeTicks&)> FrameEncodedCallback;
+ typedef base::Callback<void(scoped_ptr<transport::EncodedFrame>)>
+ FrameEncodedCallback;
AudioEncoder(const scoped_refptr<CastEnvironment>& cast_environment,
const AudioSenderConfig& audio_config,
const FrameEncodedCallback& frame_encoded_callback);
+ virtual ~AudioEncoder();
- // The |audio_bus| must be valid until the |done_callback| is called.
- // The callback is called from the main cast thread as soon as the encoder is
- // done with |audio_bus|; it does not mean that the encoded data has been
- // sent out.
- void InsertAudio(const AudioBus* audio_bus,
- const base::TimeTicks& recorded_time,
- const base::Closure& done_callback);
+ CastInitializationStatus InitializationResult() const;
- protected:
- virtual ~AudioEncoder();
+ void InsertAudio(scoped_ptr<AudioBus> audio_bus,
+ const base::TimeTicks& recorded_time);
private:
- friend class base::RefCountedThreadSafe<AudioEncoder>;
-
class ImplBase;
class OpusImpl;
class Pcm16Impl;
- // Invokes |impl_|'s encode method on the AUDIO_ENCODER thread while holding
- // a ref-count on AudioEncoder.
- void EncodeAudio(const AudioBus* audio_bus,
- const base::TimeTicks& recorded_time,
- const base::Closure& done_callback);
-
const scoped_refptr<CastEnvironment> cast_environment_;
- scoped_ptr<ImplBase> impl_;
+ scoped_refptr<ImplBase> impl_;
// Used to ensure only one thread invokes InsertAudio().
base::ThreadChecker insert_thread_checker_;