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

Side by Side Diff: media/audio/audio_util.h

Issue 9655018: Make AudioParameters a class instead of a struct (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 8 years, 9 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 | Annotate | Revision Log
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 #ifndef MEDIA_AUDIO_AUDIO_UTIL_H_ 5 #ifndef MEDIA_AUDIO_AUDIO_UTIL_H_
6 #define MEDIA_AUDIO_AUDIO_UTIL_H_ 6 #define MEDIA_AUDIO_AUDIO_UTIL_H_
7 7
8 #include <string> 8 #include <string>
9 #include <vector> 9 #include <vector>
10 10
11 #include "base/basictypes.h" 11 #include "base/basictypes.h"
12 #include "media/base/channel_layout.h"
12 #include "media/base/media_export.h" 13 #include "media/base/media_export.h"
13 14
14 struct AudioParameters;
15
16 namespace base { 15 namespace base {
17 class SharedMemory; 16 class SharedMemory;
18 } 17 }
19 18
20 namespace media { 19 namespace media {
21 20
22 // For all audio functions 3 audio formats are supported: 21 // For all audio functions 3 audio formats are supported:
23 // 8 bits unsigned 0 to 255. 22 // 8 bits unsigned 0 to 255.
24 // 16 bit signed (little endian). 23 // 16 bit signed (little endian).
25 // 32 bit signed (little endian) 24 // 32 bit signed (little endian)
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after
76 // floating-point audio contained in |source| to the int16 |destination|. 75 // floating-point audio contained in |source| to the int16 |destination|.
77 // The floating-point data is in a canonical range of -1.0 -> +1.0. 76 // The floating-point data is in a canonical range of -1.0 -> +1.0.
78 // The size of the |source| vector determines the number of channels. 77 // The size of the |source| vector determines the number of channels.
79 // The |destination| buffer is assumed to be large enough to hold the 78 // The |destination| buffer is assumed to be large enough to hold the
80 // result. Thus it must be at least size: number_of_frames * source.size() 79 // result. Thus it must be at least size: number_of_frames * source.size()
81 MEDIA_EXPORT void InterleaveFloatToInt16(const std::vector<float*>& source, 80 MEDIA_EXPORT void InterleaveFloatToInt16(const std::vector<float*>& source,
82 int16* destination, 81 int16* destination,
83 size_t number_of_frames); 82 size_t number_of_frames);
84 83
85 // Returns the default audio output hardware sample-rate. 84 // Returns the default audio output hardware sample-rate.
86 MEDIA_EXPORT double GetAudioHardwareSampleRate(); 85 MEDIA_EXPORT int GetAudioHardwareSampleRate();
87 86
88 // Returns the audio input hardware sample-rate for the specified device. 87 // Returns the audio input hardware sample-rate for the specified device.
89 MEDIA_EXPORT double GetAudioInputHardwareSampleRate( 88 MEDIA_EXPORT int GetAudioInputHardwareSampleRate(
90 const std::string& device_id); 89 const std::string& device_id);
91 90
92 // Returns the optimal low-latency buffer size for the audio hardware. 91 // Returns the optimal low-latency buffer size for the audio hardware.
93 // This is the smallest buffer size the system can comfortably render 92 // This is the smallest buffer size the system can comfortably render
94 // at without glitches. The buffer size is in sample-frames. 93 // at without glitches. The buffer size is in sample-frames.
95 MEDIA_EXPORT size_t GetAudioHardwareBufferSize(); 94 MEDIA_EXPORT size_t GetAudioHardwareBufferSize();
96 95
97 // Returns the number of channels for the specified audio input device. 96 // Returns the channel layout for the specified audio input device.
98 MEDIA_EXPORT uint32 GetAudioInputHardwareChannelCount( 97 MEDIA_EXPORT ChannelLayout GetAudioInputHardwareChannelLayout(
99 const std::string& device_id); 98 const std::string& device_id);
100 99
101 // Functions that handle data buffer passed between processes in the shared 100 // Functions that handle data buffer passed between processes in the shared
102 // memory. Called on both IPC sides. 101 // memory. Called on both IPC sides.
103 102
104 MEDIA_EXPORT uint32 TotalSharedMemorySizeInBytes(uint32 packet_size); 103 MEDIA_EXPORT uint32 TotalSharedMemorySizeInBytes(uint32 packet_size);
105 MEDIA_EXPORT uint32 PacketSizeSizeInBytes(uint32 shared_memory_created_size); 104 MEDIA_EXPORT uint32 PacketSizeSizeInBytes(uint32 shared_memory_created_size);
106 MEDIA_EXPORT uint32 GetActualDataSizeInBytes(base::SharedMemory* shared_memory, 105 MEDIA_EXPORT uint32 GetActualDataSizeInBytes(base::SharedMemory* shared_memory,
107 uint32 shared_memory_size); 106 uint32 shared_memory_size);
108 MEDIA_EXPORT void SetActualDataSizeInBytes(base::SharedMemory* shared_memory, 107 MEDIA_EXPORT void SetActualDataSizeInBytes(base::SharedMemory* shared_memory,
109 uint32 shared_memory_size, 108 uint32 shared_memory_size,
110 uint32 actual_data_size); 109 uint32 actual_data_size);
111 MEDIA_EXPORT void SetUnknownDataSize(base::SharedMemory* shared_memory, 110 MEDIA_EXPORT void SetUnknownDataSize(base::SharedMemory* shared_memory,
112 uint32 shared_memory_size); 111 uint32 shared_memory_size);
113 MEDIA_EXPORT bool IsUnknownDataSize(base::SharedMemory* shared_memory, 112 MEDIA_EXPORT bool IsUnknownDataSize(base::SharedMemory* shared_memory,
114 uint32 shared_memory_size); 113 uint32 shared_memory_size);
115 114
116 #if defined(OS_WIN) 115 #if defined(OS_WIN)
117 116
118 // Does Windows support WASAPI? We are checking in lot of places, and 117 // Does Windows support WASAPI? We are checking in lot of places, and
119 // sometimes check was written incorrectly, so move into separate function. 118 // sometimes check was written incorrectly, so move into separate function.
120 MEDIA_EXPORT bool IsWASAPISupported(); 119 MEDIA_EXPORT bool IsWASAPISupported();
121 120
122 #endif // defined(OS_WIN) 121 #endif // defined(OS_WIN)
123 122
124 } // namespace media 123 } // namespace media
125 124
126 #endif // MEDIA_AUDIO_AUDIO_UTIL_H_ 125 #endif // MEDIA_AUDIO_AUDIO_UTIL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698