• WinAPI: midiInOpen 打开 MIDI 输入设备


    提示:
    因为其中的回调函数是在中断时间内访问的, 必须在 DLL 中; 要访问的数据都必须是在固定的数据段中; 除了
    PostMessage
    timeGetSystemTime
    timeGetTime
    timeSetEvent
    timeKillEvent
    midiOutShortMsg
    midiOutLongMsg
    OutputDebugString 外, 也不能有其他系统调用.

    //声明:
    midiInOpen(
      lphMidiIn: PHMIDIIN; {用于返回设备句柄的指针; 之后再调用其他函数应该使用这个句柄}
      uDeviceID: UINT;     {设备ID; 不可以指定为常量 MIDI_MAPPER = UINT(-1);}
      dwCallback: DWORD    {回调函数地址或窗口句柄; 若不使用回调机制, 设为 nil}
      dwInstance: DWORD    {给回调函数的实例数据; 不用于窗口}
      dwFlags: DWORD       {打开选项}
    ): MMRESULT;           {成功返回 0; 可能的错误值见下:}
    
    MMSYSERR_BADDEVICEID = 2;  {设备ID超界}
    MMSYSERR_ALLOCATED   = 4;  {指定的资源已被分配}
    MMSYSERR_NOMEM       = 7;  {不能分配或锁定内存}
    
    //打开选项 dwFlags 的可选值:
    CALLBACK_NULL     = $00000000; {当 dwCallback 是 nil 时指定}
    CALLBACK_WINDOW   = $00010000; {当 dwCallback 是窗口句柄时指定}
    CALLBACK_FUNCTION = $00030000; {当 dwCallback 是函数指针时指定}
    
    //如果选择窗口接受回调信息, 可能会发送到窗口的消息有:
    MM_MIM_OPEN      = $3C1;
    MM_MIM_CLOSE     = $3C2;
    MM_MIM_DATA      = $3C3;
    MM_MIM_LONGDATA  = $3C4;
    MM_MIM_ERROR     = $3C5;
    MM_MIM_LONGERROR = $3C6;
    
    //如果选择函数接受回调信息, 可能会发送给函数的消息有:
    MIM_OPEN      = MM_MIM_OPEN;
    MIM_CLOSE     = MM_MIM_CLOSE;
    MIM_DATA      = MM_MIM_DATA;
    MIM_LONGDATA  = MM_MIM_LONGDATA;
    MIM_ERROR     = MM_MIM_ERROR;
    MIM_LONGERROR = MM_MIM_LONGERROR;
    
    //举例:
  • 相关阅读:
    11、MyBatis教程之动态SQL
    10、MyBatis教程之一对多处理
    9、MyBatis教程之多对一处理
    8、MyBatis之使用注解开发
    7、MyBatis教程之分页实现
    6、MyBatis教程之日志实现
    5、MyBatis教程之ResultMap
    4、MyBatis教程之配置解析
    3、MyBatis教程之CURD操作
    Session的几种保存方式
  • 原文地址:https://www.cnblogs.com/del/p/1079085.html
Copyright © 2020-2023  润新知