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

Side by Side Diff: media/audio/audio_parameters.cc

Issue 1304973005: Refactor AudioParameters member setting. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: More cross-platform. Created 5 years, 3 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 (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 #include "media/audio/audio_parameters.h" 5 #include "media/audio/audio_parameters.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "media/base/limits.h" 8 #include "media/base/limits.h"
9 9
10 namespace media { 10 namespace media {
11 11
12 AudioParameters::AudioParameters() 12 AudioParameters::AudioParameters()
13 : format_(AUDIO_PCM_LINEAR), 13 : AudioParameters(AUDIO_PCM_LINEAR, CHANNEL_LAYOUT_NONE, 0, 0, 0) {}
14 channel_layout_(CHANNEL_LAYOUT_NONE), 14
15 sample_rate_(0), 15 AudioParameters::AudioParameters(Format format,
16 bits_per_sample_(0), 16 ChannelLayout channel_layout,
17 frames_per_buffer_(0), 17 int sample_rate,
18 channels_(0), 18 int bits_per_sample,
19 effects_(NO_EFFECTS) { 19 int frames_per_buffer) {
20 Reset(format, channel_layout, sample_rate, bits_per_sample,
21 frames_per_buffer);
20 } 22 }
21 23
22 AudioParameters::AudioParameters(Format format, ChannelLayout channel_layout, 24 void AudioParameters::Reset(Format format,
23 int sample_rate, int bits_per_sample, 25 ChannelLayout channel_layout,
24 int frames_per_buffer) 26 int sample_rate,
25 : format_(format), 27 int bits_per_sample,
26 channel_layout_(channel_layout), 28 int frames_per_buffer) {
27 sample_rate_(sample_rate),
28 bits_per_sample_(bits_per_sample),
29 frames_per_buffer_(frames_per_buffer),
30 channels_(ChannelLayoutToChannelCount(channel_layout)),
31 effects_(NO_EFFECTS) {
32 }
33
34 AudioParameters::AudioParameters(Format format, ChannelLayout channel_layout,
35 int sample_rate, int bits_per_sample,
36 int frames_per_buffer, int effects)
37 : format_(format),
38 channel_layout_(channel_layout),
39 sample_rate_(sample_rate),
40 bits_per_sample_(bits_per_sample),
41 frames_per_buffer_(frames_per_buffer),
42 channels_(ChannelLayoutToChannelCount(channel_layout)),
43 effects_(effects) {
44 }
45
46 AudioParameters::AudioParameters(Format format, ChannelLayout channel_layout,
47 int channels, int sample_rate,
48 int bits_per_sample, int frames_per_buffer,
49 int effects)
50 : format_(format),
51 channel_layout_(channel_layout),
52 sample_rate_(sample_rate),
53 bits_per_sample_(bits_per_sample),
54 frames_per_buffer_(frames_per_buffer),
55 channels_(channels),
56 effects_(effects) {
57 }
58
59 void AudioParameters::Reset(Format format, ChannelLayout channel_layout,
60 int channels, int sample_rate,
61 int bits_per_sample, int frames_per_buffer) {
62 format_ = format; 29 format_ = format;
63 channel_layout_ = channel_layout; 30 channel_layout_ = channel_layout;
64 channels_ = channels; 31 channels_ = ChannelLayoutToChannelCount(channel_layout);
65 sample_rate_ = sample_rate; 32 sample_rate_ = sample_rate;
66 bits_per_sample_ = bits_per_sample; 33 bits_per_sample_ = bits_per_sample;
67 frames_per_buffer_ = frames_per_buffer; 34 frames_per_buffer_ = frames_per_buffer;
35 effects_ = NO_EFFECTS;
68 } 36 }
69 37
70 bool AudioParameters::IsValid() const { 38 bool AudioParameters::IsValid() const {
71 return (channels_ > 0) && (channels_ <= media::limits::kMaxChannels) && 39 return (channels_ > 0) && (channels_ <= media::limits::kMaxChannels) &&
72 (channel_layout_ > CHANNEL_LAYOUT_UNSUPPORTED) && 40 (channel_layout_ > CHANNEL_LAYOUT_UNSUPPORTED) &&
73 (sample_rate_ >= media::limits::kMinSampleRate) && 41 (sample_rate_ >= media::limits::kMinSampleRate) &&
74 (sample_rate_ <= media::limits::kMaxSampleRate) && 42 (sample_rate_ <= media::limits::kMaxSampleRate) &&
75 (bits_per_sample_ > 0) && 43 (bits_per_sample_ > 0) &&
76 (bits_per_sample_ <= media::limits::kMaxBitsPerSample) && 44 (bits_per_sample_ <= media::limits::kMaxBitsPerSample) &&
77 (frames_per_buffer_ > 0) && 45 (frames_per_buffer_ > 0) &&
78 (frames_per_buffer_ <= media::limits::kMaxSamplesPerPacket) && 46 (frames_per_buffer_ <= media::limits::kMaxSamplesPerPacket) &&
79 (channel_layout_ == CHANNEL_LAYOUT_DISCRETE || 47 (channel_layout_ == CHANNEL_LAYOUT_DISCRETE ||
80 channels_ == ChannelLayoutToChannelCount(channel_layout_)); 48 channels_ == ChannelLayoutToChannelCount(channel_layout_));
81 } 49 }
82 50
83 std::string AudioParameters::AsHumanReadableString() const { 51 std::string AudioParameters::AsHumanReadableString() const {
84 std::ostringstream s; 52 std::ostringstream s;
85 s << "format: " << format() 53 s << "format: " << format() << " channel_layout: " << channel_layout()
86 << " channels: " << channels() 54 << " channels: " << channels() << " sample_rate: " << sample_rate()
87 << " channel_layout: " << channel_layout()
88 << " sample_rate: " << sample_rate()
89 << " bits_per_sample: " << bits_per_sample() 55 << " bits_per_sample: " << bits_per_sample()
90 << " frames_per_buffer: " << frames_per_buffer(); 56 << " frames_per_buffer: " << frames_per_buffer()
57 << " effects: " << effects();
91 return s.str(); 58 return s.str();
92 } 59 }
93 60
94 int AudioParameters::GetBytesPerBuffer() const { 61 int AudioParameters::GetBytesPerBuffer() const {
95 return frames_per_buffer_ * GetBytesPerFrame(); 62 return frames_per_buffer_ * GetBytesPerFrame();
96 } 63 }
97 64
98 int AudioParameters::GetBytesPerSecond() const { 65 int AudioParameters::GetBytesPerSecond() const {
99 return sample_rate_ * GetBytesPerFrame(); 66 return sample_rate_ * GetBytesPerFrame();
100 } 67 }
(...skipping 12 matching lines...) Expand all
113 return format_ == other.format() && 80 return format_ == other.format() &&
114 sample_rate_ == other.sample_rate() && 81 sample_rate_ == other.sample_rate() &&
115 channel_layout_ == other.channel_layout() && 82 channel_layout_ == other.channel_layout() &&
116 channels_ == other.channels() && 83 channels_ == other.channels() &&
117 bits_per_sample_ == other.bits_per_sample() && 84 bits_per_sample_ == other.bits_per_sample() &&
118 frames_per_buffer_ == other.frames_per_buffer() && 85 frames_per_buffer_ == other.frames_per_buffer() &&
119 effects_ == other.effects(); 86 effects_ == other.effects();
120 } 87 }
121 88
122 } // namespace media 89 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698