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

Side by Side Diff: components/copresence/mediums/audio/audio_recorder_impl.h

Issue 637223011: Redesign the copresence audio handlers. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git/+/master
Patch Set: Created 6 years, 2 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
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef COMPONENTS_COPRESENCE_MEDIUMS_AUDIO_AUDIO_RECORDER_H_ 5 #ifndef COMPONENTS_COPRESENCE_MEDIUMS_AUDIO_AUDIO_RECORDER_IMPL_H_
6 #define COMPONENTS_COPRESENCE_MEDIUMS_AUDIO_AUDIO_RECORDER_H_ 6 #define COMPONENTS_COPRESENCE_MEDIUMS_AUDIO_AUDIO_RECORDER_IMPL_H_
7 7
8 #include <string> 8 #include <string>
9 9
10 #include "base/gtest_prod_util.h" 10 #include "base/gtest_prod_util.h"
11 #include "base/macros.h" 11 #include "base/macros.h"
12 #include "base/memory/scoped_ptr.h" 12 #include "base/memory/scoped_ptr.h"
13 #include "components/copresence/mediums/audio/audio_recorder.h"
13 #include "media/audio/audio_io.h" 14 #include "media/audio/audio_io.h"
14 #include "media/audio/audio_parameters.h" 15 #include "media/audio/audio_parameters.h"
15 #include "media/base/audio_converter.h" 16 #include "media/base/audio_converter.h"
16 17
17 namespace base { 18 namespace base {
18 class MessageLoop; 19 class MessageLoop;
19 } 20 }
20 21
21 namespace media { 22 namespace media {
22 class AudioBus; 23 class AudioBus;
23 } 24 }
24 25
25 namespace copresence { 26 namespace copresence {
26 27
27 // The AudioRecorder class will record audio until told to stop. 28 // The AudioRecorder class will record audio until told to stop.
28 class AudioRecorder : public media::AudioInputStream::AudioInputCallback, 29 class AudioRecorderImpl final
29 public media::AudioConverter::InputCallback { 30 : public AudioRecorder,
31 public media::AudioInputStream::AudioInputCallback,
32 public media::AudioConverter::InputCallback {
30 public: 33 public:
31 typedef base::Callback<void(const std::string&)> DecodeSamplesCallback; 34 typedef base::Callback<void(const std::string&)> RecordedSamplesCallback;
32 35
33 explicit AudioRecorder(const DecodeSamplesCallback& decode_callback); 36 AudioRecorderImpl();
34 37
35 // Initializes the object. Do not use this object before calling this method. 38 // AudioRecorder overrides:
36 virtual void Initialize(); 39 void Initialize(const RecordedSamplesCallback& decode_callback) override;
37 40 void Record() override;
38 virtual void Record(); 41 void Stop() override;
39 virtual void Stop(); 42 void Finalize() override;
40 43 bool IsRecording() override;
41 // Cleans up and deletes this object. Do not use object after this call.
42 virtual void Finalize();
43
44 bool IsRecording();
45 44
46 // Takes ownership of the stream. 45 // Takes ownership of the stream.
47 void set_input_stream_for_testing( 46 void set_input_stream_for_testing(
48 media::AudioInputStream* input_stream_for_testing) { 47 media::AudioInputStream* input_stream_for_testing) {
49 input_stream_for_testing_.reset(input_stream_for_testing); 48 input_stream_for_testing_.reset(input_stream_for_testing);
50 } 49 }
51 50
52 // Takes ownership of the params. 51 // Takes ownership of the params.
53 void set_params_for_testing(media::AudioParameters* params_for_testing) { 52 void set_params_for_testing(media::AudioParameters* params_for_testing) {
54 params_for_testing_.reset(params_for_testing); 53 params_for_testing_.reset(params_for_testing);
55 } 54 }
56 55
57 protected: 56 protected:
58 ~AudioRecorder() override; 57 virtual ~AudioRecorderImpl();
59 void set_is_recording(bool is_recording) { is_recording_ = is_recording; } 58 void set_is_recording(bool is_recording) { is_recording_ = is_recording; }
60 59
61 private: 60 private:
62 friend class AudioRecorderTest; 61 friend class AudioRecorderTest;
63 FRIEND_TEST_ALL_PREFIXES(AudioRecorderTest, BasicRecordAndStop); 62 FRIEND_TEST_ALL_PREFIXES(AudioRecorderTest, BasicRecordAndStop);
64 FRIEND_TEST_ALL_PREFIXES(AudioRecorderTest, OutOfOrderRecordAndStopMultiple); 63 FRIEND_TEST_ALL_PREFIXES(AudioRecorderTest, OutOfOrderRecordAndStopMultiple);
65 64
66 // Methods to do our various operations; all of these need to be run on the 65 // Methods to do our various operations; all of these need to be run on the
67 // audio thread. 66 // audio thread.
68 void InitializeOnAudioThread(); 67 void InitializeOnAudioThread();
(...skipping 16 matching lines...) Expand all
85 double ProvideInput(media::AudioBus* dest, 84 double ProvideInput(media::AudioBus* dest,
86 base::TimeDelta buffer_delay) override; 85 base::TimeDelta buffer_delay) override;
87 86
88 // Flushes the audio loop, making sure that any queued operations are 87 // Flushes the audio loop, making sure that any queued operations are
89 // performed. 88 // performed.
90 void FlushAudioLoopForTesting(); 89 void FlushAudioLoopForTesting();
91 90
92 bool is_recording_; 91 bool is_recording_;
93 92
94 media::AudioInputStream* stream_; 93 media::AudioInputStream* stream_;
95 DecodeSamplesCallback decode_callback_; 94
95 RecordedSamplesCallback decode_callback_;
96 96
97 // ProvideInput will use this buffer as its source. 97 // ProvideInput will use this buffer as its source.
98 const media::AudioBus* temp_conversion_buffer_; 98 const media::AudioBus* temp_conversion_buffer_;
99 99
100 // Outside of the ctor/Initialize method, only access the next variables on 100 // Outside of the ctor/Initialize method, only access the next variables on
101 // the recording thread. 101 // the recording thread.
102 scoped_ptr<media::AudioBus> buffer_; 102 scoped_ptr<media::AudioBus> buffer_;
103 int total_buffer_frames_; 103 int total_buffer_frames_;
104 int buffer_frame_index_; 104 int buffer_frame_index_;
105 105
106 scoped_ptr<media::AudioConverter> converter_; 106 scoped_ptr<media::AudioConverter> converter_;
107 107
108 scoped_ptr<media::AudioInputStream> input_stream_for_testing_; 108 scoped_ptr<media::AudioInputStream> input_stream_for_testing_;
109 scoped_ptr<media::AudioParameters> params_for_testing_; 109 scoped_ptr<media::AudioParameters> params_for_testing_;
110 110
111 DISALLOW_COPY_AND_ASSIGN(AudioRecorder); 111 DISALLOW_COPY_AND_ASSIGN(AudioRecorderImpl);
112 }; 112 };
113 113
114 } // namespace copresence 114 } // namespace copresence
115 115
116 #endif // COMPONENTS_COPRESENCE_MEDIUMS_AUDIO_AUDIO_RECORDER_H_ 116 #endif // COMPONENTS_COPRESENCE_MEDIUMS_AUDIO_AUDIO_RECORDER_IMPL_H_
OLDNEW
« no previous file with comments | « components/copresence/mediums/audio/audio_recorder.cc ('k') | components/copresence/mediums/audio/audio_recorder_impl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698