MidiManager


public final class MidiManager
extends Object

java.lang.Object
   ↳ android.media.midi.MidiManager


This class is the public application interface to the MIDI service.
Requires the PackageManager#FEATURE_MIDI feature which can be detected using PackageManager.hasSystemFeature(String).

Summary

Nested classes

class MidiManager.DeviceCallback

Callback class used for clients to receive MIDI device added and removed notifications 

interface MidiManager.OnDeviceOpenedListener

Listener class used for receiving the results of MidiManager.openDevice(MidiDeviceInfo, OnDeviceOpenedListener, Handler) and MidiManager.openBluetoothDevice(BluetoothDevice, OnDeviceOpenedListener, Handler) 

Constants

int TRANSPORT_MIDI_BYTE_STREAM

Constant representing MIDI devices.

int TRANSPORT_UNIVERSAL_MIDI_PACKETS

Constant representing Universal MIDI devices.

Public methods

MidiDeviceInfo[] getDevices()

This method was deprecated in API level 33. Use getDevicesForTransport(int) instead.

Set<MidiDeviceInfo> getDevicesForTransport(int transport)

Gets a list of connected MIDI devices by transport.

void openBluetoothDevice(BluetoothDevice bluetoothDevice, MidiManager.OnDeviceOpenedListener listener, Handler handler)

Opens a Bluetooth MIDI device for reading and writing.

void openDevice(MidiDeviceInfo deviceInfo, MidiManager.OnDeviceOpenedListener listener, Handler handler)

Opens a MIDI device for reading and writing.

void registerDeviceCallback(int transport, Executor executor, MidiManager.DeviceCallback callback)

Registers a callback to receive notifications when MIDI devices are added and removed for a specific transport type.

void registerDeviceCallback(MidiManager.DeviceCallback callback, Handler handler)

This method was deprecated in API level 33. Use registerDeviceCallback(int, java.util.concurrent.Executor, android.media.midi.MidiManager.DeviceCallback) instead.

void unregisterDeviceCallback(MidiManager.DeviceCallback callback)

Unregisters a DeviceCallback.

Inherited methods

Object clone()

Creates and returns a copy of this object.

boolean equals(Object obj)

Indicates whether some other object is "equal to" this one.

void finalize()

Called by the garbage collector on an object when garbage collection determines that there are no more references to the object.

final Class<?> getClass()

Returns the runtime class of this Object.

int hashCode()

Returns a hash code value for the object.

final void notify()

Wakes up a single thread that is waiting on this object's monitor.

final void notifyAll()

Wakes up all threads that are waiting on this object's monitor.

String toString()

Returns a string representation of the object.

final void wait(long timeoutMillis, int nanos)

Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.

final void wait(long timeoutMillis)

Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.

final void wait()

Causes the current thread to wait until it is awakened, typically by being notified or interrupted.

Constants

TRANSPORT_MIDI_BYTE_STREAM

Added in API level 33
public static final int TRANSPORT_MIDI_BYTE_STREAM

Constant representing MIDI devices. These devices do NOT support Universal MIDI Packets by default. These support the original MIDI 1.0 byte stream. When communicating to a USB device, a raw byte stream will be padded for USB. Likewise, for a Bluetooth device, the raw bytes will be converted for Bluetooth. For virtual devices, the byte stream will be passed directly. If Universal MIDI Packets are needed, please use MIDI-CI.

Constant Value: 1 (0x00000001)

TRANSPORT_UNIVERSAL_MIDI_PACKETS

Added in API level 33
public static final int TRANSPORT_UNIVERSAL_MIDI_PACKETS

Constant representing Universal MIDI devices. These devices do support Universal MIDI Packets (UMP) by default. When sending data to these devices, please send UMP. Packets should always be a multiple of 4 bytes. UMP is defined in the USB MIDI 2.0 spec. Please read the standard for more info.

Constant Value: 2 (0x00000002)

Public methods

getDevices

Added in API level 23
Deprecated in API level 33
public MidiDeviceInfo[] getDevices ()

This method was deprecated in API level 33.
Use getDevicesForTransport(int) instead.

Gets a list of connected MIDI devices. This returns all devices that do not default to Universal MIDI Packets. To get those instead, please call getDevicesForTransport(int) instead.

Returns
MidiDeviceInfo[] an array of MIDI devices

getDevicesForTransport

Added in API level 33
public Set<MidiDeviceInfo> getDevicesForTransport (int transport)

