다음을 통해 공유


MM_MIM_MOREDATA 메시지

MIDI 입력 디바이스에서 MIDI 메시지를 수신하지만 애플리케이션이 입력 디바이스 드라이버를 따라갈 수 있을 만큼 빠르게 MIM_DATA 메시지를 처리하지 않을 때 MM_MIM_MOREDATA 메시지가 콜백 창으로 전송됩니다. 이 창은 애플리케이션이 midiInOpen 함수 호출에서 MIDI_IO_STATUS 지정하는 경우에만 이 메시지를 받습니다.

MM_MIM_MOREDATA 
wParam = (WPARAM) hInput 
lParam = (LPARAM) (DWORD) lMidiMessage 

매개 변수

hInput

MIDI 메시지를 받은 MIDI 입력 디바이스에 대한 핸들입니다.

lMidiMessage

받은 MIDI 메시지를 지정합니다. 메시지는 다음과 같이 이중 단어 값으로 압축됩니다.

요구 사항 Description
높은 단어 높은 순서 바이트 사용되지 않습니다.
낮은 순서 바이트 필요한 경우 MIDI 데이터의 두 번째 바이트를 포함합니다.
낮은 단어 높은 순서 바이트 MIDI 데이터의 첫 번째 바이트를 포함합니다(필요한 경우).
낮은 순서 바이트 MIDI 상태 포함합니다.

두 MIDI 데이터 바이트는 MIDI 상태 바이트에 따라 선택 사항입니다.

반환 값

이 메시지는 값을 반환하지 않습니다.

설명

애플리케이션이 MIDI 데이터를 처리할 수 있는 것보다 빠르게 수신하는 경우 창 콜백 메커니즘을 사용하면 안 됩니다. 속도를 최대화하려면 콜백 함수를 사용하고 MM_MIM_MOREDATA 대신 MIM_MOREDATA 메시지를 사용합니다.

애플리케이션은 MM_MIM_MOREDATA 메시지 처리를 최소화해야 합니다. (특히 애플리케이션은 MM_MIM_MOREDATA 처리하는 동안 PostMessage 함수를 호출해서는 안 됩니다.) 대신 애플리케이션은 이벤트 데이터를 버퍼에 배치한 다음 반환해야 합니다.

애플리케이션이 일련의 MM_MIM_MOREDATA 메시지 후에 MM_MIM_DATA 메시지를 받으면 들어오는 MIDI 이벤트를 catch하고 시간 집약적 함수를 안전하게 호출할 수 있습니다.

MIDI 입력 포트에서 받은 MIDI 메시지는 실행 상태 비활성화되어 있습니다. 각 메시지는 MIDI 상태 바이트를 포함하도록 확장됩니다.

MIDI 시스템 전용 메시지를 받으면 이 메시지가 전송되지 않습니다. 이 메시지와 함께 사용할 수 있는 타임스탬프는 없습니다. 타임스탬프를 사용한 입력 데이터의 경우 콜백 함수로 전송되는 메시지를 사용해야 합니다.

요구 사항

요구 사항
지원되는 최소 클라이언트
Windows 2000 Professional[데스크톱 앱만]
지원되는 최소 서버
Windows 2000 Server[데스크톱 앱만]
헤더
Mmsystem.h(Windows.h 포함)

추가 정보

악기 디지털 인터페이스(MIDI)

MIDI 메시지