// -----------------------------------------
// 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
{
///
/// Used to by the system to send notifications about stream attenuation changes.
///
///
/// MSDN Reference: http://msdn.microsoft.com/en-us/library/dd371006.aspx
///
public partial interface IAudioVolumeDuckNotification
{
///
/// Sends a notification about a pending system ducking event.
///
/// A string containing the session instance identifier of the communications session that raises the the auto-ducking event.
/// The number of active communications sessions.
/// An HRESULT code indicating whether the operation succeeded of failed.
[PreserveSig]
int OnVolumeDuckNotification(
[In] [MarshalAs(UnmanagedType.LPWStr)] string sessionId,
[In] UInt32 activeSessionCount);
///
/// Sends a notification about a pending system unducking event.
///
/// A string containing the session instance identifier of the terminating communications session that intiated the ducking.
/// An HRESULT code indicating whether the operation succeeded of failed.
[PreserveSig]
int OnVolumeUnduckNotification(
[In] [MarshalAs(UnmanagedType.LPWStr)] string sessionId);
}
}