| // Copyright (c) 2013 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef MEDIA_AUDIO_FAKE_AUDIO_CONSUMER_H_ |
| #define MEDIA_AUDIO_FAKE_AUDIO_CONSUMER_H_ |
| |
| #include "base/callback_forward.h" |
| #include "base/memory/ref_counted.h" |
| #include "media/base/media_export.h" |
| |
| namespace base { |
| class SingleThreadTaskRunner; |
| } |
| |
| namespace media { |
| class AudioBus; |
| class AudioParameters; |
| |
| // A fake audio consumer. Using a provided message loop, FakeAudioConsumer will |
| // simulate a real time consumer of audio data. |
| class MEDIA_EXPORT FakeAudioConsumer { |
| public: |
| // |worker_task_runner| is the task runner on which the ReadCB provided to |
| // Start() will be executed on. This may or may not be the be for the same |
| // thread that invokes the Start/Stop methods. |
| // |params| is used to determine the frequency of callbacks. |
| FakeAudioConsumer( |
| const scoped_refptr<base::SingleThreadTaskRunner>& worker_task_runner, |
| const AudioParameters& params); |
| ~FakeAudioConsumer(); |
| |
| // Start executing |read_cb| at a regular intervals. Stop() must be called by |
| // the same thread before destroying FakeAudioConsumer. |
| typedef base::Callback<void(AudioBus* audio_bus)> ReadCB; |
| void Start(const ReadCB& read_cb); |
| |
| // Stop executing the ReadCB provided to Start(). Blocks until the worker |
| // loop is not inside a ReadCB invocation. Safe to call multiple times. Must |
| // be called on the same thread that called Start(). |
| void Stop(); |
| |
| private: |
| // All state and implementation is kept within this ref-counted class because |
| // cancellation of posted tasks must happen on the worker thread some time |
| // after the call to Stop() (on the main thread) returns. |
| class Worker; |
| const scoped_refptr<Worker> worker_; |
| |
| DISALLOW_COPY_AND_ASSIGN(FakeAudioConsumer); |
| }; |
| |
| } // namespace media |
| |
| #endif // MEDIA_AUDIO_FAKE_AUDIO_CONSUMER_H_ |