Gets a list of connected MIDI devices by transport. TRANSPORT_MIDI_BYTE_STREAM is used for MIDI 1.0 and is the most common. For devices with built in Universal MIDI Packet support, use TRANSPORT_UNIVERSAL_MIDI_PACKETS instead.

Parameters
transport int: The transport to be used. This is either TRANSPORT_MIDI_BYTE_STREAM or TRANSPORT_UNIVERSAL_MIDI_PACKETS. Value is TRANSPORT_MIDI_BYTE_STREAM, or TRANSPORT_UNIVERSAL_MIDI_PACKETS

Returns
Set<MidiDeviceInfo> a collection of MIDI devices This value cannot be null.

openBluetoothDevice

Added in API level 23
public void openBluetoothDevice (BluetoothDevice bluetoothDevice, 
                MidiManager.OnDeviceOpenedListener listener, 
                Handler handler)

Opens a Bluetooth MIDI device for reading and writing. Bluetooth MIDI devices are only available after openBluetoothDevice() is called. Once that happens anywhere in the system, then the BLE-MIDI device will appear as just another MidiDevice to other apps. If the device opened using openBluetoothDevice() is closed, then it will no longer be available. To other apps, it will appear as if the BLE MidiDevice had been unplugged. If a MidiDevice is garbage collected then it will be closed automatically. If you want the BLE-MIDI device to remain available you should keep the object alive. You may close the device with MidiDevice.close().

Parameters
bluetoothDevice BluetoothDevice: a BluetoothDevice to open as a MIDI device

listener MidiManager.OnDeviceOpenedListener: a MidiManager.OnDeviceOpenedListener to be called to receive the result

handler Handler: the Handler that will be used for delivering the result. If handler is null, then the thread used for the listener is unspecified.

openDevice

Added in API level 23
public void openDevice (MidiDeviceInfo deviceInfo, 
                MidiManager.OnDeviceOpenedListener listener, 
                Handler handler)

Opens a MIDI device for reading and writing.

Parameters
deviceInfo MidiDeviceInfo: a MidiDeviceInfo to open

listener MidiManager.OnDeviceOpenedListener: a MidiManager.OnDeviceOpenedListener to be called to receive the result

handler Handler: the Handler that will be used for delivering the result. If handler is null, then the thread used for the listener is unspecified.

registerDeviceCallback

Added in API level 33
public void registerDeviceCallback (int transport, 
                Executor executor, 
                MidiManager.DeviceCallback callback)

Registers a callback to receive notifications when MIDI devices are added and removed for a specific transport type. The DeviceCallback.onDeviceStatusChanged method will be called immediately for any devices that have open ports. This allows applications to know which input ports are already in use and, therefore, unavailable. Applications should call getDevicesForTransport(int) before registering the callback to get a list of devices already added.

Parameters
transport int: The transport to be used. This is either TRANSPORT_MIDI_BYTE_STREAM or TRANSPORT_UNIVERSAL_MIDI_PACKETS. Value is TRANSPORT_MIDI_BYTE_STREAM, or TRANSPORT_UNIVERSAL_MIDI_PACKETS

executor Executor: The Executor that will be used for delivering the device notifications. This value cannot be null.

callback MidiManager.DeviceCallback: a DeviceCallback for MIDI device notifications This value cannot be null.

registerDeviceCallback

Added in API level 23
Deprecated in API level 33
public void registerDeviceCallback (MidiManager.DeviceCallback callback, 
                Handler handler)

This method was deprecated in API level 33.
Use registerDeviceCallback(int, java.util.concurrent.Executor, android.media.midi.MidiManager.DeviceCallback) instead.

Registers a callback to receive notifications when MIDI 1.0 devices are added and removed. These are devices that do not default to Universal MIDI Packets. To register for a callback for those, call registerDeviceCallback(DeviceCallback, Handler) instead. The DeviceCallback.onDeviceStatusChanged method will be called immediately for any devices that have open ports. This allows applications to know which input ports are already in use and, therefore, unavailable. Applications should call getDevices() before registering the callback to get a list of devices already added.

Parameters
callback MidiManager.DeviceCallback: a DeviceCallback for MIDI device notifications

handler Handler: The Handler that will be used for delivering the device notifications. If handler is null, then the thread used for the callback is unspecified.

unregisterDeviceCallback

Added in API level 23
public void unregisterDeviceCallback (MidiManager.DeviceCallback callback)

Unregisters a DeviceCallback.

Parameters
callback MidiManager.DeviceCallback: a DeviceCallback to unregister