/*
 * Copyright (c) 2002, 2015, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Oracle designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Oracle in the LICENSE file that accompanied this code.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */

package com.sun.media.sound;

import javax.sound.sampled.Mixer;
import javax.sound.sampled.spi.MixerProvider;

DirectAudioDevice provider.
Author:Florian Bomers
/** * DirectAudioDevice provider. * * @author Florian Bomers */
public final class DirectAudioDeviceProvider extends MixerProvider {
Set of info objects for all port input devices on the system.
/** * Set of info objects for all port input devices on the system. */
private static DirectAudioDeviceInfo[] infos;
Set of all port input devices on the system.
/** * Set of all port input devices on the system. */
private static DirectAudioDevice[] devices; static { // initialize Platform.initialize(); }
Required public no-arg constructor.
/** * Required public no-arg constructor. */
public DirectAudioDeviceProvider() { synchronized (DirectAudioDeviceProvider.class) { if (Platform.isDirectAudioEnabled()) { init(); } else { infos = new DirectAudioDeviceInfo[0]; devices = new DirectAudioDevice[0]; } } } private static void init() { // get the number of input devices int numDevices = nGetNumDevices(); if (infos == null || infos.length != numDevices) { if (Printer.trace) Printer.trace("DirectAudioDeviceProvider: init()"); // initialize the arrays infos = new DirectAudioDeviceInfo[numDevices]; devices = new DirectAudioDevice[numDevices]; // fill in the info objects now. for (int i = 0; i < infos.length; i++) { infos[i] = nNewDirectAudioDeviceInfo(i); } if (Printer.trace) Printer.trace("DirectAudioDeviceProvider: init(): found numDevices: " + numDevices); } } @Override public Mixer.Info[] getMixerInfo() { synchronized (DirectAudioDeviceProvider.class) { Mixer.Info[] localArray = new Mixer.Info[infos.length]; System.arraycopy(infos, 0, localArray, 0, infos.length); return localArray; } } @Override public Mixer getMixer(Mixer.Info info) { synchronized (DirectAudioDeviceProvider.class) { // if the default device is asked, we provide the mixer // with SourceDataLine's if (info == null) { for (int i = 0; i < infos.length; i++) { Mixer mixer = getDevice(infos[i]); if (mixer.getSourceLineInfo().length > 0) { return mixer; } } } // otherwise get the first mixer that matches // the requested info object for (int i = 0; i < infos.length; i++) { if (infos[i].equals(info)) { return getDevice(infos[i]); } } } throw new IllegalArgumentException( String.format("Mixer %s not supported by this provider", info)); } private static Mixer getDevice(DirectAudioDeviceInfo info) { int index = info.getIndex(); if (devices[index] == null) { devices[index] = new DirectAudioDevice(info); } return devices[index]; }
Info class for DirectAudioDevices. Adds an index value and a string for making native references to a particular device. This constructor is called from native.
/** * Info class for DirectAudioDevices. Adds an index value and a string for * making native references to a particular device. * This constructor is called from native. */
static final class DirectAudioDeviceInfo extends Mixer.Info { private final int index; private final int maxSimulLines; // For ALSA, the deviceID contains the encoded card index, device index, and sub-device-index private final int deviceID; private DirectAudioDeviceInfo(int index, int deviceID, int maxSimulLines, String name, String vendor, String description, String version) { super(name, vendor, "Direct Audio Device: "+description, version); this.index = index; this.maxSimulLines = maxSimulLines; this.deviceID = deviceID; } int getIndex() { return index; } int getMaxSimulLines() { return maxSimulLines; } int getDeviceID() { return deviceID; } } // class DirectAudioDeviceInfo private static native int nGetNumDevices(); // index: [0..nGetNumDevices()-1] private static native DirectAudioDeviceInfo nNewDirectAudioDeviceInfo(int deviceIndex); }