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

Side by Side Diff: media/audio/sounds/wav_audio_handler.h

Issue 1453233002: Improve input handling for WaveAudioHandler. (Closed) Base URL: https://chromium.googlesource.com/chromium/src@master
Patch Set: More comments, more test cases. Created 5 years, 1 month 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 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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_SOUNDS_WAV_AUDIO_HANDLER_H_ 5 #ifndef MEDIA_AUDIO_SOUNDS_WAV_AUDIO_HANDLER_H_
6 #define MEDIA_AUDIO_SOUNDS_WAV_AUDIO_HANDLER_H_ 6 #define MEDIA_AUDIO_SOUNDS_WAV_AUDIO_HANDLER_H_
7 7
8 #include "base/macros.h"
9 #include "base/memory/scoped_ptr.h"
8 #include "base/strings/string_piece.h" 10 #include "base/strings/string_piece.h"
9 #include "base/time/time.h" 11 #include "base/time/time.h"
10 #include "media/base/media_export.h" 12 #include "media/base/media_export.h"
11 13
12 namespace media { 14 namespace media {
13 15
14 class AudioBus; 16 class AudioBus;
15 17
16 // This class provides the input from wav file format. See 18 // This class provides the input from wav file format. See
17 // https://ccrma.stanford.edu/courses/422/projects/WaveFormat/ 19 // https://ccrma.stanford.edu/courses/422/projects/WaveFormat/
18 class MEDIA_EXPORT WavAudioHandler { 20 class MEDIA_EXPORT WavAudioHandler {
19 public: 21 public:
20 explicit WavAudioHandler(const base::StringPiece& wav_data);
21 virtual ~WavAudioHandler(); 22 virtual ~WavAudioHandler();
22 23
24 // Create a WavAudioHandler using |wav_data|. If |wav_data| cannot be parsed
25 // correctly, the returned scoped_ptr will be null.
26 static scoped_ptr<WavAudioHandler> Create(const base::StringPiece& wav_data);
27
23 // Returns true when cursor points to the end of the track. 28 // Returns true when cursor points to the end of the track.
24 bool AtEnd(size_t cursor) const; 29 bool AtEnd(size_t cursor) const;
25 30
26 // Copies the audio data to |bus| starting from the |cursor| and in 31 // Copies the audio data to |bus| starting from the |cursor| and in
27 // the case of success stores the number of written bytes in 32 // the case of success stores the number of written bytes in
28 // |bytes_written|. |bytes_written| should not be NULL. 33 // |bytes_written|. |bytes_written| should not be NULL. Returns false if the
34 // operation was unsuccessful. Returns true otherwise.
29 bool CopyTo(AudioBus* bus, size_t cursor, size_t* bytes_written) const; 35 bool CopyTo(AudioBus* bus, size_t cursor, size_t* bytes_written) const;
30 36
31 // Accessors. 37 // Accessors.
32 const base::StringPiece& data() const { return data_; } 38 const base::StringPiece& data() const { return data_; }
33 uint16_t num_channels() const { return num_channels_; } 39 uint16_t num_channels() const { return num_channels_; }
34 uint32_t sample_rate() const { return sample_rate_; } 40 uint32_t sample_rate() const { return sample_rate_; }
35 uint16_t bits_per_sample() const { return bits_per_sample_; } 41 uint16_t bits_per_sample() const { return bits_per_sample_; }
36 uint32_t total_frames() const { return total_frames_; } 42 uint32_t total_frames() const { return total_frames_; }
37 43
38 // Returns the duration of the entire audio chunk. 44 // Returns the duration of the entire audio chunk.
39 base::TimeDelta GetDuration() const; 45 base::TimeDelta GetDuration() const;
40 46
41 private: 47 private:
42 // Parses a chunk of wav format data. Returns the length of the chunk. 48 WavAudioHandler(const base::StringPiece& audio_data,
43 int ParseSubChunk(const base::StringPiece& data); 49 uint16_t num_channels,
44 50 uint32_t sample_rate,
45 // Parses the 'fmt' section chunk and stores |params_|. 51 uint16_t bits_per_sample);
46 bool ParseFmtChunk(const base::StringPiece& data);
47
48 // Parses the 'data' section chunk and stores |data_|.
49 bool ParseDataChunk(const base::StringPiece& data);
50 52
51 // Data part of the |wav_data_|. 53 // Data part of the |wav_data_|.
52 base::StringPiece data_; 54 const base::StringPiece data_;
55 const uint16_t num_channels_;
56 const uint32_t sample_rate_;
57 const uint16_t bits_per_sample_;
58 uint32_t total_frames_;
53 59
54 uint16_t num_channels_; 60 DISALLOW_COPY_AND_ASSIGN(WavAudioHandler);
55 uint32_t sample_rate_;
56 uint16_t bits_per_sample_;
57 uint32_t total_frames_;
58 }; 61 };
59 62
60 } // namespace media 63 } // namespace media
61 64
62 #endif // MEDIA_AUDIO_SOUNDS_WAV_AUDIO_HANDLER_H_ 65 #endif // MEDIA_AUDIO_SOUNDS_WAV_AUDIO_HANDLER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698