Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(121)

Side by Side Diff: media/audio/virtual_audio_sink.h

Issue 1897953003: Unmute Tab Audio For Desktop Share (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright (c) 2016 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.
4
5 #ifndef MEDIA_AUDIO_VIRTUAL_AUDIO_SINK_H_
6 #define MEDIA_AUDIO_VIRTUAL_AUDIO_SINK_H_
7
8 #include "base/callback.h"
9 #include "base/macros.h"
10 #include "media/audio/audio_io.h"
11 #include "media/audio/audio_parameters.h"
12 #include "media/base/audio_converter.h"
13 #include "media/base/audio_shifter.h"
14
15 namespace media {
16
17 class VirtualAudioInputStream;
18
19 class MEDIA_EXPORT AudioPushSink {
20 public:
21 virtual void OnData(const AudioBus* source) = 0;
22 virtual void Start() = 0;
23 virtual void Stop() = 0;
24 virtual void Close() = 0;
25 };
26
27 // This class is an adapter between push model and pull model for audio stream.
28 // Audio provider calls OnData() to push audio data into this class.
29 // Audio consumer calls ProvideInput() to pull audio data.
30 class MEDIA_EXPORT VirtualAudioSink : public AudioPushSink,
31 public AudioConverter::InputCallback {
32 public:
33 typedef base::Callback<void(VirtualAudioSink* sink)> AfterCloseCallback;
34
35 VirtualAudioSink(AudioParameters param,
36 VirtualAudioInputStream* target,
miu 2016/04/21 00:15:25 Please document that the caller must guarantee |ta
qiangchen 2016/04/28 00:00:56 Done.
37 AfterCloseCallback callback);
38 ~VirtualAudioSink() override;
39
40 // AudioPushSink
41 void Start() override;
miu 2016/04/21 00:15:25 From what I see, you don't need these Start/Stop m
qiangchen 2016/04/28 00:00:56 Done.
42 void Stop() override;
43 void Close() override;
44 void OnData(const AudioBus* source) override;
miu 2016/04/21 00:15:25 1. |source| should be of type const AudioBus& (not
qiangchen 2016/04/28 00:00:56 Done.
45
46 // AudioConverter::InputCallback
47 double ProvideInput(AudioBus* audio_bus,
48 base::TimeDelta buffer_delay) override;
49
50 private:
51 bool started_;
52 AudioParameters params_;
53 VirtualAudioInputStream* target_;
54 std::unique_ptr<AudioShifter> shifter_;
miu 2016/04/21 00:15:25 Don't use unnecessary indirection here for the Aud
qiangchen 2016/04/28 00:00:56 Done.
55 AfterCloseCallback after_close_callback_;
56 };
57
58 } // namespace media
59
60 #endif // MEDIA_AUDIO_VIRTUAL_AUDIO_SINK_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698