Export (0) Print
Expand All
Expand Minimize

midiOutOpen function

The midiOutOpen function opens a MIDI output device for playback.

Syntax


MMRESULT midiOutOpen(
  LPHMIDIOUT lphmo,
  UINT uDeviceID,
  DWORD_PTR dwCallback,
  DWORD_PTR dwCallbackInstance,
  DWORD dwFlags
);

Parameters

lphmo

Pointer to an HMIDIOUT handle. This location is filled with a handle identifying the opened MIDI output device. The handle is used to identify the device in calls to other MIDI output functions.

uDeviceID

Identifier of the MIDI output device that is to be opened.

dwCallback

Pointer to a callback function, an event handle, a thread identifier, or a handle of a window or thread called during MIDI playback to process messages related to the progress of the playback. If no callback is desired, specify NULL for this parameter. For more information on the callback function, see MidiOutProc.

dwCallbackInstance

User instance data passed to the callback. This parameter is not used with window callbacks or threads.

dwFlags

Callback flag for opening the device. It can be the following values.

Value Meaning
CALLBACK_EVENTThe dwCallback parameter is an event handle. This callback mechanism is for output only.
CALLBACK_FUNCTIONThe dwCallback parameter is a callback function address.
CALLBACK_NULLThere is no callback mechanism. This value is the default setting.
CALLBACK_THREADThe dwCallback parameter is a thread identifier.
CALLBACK_WINDOWThe dwCallback parameter is a window handle.

 

Return value

Returns MMSYSERR_NOERROR if successful or an error otherwise. Possible error values include the following.

Return codeDescription
MIDIERR_NODEVICE

No MIDI port was found. This error occurs only when the mapper is opened.

MMSYSERR_ALLOCATED

The specified resource is already allocated.

MMSYSERR_BADDEVICEID

The specified device identifier is out of range.

MMSYSERR_INVALPARAM

The specified pointer or structure is invalid.

MMSYSERR_NOMEM

The system is unable to allocate or lock memory.

 

Remarks

To determine the number of MIDI output devices present in the system, use the midiOutGetNumDevs function. The device identifier specified by wDeviceID varies from zero to one less than the number of devices present. MIDI_MAPPER can also be used as the device identifier.

If a window or thread is chosen to receive callback information, the following messages are sent to the window procedure or thread to indicate the progress of MIDI output: MM_MOM_OPEN, MM_MOM_CLOSE, and MM_MOM_DONE.

If a function is chosen to receive callback information, the following messages are sent to the function to indicate the progress of MIDI output: MOM_OPEN, MOM_CLOSE, and MOM_DONE.

Requirements

Minimum supported client

Windows 2000 Professional [desktop apps only]

Minimum supported server

Windows 2000 Server [desktop apps only]

Header

Mmsystem.h (include Windows.h)

Library

Winmm.lib

DLL

Winmm.dll

See also

MIDI Functions

 

 

Community Additions

ADD
Show:
© 2014 Microsoft