// ----------------------------------------- // SoundScribe (TM) and related software. // // Copyright (C) 2007-2011 Vannatech // http://www.vannatech.com // All rights reserved. // // This source code is subject to the MIT License. // http://www.opensource.org/licenses/mit-license.php // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. // ----------------------------------------- using System; using System.Runtime.InteropServices; namespace Vannatech.CoreAudio.Interfaces { /// /// Enables a client to control and monitor the volume levels for all of the channels in an audio stream. /// /// /// MSDN Reference: http://msdn.microsoft.com/en-us/library/dd370977.aspx /// public partial interface IAudioStreamVolume { /// /// Retrieves the number of channels contained in the audio stream. /// /// Receives the channel count. /// An HRESULT code indicating whether the operation succeeded of failed. [PreserveSig] int GetChannelCount( [Out] [MarshalAs(UnmanagedType.U4)] out UInt32 count); /// /// Sets the volume level for the specified channel in the audio stream. /// /// The zero-based index of the channel. /// The new volume level expressed as a normalized value between 0.0 and 1.0. /// An HRESULT code indicating whether the operation succeeded of failed. [PreserveSig] int SetChannelVolume( [In] [MarshalAs(UnmanagedType.U4)] UInt32 index, [In] [MarshalAs(UnmanagedType.R4)] float level); /// /// Retrieves the volume level for the specified channel in the audio stream. /// /// The zero-based channel index. /// Receives the volume level expressed as a normalized value between 0.0 and 1.0. /// An HRESULT code indicating whether the operation succeeded of failed. [PreserveSig] int GetChannelVolume( [In] [MarshalAs(UnmanagedType.U4)] UInt32 index, [Out] [MarshalAs(UnmanagedType.R4)] out float level); /// /// Sets the individual volume levels for all the channels in the audio stream. /// /// The number of channels in the audio stream. This must match the volume level array length. /// The new volume levels for each channel in the audio stream, expressed as normalized values between 0.0 and 1.0. /// An HRESULT code indicating whether the operation succeeded of failed. [PreserveSig] int SetAllVolumes( [In] [MarshalAs(UnmanagedType.U4)] UInt32 count, [In] [MarshalAs(UnmanagedType.LPArray, ArraySubType = UnmanagedType.R4)] float[] levels); /// /// Retrieves the volume levels for all the channels in the audio stream. /// /// The number of elements in the volumes array. /// Receives an array of volume levels for the channels in the audio stream. /// An HRESULT code indicating whether the operation succeeded of failed. [PreserveSig] int GetAllVolumes( [In] [MarshalAs(UnmanagedType.U4)] UInt32 length, [In, Out] [MarshalAs(UnmanagedType.LPArray, ArraySubType = UnmanagedType.R4)] float[] volumes); } }