OLD | NEW |
---|---|
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 MEDIA_AUDIO_AUDIO_FILE_WRITER_H_ | 5 #ifndef MEDIA_AUDIO_AUDIO_FILE_WRITER_H_ |
6 #define MEDIA_AUDIO_AUDIO_FILE_WRITER_H_ | 6 #define MEDIA_AUDIO_AUDIO_FILE_WRITER_H_ |
7 | 7 |
8 #include <memory> | 8 #include <memory> |
9 | 9 |
10 #include "base/callback_forward.h" | |
11 | |
10 namespace base { | 12 namespace base { |
11 class FilePath; | 13 class FilePath; |
12 } | 14 } |
13 | 15 |
14 namespace media { | 16 namespace media { |
15 | 17 |
16 class AudioBus; | 18 class AudioBus; |
19 class AudioParameters; | |
17 | 20 |
18 // A writer interface used for writing audio data to file for debugging | 21 // A writer interface used for writing audio data to file for debugging |
19 // purposes. | 22 // purposes. |
20 class AudioFileWriter { | 23 class AudioFileWriter { |
21 public: | 24 public: |
22 virtual ~AudioFileWriter() {} | 25 virtual ~AudioFileWriter() {} |
23 | 26 |
24 // Must be called before calling Write() for the first time after creation or | 27 // Must be called before calling Write() for the first time after creation or |
25 // Stop() call. Can be called on any sequence; Write() and Stop() must be | 28 // Stop() call. Can be called on any sequence; Write() and Stop() must be |
26 // called on the same sequence as Start(). | 29 // called on the same sequence as Start(). |
27 virtual void Start(const base::FilePath& file) = 0; | 30 virtual void Start(const base::FilePath& file) = 0; |
28 | 31 |
29 // Must be called to finish recording. Each call to Start() requires a call to | 32 // Must be called to finish recording. Each call to Start() requires a call to |
30 // Stop(). Will be automatically called on destruction. | 33 // Stop(). Will be automatically called on destruction. |
31 virtual void Stop() = 0; | 34 virtual void Stop() = 0; |
32 | 35 |
33 // Write |data| to file. | 36 // Write |data| to file. |
34 virtual void Write(std::unique_ptr<AudioBus> data) = 0; | 37 virtual void Write(std::unique_ptr<AudioBus> data) = 0; |
35 | 38 |
36 // Returns true if Write() call scheduled at this point will most likely write | 39 // Returns true if Write() call scheduled at this point will most likely write |
37 // data to the file, and false if it most likely will be a no-op. The result | 40 // data to the file, and false if it most likely will be a no-op. The result |
38 // may be ambigulous if Start() or Stop() is executed at the moment. Can be | 41 // may be ambigulous if Start() or Stop() is executed at the moment. Can be |
39 // called from any sequence. | 42 // called from any sequence. |
40 virtual bool WillWrite() = 0; | 43 virtual bool WillWrite() = 0; |
44 | |
45 // Gets the extension for the file type the as a string, for example "wav". | |
46 // Can be called before calling Start() to add the appropriate extension to | |
47 // the filename. | |
48 virtual std::string GetExtension() = 0; | |
41 }; | 49 }; |
42 | 50 |
43 } // namespace media | 51 // Used for creating an AudioFileWriter. |
52 using CreateAudioFileWriterCallback = | |
53 base::RepeatingCallback<std::unique_ptr<AudioFileWriter>( | |
o1ka
2017/02/09 13:04:03
Declare in within AudioFileWriter scope and call i
Henrik Grunell
2017/02/10 09:00:56
Sounds good, done.
| |
54 const AudioParameters&)>; | |
55 | |
56 } // namspace media | |
44 | 57 |
45 #endif // MEDIA_AUDIO_AUDIO_FILE_WRITER_H_ | 58 #endif // MEDIA_AUDIO_AUDIO_FILE_WRITER_H_ |
OLD | NEW |