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

Unified Diff: media/audio/audio_parameters.h

Issue 1907973003: media: Move audio_parameters and audio_point to media/base/ (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebase 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « media/audio/audio_output_resampler.h ('k') | media/audio/audio_parameters.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: media/audio/audio_parameters.h
diff --git a/media/audio/audio_parameters.h b/media/audio/audio_parameters.h
deleted file mode 100644
index d7d730b91497b1a6bd145961c5ce7b6e0ec6f2c1..0000000000000000000000000000000000000000
--- a/media/audio/audio_parameters.h
+++ /dev/null
@@ -1,222 +0,0 @@
-// Copyright (c) 2012 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#ifndef MEDIA_AUDIO_AUDIO_PARAMETERS_H_
-#define MEDIA_AUDIO_AUDIO_PARAMETERS_H_
-
-#include <stdint.h>
-#include <string>
-
-#include "base/compiler_specific.h"
-#include "base/time/time.h"
-#include "build/build_config.h"
-#include "media/audio/point.h"
-#include "media/base/audio_bus.h"
-#include "media/base/channel_layout.h"
-#include "media/base/media_export.h"
-
-namespace media {
-
-// Use a struct-in-struct approach to ensure that we can calculate the required
-// size as sizeof(Audio{Input,Output}BufferParameters) + #(bytes in audio
-// buffer) without using packing. Also align Audio{Input,Output}BufferParameters
-// instead of in Audio{Input,Output}Buffer to be able to calculate size like so.
-// Use a macro for the alignment value that's the same as
-// AudioBus::kChannelAlignment, since MSVC doesn't accept the latter to be used.
-#if defined(OS_WIN)
-#pragma warning(push)
-#pragma warning(disable: 4324) // Disable warning for added padding.
-#endif
-#define PARAMETERS_ALIGNMENT 16
-static_assert(AudioBus::kChannelAlignment == PARAMETERS_ALIGNMENT,
- "Audio buffer parameters struct alignment not same as AudioBus");
-struct MEDIA_EXPORT ALIGNAS(PARAMETERS_ALIGNMENT) AudioInputBufferParameters {
- double volume;
- uint32_t size;
- uint32_t hardware_delay_bytes;
- uint32_t id;
- bool key_pressed;
-};
-struct MEDIA_EXPORT ALIGNAS(PARAMETERS_ALIGNMENT) AudioOutputBufferParameters {
- uint32_t frames_skipped;
-};
-#undef PARAMETERS_ALIGNMENT
-#if defined(OS_WIN)
-#pragma warning(pop)
-#endif
-
-static_assert(sizeof(AudioInputBufferParameters) %
- AudioBus::kChannelAlignment ==
- 0,
- "AudioInputBufferParameters not aligned");
-static_assert(sizeof(AudioOutputBufferParameters) %
- AudioBus::kChannelAlignment ==
- 0,
- "AudioOutputBufferParameters not aligned");
-
-struct MEDIA_EXPORT AudioInputBuffer {
- AudioInputBufferParameters params;
- int8_t audio[1];
-};
-struct MEDIA_EXPORT AudioOutputBuffer {
- AudioOutputBufferParameters params;
- int8_t audio[1];
-};
-
-class MEDIA_EXPORT AudioParameters {
- public:
- // TODO(miu): Rename this enum to something that correctly reflects its
- // semantics, such as "TransportScheme."
- enum Format {
- AUDIO_PCM_LINEAR = 0, // PCM is 'raw' amplitude samples.
- AUDIO_PCM_LOW_LATENCY, // Linear PCM, low latency requested.
- AUDIO_FAKE, // Creates a fake AudioOutputStream object.
- AUDIO_FORMAT_LAST = AUDIO_FAKE, // Only used for validation of format.
- };
-
- enum {
- // Telephone quality sample rate, mostly for speech-only audio.
- kTelephoneSampleRate = 8000,
- // CD sampling rate is 44.1 KHz or conveniently 2x2x3x3x5x5x7x7.
- kAudioCDSampleRate = 44100,
- };
-
- // Bitmasks to determine whether certain platform (typically hardware) audio
- // effects should be enabled.
- enum PlatformEffectsMask {
- NO_EFFECTS = 0x0,
- ECHO_CANCELLER = 0x1,
- DUCKING = 0x2, // Enables ducking if the OS supports it.
- KEYBOARD_MIC = 0x4,
- HOTWORD = 0x8,
- };
-
- AudioParameters();
- AudioParameters(Format format,
- ChannelLayout channel_layout,
- int sample_rate,
- int bits_per_sample,
- int frames_per_buffer);
-
- ~AudioParameters();
-
- // Re-initializes all members.
- void Reset(Format format,
- ChannelLayout channel_layout,
- int sample_rate,
- int bits_per_sample,
- int frames_per_buffer);
-
- // Checks that all values are in the expected range. All limits are specified
- // in media::Limits.
- bool IsValid() const;
-
- // Returns a human-readable string describing |*this|. For debugging & test
- // output only.
- std::string AsHumanReadableString() const;
-
- // Returns size of audio buffer in bytes.
- int GetBytesPerBuffer() const;
-
- // Returns the number of bytes representing one second of audio.
- int GetBytesPerSecond() const;
-
- // Returns the number of bytes representing a frame of audio.
- int GetBytesPerFrame() const;
-
- // Returns the number of microseconds per frame of audio. Intentionally
- // reported as a double to surface of partial microseconds per frame, which
- // is common for many sample rates. Failing to account for these nanoseconds
- // can lead to audio/video sync drift.
- double GetMicrosecondsPerFrame() const;
-
- // Returns the duration of this buffer as calculated from frames_per_buffer()
- // and sample_rate().
- base::TimeDelta GetBufferDuration() const;
-
- // Comparison with other AudioParams.
- bool Equals(const AudioParameters& other) const;
-
- void set_format(Format format) { format_ = format; }
- Format format() const { return format_; }
-
- // A setter for channel_layout_ is intentionally excluded.
- ChannelLayout channel_layout() const { return channel_layout_; }
-
- // The number of channels is usually computed from channel_layout_. Setting
- // this explictly is only required with CHANNEL_LAYOUT_DISCRETE.
- void set_channels_for_discrete(int channels) {
- DCHECK(channel_layout_ == CHANNEL_LAYOUT_DISCRETE ||
- channels == ChannelLayoutToChannelCount(channel_layout_));
- channels_ = channels;
- }
- int channels() const { return channels_; }
-
- void set_sample_rate(int sample_rate) { sample_rate_ = sample_rate; }
- int sample_rate() const { return sample_rate_; }
-
- void set_bits_per_sample(int bits_per_sample) {
- bits_per_sample_ = bits_per_sample;
- }
- int bits_per_sample() const { return bits_per_sample_; }
-
- void set_frames_per_buffer(int frames_per_buffer) {
- frames_per_buffer_ = frames_per_buffer;
- }
- int frames_per_buffer() const { return frames_per_buffer_; }
-
- void set_effects(int effects) { effects_ = effects; }
- int effects() const { return effects_; }
-
- void set_mic_positions(const std::vector<Point>& mic_positions) {
- mic_positions_ = mic_positions;
- }
- const std::vector<Point>& mic_positions() const { return mic_positions_; }
-
- AudioParameters(const AudioParameters&);
- AudioParameters& operator=(const AudioParameters&);
-
- // Creates reasonable dummy parameters in case no device is available.
- static AudioParameters UnavailableDeviceParams();
-
- private:
- Format format_; // Format of the stream.
- ChannelLayout channel_layout_; // Order of surround sound channels.
- int channels_; // Number of channels. Value set based on
- // |channel_layout|.
- int sample_rate_; // Sampling frequency/rate.
- int bits_per_sample_; // Number of bits per sample.
- int frames_per_buffer_; // Number of frames in a buffer.
- int effects_; // Bitmask using PlatformEffectsMask.
-
- // Microphone positions using Cartesian coordinates:
- // x: the horizontal dimension, with positive to the right from the camera's
- // perspective.
- // y: the depth dimension, with positive forward from the camera's
- // perspective.
- // z: the vertical dimension, with positive upwards.
- //
- // Usually, the center of the microphone array will be treated as the origin
- // (often the position of the camera).
- //
- // An empty vector indicates unknown positions.
- std::vector<Point> mic_positions_;
-};
-
-// Comparison is useful when AudioParameters is used with std structures.
-inline bool operator<(const AudioParameters& a, const AudioParameters& b) {
- if (a.format() != b.format())
- return a.format() < b.format();
- if (a.channels() != b.channels())
- return a.channels() < b.channels();
- if (a.sample_rate() != b.sample_rate())
- return a.sample_rate() < b.sample_rate();
- if (a.bits_per_sample() != b.bits_per_sample())
- return a.bits_per_sample() < b.bits_per_sample();
- return a.frames_per_buffer() < b.frames_per_buffer();
-}
-
-} // namespace media
-
-#endif // MEDIA_AUDIO_AUDIO_PARAMETERS_H_
« no previous file with comments | « media/audio/audio_output_resampler.h ('k') | media/audio/audio_parameters.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698