1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style license that can be 3 // found in the LICENSE file. 4 5 // The <code>chrome.audio</code> API is provided to allow users to 6 // get information about and control the audio devices attached to the 7 // system. This API is currently only implemented for ChromeOS. 8 namespace audio { 9 10 dictionary OutputDeviceInfo { 11 // The unique identifier of the audio output device. 12 DOMString id; 13 // The user-friendly name (e.g. "Bose Amplifier"). 14 DOMString name; 15 // True if this is the current active device. 16 boolean isActive; 17 // True if this is muted. 18 boolean isMuted; 19 // The output volume ranging from 0.0 to 1.0. 20 double volume; 21 }; 22 23 dictionary InputDeviceInfo { 24 // The unique identifier of the audio input device. 25 DOMString id; 26 // The user-friendly name (e.g. "USB Microphone"). 27 DOMString name; 28 // True if this is the current active device. 29 boolean isActive; 30 // True if this is muted. 31 boolean isMuted; 32 // The input gain ranging from 0.0 to 1.0. 33 double gain; 34 }; 35 36 dictionary DeviceProperties { 37 // True if this is muted. 38 boolean isMuted; 39 // If this is an output device then this field indicates the output volume. 40 // If this is an input device then this field is ignored. 41 double? volume; 42 // If this is an input device then this field indicates the input gain. 43 // If this is an output device then this field is ignored. 44 double? gain; 45 }; 46 47 callback GetInfoCallback = void(OutputDeviceInfo[] outputInfo, 48 InputDeviceInfo[] inputInfo); 49 callback SetActiveDevicesCallback = void(); 50 callback SetPropertiesCallback = void(); 51 52 interface Functions { 53 // Get the information of all audio output and input devices. 54 static void getInfo(GetInfoCallback callback); 55 56 // Select a subset of audio devices as active. 57 static void setActiveDevices(DOMString[] ids, 58 SetActiveDevicesCallback callback); 59 60 // Sets the properties for the input or output device. 61 static void setProperties(DOMString id, 62 DeviceProperties properties, 63 SetPropertiesCallback callback); 64 }; 65 66 interface Events { 67 // Fired when anything changes to the audio device configuration. 68 // TODO(hshi): as suggested by mpcomplete this should pass down the same 69 // data as GetInfoCallback. Implement this once we have getInfo working. 70 static void onDeviceChanged(); 71 }; 72 }; 73