home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / warptlk3.zip / TOOLKIT / BETA / H / MMSYSTEM.H < prev    next >
C/C++ Source or Header  |  1995-08-24  |  132KB  |  2,391 lines

  1. #ifndef MMSYSTEM
  2. #define MMSYSTEM
  3.  
  4. /****************************************************************************/
  5. /*                                                                          */
  6. /* Module Name: MMSYSTEM.H                                                  */
  7. /*                                                                          */
  8. /* This is the multimedia include file that has the typedefs, defines and   */
  9. /* function prototyes for Media Control Interface of MMPM/2 (tm)            */
  10. /*                                                                          */
  11. /* Copyright (c) International Business Machines Corporation 1991, 1992     */
  12. /*                        All Rights Reserved                               */
  13. /*                                                                          */
  14. /****************************************************************************/
  15. #define MCI_TRUE                        1
  16. #define MCI_FALSE                       0
  17.  
  18. /*********************************************************************/
  19. /*                                                                   */
  20. /*             MCI command message identifiers                       */
  21. /*                                                                   */
  22. /*********************************************************************/
  23. #define MCI_OPEN                        1
  24. #define MCI_CLOSE                       2
  25. #define MCI_ESCAPE                      3
  26. #define MCI_PLAY                        4
  27. #define MCI_SEEK                        5
  28. #define MCI_STOP                        6
  29. #define MCI_PAUSE                       7
  30. #define MCI_INFO                        8
  31. #define MCI_GETDEVCAPS                  9
  32. #define MCI_STATUS                      10
  33. #define MCI_SPIN                        11
  34. #define MCI_SET                         12
  35. #define MCI_STEP                        13
  36. #define MCI_RECORD                      14
  37. #define MCI_SYSINFO                     15
  38. #define MCI_SAVE                        16
  39. #define MCI_CUE                         17
  40. #define MCI_UPDATE                      18
  41. #define MCI_SET_CUEPOINT                19
  42. #define MCI_SET_POSITION_ADVISE         20
  43. #define MCI_SET_SYNC_OFFSET             21
  44. #define MCI_LOAD                        22
  45. #define MCI_ACQUIREDEVICE               23
  46. #define MCI_RELEASEDEVICE               24
  47. #define MCI_MASTERAUDIO                 25
  48. #define MCI_GETTOC                      26
  49. #define MCI_DEVICESETTINGS              27
  50. #define MCI_CONNECTOR                   28
  51. #define MCI_RESUME                      29
  52.  
  53. #define MCI_CONNECTORINFO               31
  54. #define MCI_DEFAULT_CONNECTION          32
  55. #define MCI_CONNECTION                  33
  56. #define MCI_GROUP                       34
  57. #define MCI_NETWORK_DEFAULT_CONNECTION  35
  58.  
  59.    /*************************************************/
  60.    /* MCI command message identifiers reserved for  */
  61.    /*  Digital Video and Video Overlay              */
  62.    /*************************************************/
  63.  
  64. #define MCI_CAPTURE                     40
  65. #define MCI_FREEZE                      41
  66. #define MCI_GETIMAGEBUFFER              42
  67. #define MCI_GETIMAGEPALETTE             43
  68. #define MCI_PUT                         44
  69. #define MCI_REALIZE                     45
  70. #define MCI_REWIND                      46
  71. #define MCI_RESTORE                     47
  72. #define MCI_SETIMAGEBUFFER              48
  73. #define MCI_SETIMAGEPALETTE             49
  74. #define MCI_UNFREEZE                    50
  75. #define MCI_WHERE                       51
  76. #define MCI_WINDOW                      52
  77.  
  78. #define MCI_DELETE                      53
  79. #define MCI_CUT                         54
  80. #define MCI_PASTE                       55
  81. #define MCI_COPY                        56
  82. #define MCI_REDO                        57
  83. #define MCI_UNDO                        58
  84. #define MCI_MIXNOTIFY                   59
  85. #define MCI_SETTUNER                    60
  86. #define MCI_FILTER                      61
  87. #define MCI_BUFFER                      62
  88. #define MCI_MIXSETUP                    63
  89.  
  90. #define MCI_MAX_COMMAND                 63
  91.  
  92. #define RECT                            DWORD
  93. #define HDCT                            DWORD
  94. /*********************************************************************/
  95. /* this and all subsequent message ID's are reserved for the user    */
  96. /*********************************************************************/
  97. #define MCI_USER_MESSAGES               2000
  98.  
  99. /*********************************************************************/
  100. /* Special Device ID for "all"                                       */
  101. /*********************************************************************/
  102. #define MCI_ALL_DEVICE_ID               0xFFFF
  103.  
  104. /*********************************************************************/
  105. /* MCI implementation limits                                         */
  106. /*********************************************************************/
  107. #define MAX_DEVICE_NAME                 20
  108. #define MAX_ALIAS_NAME                  20
  109. #define MAX_PRODINFO                    40
  110. #define MAX_EXTENSION_NAME              4
  111. #define MAX_DEV_PARAMS                  128
  112. #define MAX_VERSION_NUMBER              6
  113. #define MAX_PDD_NAME                    9
  114. #define MAX_DLL_NAME                    260
  115. #define MAX_CLASSES                     10
  116. #define MAX_CONNECTORS                  10
  117. #define MAX_EXTENSIONS                  25
  118. #define MAX_TYPEBUFFER                  256
  119.  
  120. #ifdef INCL_32
  121. /*********************************************************************/
  122. /* MCI Device Type Constants                                         */
  123. /*********************************************************************/
  124. #define MCI_DEVTYPE_VIDEOTAPE           1
  125. #define MCI_DEVTYPE_VIDEODISC           2
  126. #define MCI_DEVTYPE_CD_AUDIO            3
  127. #define MCI_DEVTYPE_DAT                 4
  128. #define MCI_DEVTYPE_AUDIO_TAPE          5
  129. #define MCI_DEVTYPE_OTHER               6
  130. #define MCI_DEVTYPE_WAVEFORM_AUDIO      7
  131. #define MCI_DEVTYPE_SEQUENCER           8
  132. #define MCI_DEVTYPE_AUDIO_AMPMIX        9
  133. #define MCI_DEVTYPE_OVERLAY             10
  134. #define MCI_DEVTYPE_ANIMATION           11
  135. #define MCI_DEVTYPE_DIGITAL_VIDEO       12
  136. #define MCI_DEVTYPE_SPEAKER             13
  137. #define MCI_DEVTYPE_HEADPHONE           14
  138. #define MCI_DEVTYPE_MICROPHONE          15
  139. #define MCI_DEVTYPE_MONITOR             16
  140. #define MCI_DEVTYPE_CDXA                17
  141. #define MCI_DEVTYPE_FILTER              18
  142.  
  143. /*********************************************************************/
  144. /* MCI Device Type Names                                             */
  145. /*********************************************************************/
  146. #define MCI_DEVTYPE_VIDEOTAPE_NAME          "Videotape"
  147. #define MCI_DEVTYPE_VIDEODISC_NAME          "Videodisc"
  148. #define MCI_DEVTYPE_CD_AUDIO_NAME           "CDaudio"
  149. #define MCI_DEVTYPE_DAT_NAME                "DAT"
  150. #define MCI_DEVTYPE_AUDIO_TAPE_NAME         "Audiotape"
  151. #define MCI_DEVTYPE_OTHER_NAME              "Other"
  152. #define MCI_DEVTYPE_WAVEFORM_AUDIO_NAME     "Waveaudio"
  153. #define MCI_DEVTYPE_SEQUENCER_NAME          "Sequencer"
  154. #define MCI_DEVTYPE_AUDIO_AMPMIX_NAME       "Ampmix"
  155. #define MCI_DEVTYPE_OVERLAY_NAME            "Overlay"
  156. #define MCI_DEVTYPE_ANIMATION_NAME          "Animation"
  157. #define MCI_DEVTYPE_DIGITAL_VIDEO_NAME      "Digitalvideo"
  158. #define MCI_DEVTYPE_SPEAKER_NAME            "Speaker"
  159. #define MCI_DEVTYPE_HEADPHONE_NAME          "Headphone"
  160. #define MCI_DEVTYPE_MICROPHONE_NAME         "Microphone"
  161. #define MCI_DEVTYPE_MONITOR_NAME            "Monitor"
  162. #define MCI_DEVTYPE_CDXA_NAME               "CDXA"
  163. #define MCI_DEVTYPE_FILTER_NAME             "Filter"
  164.  
  165. #define MCI_MAX_SYSTEM_DEVICE_NAMES         18
  166.  
  167. #endif                       /* INCL_32 */
  168.  
  169. /*********************************************************************/
  170. /* Getdevcaps, set, and status item base values                      */
  171. /*********************************************************************/
  172.  
  173. #define MCI_AMP_ITEM_BASE                   0x00001000L
  174. #define MCI_CD_ITEM_BASE                    0x00002000L
  175. #define MCI_CDXA_ITEM_BASE                  0x00003000L
  176. #define MCI_VD_ITEM_BASE                    0x00004000L
  177. #define MCI_SEQ_ITEM_BASE                   0x00005000L
  178. #define MCI_WAVE_ITEM_BASE                  0x00006000L
  179. #define MCI_VID_ITEM_BASE                   0x00007000L
  180. #define MCI_DGV_ITEM_BASE                   0x00008000L
  181. #define MCI_OVLY_ITEM_BASE                  0x00009000L
  182.  
  183. /*********************************************************************/
  184. /* Flags for mciDriverNotify                                         */
  185. /*********************************************************************/
  186. #define MCI_NOTIFY_SUCCESSFUL               0x0000
  187. #define MCI_NOTIFY_SUPERSEDED               0x0001
  188. #define MCI_NOTIFY_ABORTED                  0x0002
  189. #define MCI_NOTIFY_ERROR                    0x0003
  190.  
  191. /*********************************************************************/
  192. /* mciDriverNotify  Message Types                                    */
  193. /*********************************************************************/
  194. #define MM_MCINOTIFY                        0x0500
  195. #define MM_MCIPASSDEVICE                    0x0501
  196. #define MM_MCIPOSITIONCHANGE                0x0502
  197. #define MM_MCICUEPOINT                      0x0503
  198. #define MM_MCIPLAYLISTMESSAGE               0x0504
  199. #define MM_MCIEVENT                         0x0505
  200. #define MM_MCISYNCH                         0x0506
  201.  
  202. #define MCI_LOSING_USE                      0x00000001L
  203. #define MCI_GAINING_USE                     0x00000002L
  204.  
  205. /*********************************************************************/
  206. /* Common message flags                                              */
  207. /*     0x000000XX are reserved for common flags                      */
  208. /*********************************************************************/
  209. #define MCI_NOTIFY                          0x00000001L
  210. #define MCI_WAIT                            0x00000002L
  211. #define MCI_FROM                            0x00000004L
  212. #define MCI_TO                              0x00000008L
  213. #define MCI_DOS_QUEUE                       0x00000008L
  214. #define MCI_MILLISECONDS                    0x00000010L
  215. #define MCI_TRACK                           0x00000020L
  216. #define MCI_OVER                            0x00000040L
  217. #define MCI_TEST                            0x00000080L
  218. #define MCI_TO_BUFFER                       0x00000100L
  219. #define MCI_FROM_BUFFER                     0x00000200L
  220. #define MCI_CONVERT_FORMAT                  0x00000400L
  221.  
  222.  
  223. /*********************************************************************/
  224. /* Time formats                                                      */
  225. /*********************************************************************/
  226. #define MCI_FORMAT_MILLISECONDS             0x00000001L
  227. #define MCI_FORMAT_MMTIME                   0x00000002L
  228. #define MCI_FORMAT_MSF                      0x00000005L
  229. #define MCI_FORMAT_TMSF                     0x00000006L
  230. #define MCI_FORMAT_CHAPTERS                 0x00000007L
  231. #define MCI_FORMAT_FRAMES                   0x00000008L
  232. #define MCI_FORMAT_HMS                      0x00000009L
  233. #define MCI_FORMAT_TRACKS                   0x0000000AL
  234. #define MCI_FORMAT_BYTES                    0x0000000BL
  235. #define MCI_FORMAT_SAMPLES                  0x0000000CL
  236. #define MCI_FORMAT_HMSF                     0x0000000DL
  237. #define MCI_FORMAT_SET_SMPTE_24             0x0000000EL
  238. #define MCI_FORMAT_SET_SMPTE_25             0x0000000FL
  239. #define MCI_FORMAT_SET_SMPTE_30             0x00000010L
  240. #define MCI_FORMAT_SET_SMPTE_30DROP         0x00000011L
  241. #define MCI_FORMAT_SET_SONGPTR              0x00000012L
  242. #define MCI_FORMAT_USEC                     0x00000013L
  243.  
  244. /*********************************************************************/
  245. /* Speed formats                                                     */
  246. /*********************************************************************/
  247. #define MCI_FORMAT_PERCENTAGE               0x00000003L
  248. #define MCI_FORMAT_FPS                      0x00000004L
  249.  
  250.  
  251. /*********************************************************************/
  252. /*                                                                   */
  253. /*  Time format conversions macros                                   */
  254. /*                                                                   */
  255. /*********************************************************************/
  256. #define MSECTOMM(value)      (((value) > (0xFFFFFFFF /3)) ? 0L : \
  257.                               ((value) * 3))
  258.  
  259. #define MSECFROMMM(value)    (((value)+1) / 3)
  260.  
  261. #define REDBOOKTOMM(value)   ((((value) & 0x000000FF) * 60 * 3000) + \
  262.                               (((value) & 0x0000FF00) / 0x100 * 3000) + \
  263.                               (((value) & 0x00FF0000) / 0x10000 * 3000/75))
  264.  
  265. #define FPS24TOMM(value) ((((value) & 0x000000FF) * 60 * 60 * 3000) + \
  266.                           (((value) & 0x0000FF00) / 0x100 * 60 * 3000) + \
  267.                           (((value) & 0x00FF0000) / 0x10000 * 3000) + \
  268.                           (((value) & 0xFF000000) / 0x1000000 * 3000/24))
  269.  
  270. #define FPS25TOMM(value) ((((value) & 0x000000FF) * 60 * 60 * 3000) + \
  271.                           (((value) & 0x0000FF00) / 0x100 * 60 * 3000) + \
  272.                           (((value) & 0x00FF0000) / 0x10000 * 3000) + \
  273.                           (((value) & 0xFF000000) / 0x1000000 * 3000/25))
  274.  
  275. #define FPS30TOMM(value) ((((value) & 0x000000FF) * 60 * 60 * 3000) + \
  276.                           (((value) & 0x0000FF00) / 0x100 * 60 * 3000) + \
  277.                           (((value) & 0x00FF0000) / 0x10000 * 3000) + \
  278.                           (((value) & 0xFF000000) / 0x1000000 * 3000/30))
  279.  
  280. #define HMSTOMM(value)   ((((value) & 0x000000FF) * 60 * 60 * 3000) + \
  281.                           (((value) & 0x0000FF00) / 0x100 * 60 * 3000) + \
  282.                           (((value) & 0x00FF0000) / 0x10000 * 3000))
  283.  
  284.  
  285.   /* The +20 is used for rounding purposes.  It is derived by:           */
  286.   /*   1/2 * ((300 MMTIME/SEC / (75 FRAMES/SEC)) = 20 MMTIME/HALF-FRAME  */
  287. #define REDBOOKFROMMM(value) ((((value)+20) >= 0x100*60*3000) ? 0L : \
  288.                               ((((value)+20) / (60*3000)) + \
  289.                                (((value)+20) % (60*3000) / 3000 << 8) + \
  290.                                (((value)+20) / (3000/75) % 75 << 16)))
  291.  
  292. #define FPS24FROMMM(value) ((((value)+63) >= 0x100*60*60*3000) ? 0L : \
  293.                         (((((((value)+63) % 3000)/(3000/24)) << 24) & 0xFF000000) | \
  294.                          ((((((value)+63) / 3000) % 60) << 16) & 0x00FF0000)      | \
  295.                         (((((((value)+63) / 3000) / 60) % 60) << 8) & 0x0000FF00) | \
  296.                          ((((((value)+63) / 3000) / 60) / 60)  & 0x000000FF)))
  297.  
  298. #define FPS25FROMMM(value) ((((value)+60) >= 0x100*60*60*3000) ? 0L : \
  299.                         (((((((value)+60) % 3000)/(3000/25)) << 24) & 0xFF000000) | \
  300.                          ((((((value)+60) / 3000) % 60) << 16) & 0x00FF0000)      | \
  301.                         (((((((value)+60) / 3000) / 60) % 60) << 8) & 0x0000FF00) | \
  302.                          ((((((value)+60) / 3000) / 60) / 60)  & 0x000000FF)))
  303.  
  304. #define FPS30FROMMM(value) ((((value)+50) >= 0x100*60*60*3000) ? 0L : \
  305.                         (((((((value)+50) % 3000)/(3000/30)) << 24) & 0xFF000000) | \
  306.                          ((((((value)+50) / 3000) % 60) << 16) & 0x00FF0000)      | \
  307.                         (((((((value)+50) / 3000) / 60) % 60) << 8) & 0x0000FF00) | \
  308.                          ((((((value)+50) / 3000) / 60) / 60)  & 0x000000FF)))
  309.  
  310. #define HMSFROMMM(value) ((((value)+50) >= 0x100*60*60*3000) ? 0L : \
  311.                         (((((((value)+50) / 3000) % 60) << 16) & 0x00FF0000)      | \
  312.                         (((((((value)+50) / 3000) / 60) % 60) << 8) & 0x0000FF00) | \
  313.                          ((((((value)+50) / 3000) / 60) / 60)  & 0x000000FF)))
  314.  
  315. #define TMSF_TRACK(time)     (*(BYTE *)(&(time)))
  316. #define TMSF_MINUTE(time)    (*((BYTE *)(&(time))+1))
  317. #define TMSF_SECOND(time)    (*((BYTE *)(&(time))+2))
  318. #define TMSF_FRAME(time)     (*((BYTE *)(&(time))+3))
  319. #define MSF_MINUTE(time)     (*(BYTE *)(&(time)))
  320. #define MSF_SECOND(time)     (*((BYTE *)(&(time))+1))
  321. #define MSF_FRAME(time)      (*((BYTE *)(&(time))+2))
  322.  
  323. /*********************************************************************/
  324. /*                                                                   */
  325. /*  BYTE ACCESS WITH A DWORD MACROS                                  */
  326. /*                                                                   */
  327. /*********************************************************************/
  328. #define DWORD_LWLB(dw)  (*(BYTE *)((DWORD *)(&dw)))       /* Low  Word Low Byte  */
  329. #define DWORD_LWHB(dw)  (*((BYTE *)((DWORD *)(&dw))+1))   /* Low  Word High Byte */
  330. #define DWORD_HWLB(dw)  (*((BYTE *)((DWORD *)(&dw))+2))   /* High Word Low Byte  */
  331. #define DWORD_HWHB(dw)  (*((BYTE *)((DWORD *)(&dw))+3))   /* High Word High Byte */
  332. #define DWORD_LOWD(dw)  (*(WORD *)((DWORD *)(&dw)))       /* Low  Word           */
  333. #define DWORD_HIWD(dw)  (*((WORD *)((DWORD *)(&dw))+1))   /* High Word           */
  334.  
  335. #ifdef INCL_32
  336.  
  337. #pragma pack(1)
  338.  
  339. /*********************************************************************/
  340. /* parameters for default command messages with empty parameter lists*/
  341. /*********************************************************************/
  342. typedef struct _MCI_GENERIC_PARMS {
  343.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  344. } MCI_GENERIC_PARMS;
  345. typedef MCI_GENERIC_PARMS   *LPMCI_GENERIC_PARMS;
  346.  
  347.  
  348. /*********************************************************************/
  349. /* flags for the MCI_ACQUIREDEVICE message                           */
  350. /*     0x00000X00 are reserved for MCI_ACQUIREDEVICE flags           */
  351. /*********************************************************************/
  352. #define MCI_EXCLUSIVE                       0x00000100L
  353. #define MCI_EXCLUSIVE_INSTANCE              0x00000200L
  354. #define MCI_ACQUIRE_QUEUE                   0x00000400L
  355.  
  356.  
  357. /*********************************************************************/
  358. /* flags for the MCI_CAPTURE message                                 */
  359. /*     0x0000XX00 are reserved for MCI_CAPTURE flags                 */
  360. /*     MCI_CONVERT is used by MCI_GETIMAGEBUFFER, MCI_SETIMAGEBUFFER */
  361. /*                            MCI_CAPTURE, and MCI_RESTORE           */
  362. /*********************************************************************/
  363. #define MCI_CAPTURE_RECT                    0x00000100L
  364. #define MCI_CONVERT                         0x00001000L
  365.  
  366. /*********************************************************************/
  367. /* parameter structure for the MCI_CAPTURE message                   */
  368. /*********************************************************************/
  369. typedef struct _MCI_CAPTURE_PARMS {
  370.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  371.     RECTL   rect;            /* Rectangle array specifying the area to  */
  372.                              /* be captured                             */
  373. } MCI_CAPTURE_PARMS;
  374. typedef MCI_CAPTURE_PARMS   *LPMCI_CAPTURE_PARMS;
  375.  
  376.  
  377. /*********************************************************************/
  378. /* flags for MCI_CONNECTOR and MCI_CONNECTION messages               */
  379. /*********************************************************************/
  380. #define MCI_ENABLE_CONNECTOR                0x00000100L
  381. #define MCI_DISABLE_CONNECTOR               0x00000200L
  382. #define MCI_QUERY_CONNECTOR_STATUS          0x00000400L
  383. #define MCI_CONNECTOR_TYPE                  0x00000800L
  384. #define MCI_CONNECTOR_INDEX                 0x00001000L
  385. #define MCI_TO_CONNECTOR_INDEX              0x00002000L
  386. #define MCI_TO_CONNECTOR_TYPE               0x00004000L
  387. #define MCI_QUERY_CONNECTION                0x00008000L
  388. #define MCI_MAKE_CONNECTION                 0x00010000L
  389. #define MCI_SET_CONNECTION                  MCI_MAKE_CONNECTION
  390. #define MCI_BREAK_CONNECTION                0x00020000L
  391. #define MCI_ENUMERATE_CONNECTORS            0x00040000L
  392. #define MCI_QUERY_CONNECTOR_TYPE            0x00080000L
  393. #define MCI_QUERY_VALID_CONNECTION          0x00100000L
  394. #define MCI_CONNECTOR_ALIAS                 0x00200000L
  395.  
  396.  
  397. /*********************************************************************/
  398. /* Connector types                                                   */
  399. /*********************************************************************/
  400. #define MCI_MIDI_STREAM_CONNECTOR           0x00000001L
  401. #define MCI_CD_STREAM_CONNECTOR             0x00000002L
  402. #define MCI_WAVE_STREAM_CONNECTOR           0x00000003L
  403. #define MCI_AMP_STREAM_CONNECTOR            0x00000004L
  404. #define MCI_XA_STREAM_CONNECTOR             0x00000005L
  405. #define MCI_HEADPHONES_CONNECTOR            0x00000006L
  406. #define MCI_SPEAKERS_CONNECTOR              0x00000007L
  407. #define MCI_MICROPHONE_CONNECTOR            0x00000008L
  408. #define MCI_LINE_IN_CONNECTOR               0x00000009L
  409. #define MCI_LINE_OUT_CONNECTOR              0x0000000aL
  410. #define MCI_VIDEO_IN_CONNECTOR              0x0000000bL
  411. #define MCI_VIDEO_OUT_CONNECTOR             0x0000000cL
  412. #define MCI_PHONE_SET_CONNECTOR             0x0000000dL
  413. #define MCI_PHONE_LINE_CONNECTOR            0x0000000eL
  414. #define MCI_AUDIO_IN_CONNECTOR              0x0000000fL
  415. #define MCI_AUDIO_OUT_CONNECTOR             0x00000010L
  416. #define MCI_UNIVERSAL_CONNECTOR             0x00000011L
  417. #define MCI_INTERNAL_AUDIO_CONNECTOR        0x00000012L
  418. #define MCI_MIDI_IN_CONNECTOR               0x00000013L
  419. #define MCI_MIDI_OUT_CONNECTOR              0x00000014L
  420. #define MCI_NULL_CONNECTOR                  0x00000015L
  421.  
  422.  
  423. /*********************************************************************/
  424. /* parameter structure for the MCI_CONNECTION message                */
  425. /*********************************************************************/
  426. typedef struct _MCI_CONNECTION_PARMS {
  427.     DWORD   dwCallback;         /* PM window handle for MCI notify message */
  428.     DWORD   dwConnectorType;    /* Connector type                          */
  429.     DWORD   dwConnectorIndex;   /* Connector index                         */
  430.     LPSTR   lpstrAlias;         /* Connection device alias                 */
  431.     WORD    wToDeviceID;        /* Connected to device ID                  */
  432.     WORD    wReserved0;         /* Reserved field                          */
  433.     DWORD   dwToConnectorType;  /* Connection to Connector type            */
  434.     DWORD   dwToConnectorIndex; /* Connection to Connector index           */
  435. } MCI_CONNECTION_PARMS;
  436. typedef MCI_CONNECTION_PARMS   *LPMCI_CONNECTION_PARMS;
  437.  
  438. /*********************************************************************/
  439. /* parameter structure for the MCI_CONNECTOR message                 */
  440. /*********************************************************************/
  441. typedef struct _MCI_CONNECTOR_PARMS {
  442.     DWORD  dwCallback;       /* PM window handle for MCI notify message    */
  443.     DWORD  dwReturn;         /* Return information                         */
  444.     DWORD  dwConnectorType;  /* If specified, dwConnectorIndex is relative */
  445.                              /* to the specified connector type            */
  446.     DWORD  dwConnectorIndex; /* Connector number                           */
  447. } MCI_CONNECTOR_PARMS;
  448. typedef MCI_CONNECTOR_PARMS   *LPMCI_CONNECTOR_PARMS;
  449.  
  450.  
  451. /*********************************************************************/
  452. /* Flags for use with ulParam1                                       */
  453. /*********************************************************************/
  454.  
  455.  
  456. #define MCI_MIXSETUP_INIT            0x00010000L
  457. #define MCI_MIXSETUP_DEINIT          0x00020000L
  458.  
  459.  
  460. /*********************************************************************/
  461. /* parameter structure for the MCI_BUFFER    message                 */
  462. /*********************************************************************/
  463. typedef struct _MCI_MIX_BUFFER {
  464.     ULONG      ulStructLength;   /* Length of the structure          */
  465.     PVOID      pBuffer;          /* Pointer to a buffer              */
  466.     ULONG      ulBufferLength;   /* Length of the buffer             */
  467.     ULONG      ulFlags;          /* Flags                            */
  468.     ULONG      ulUserParm;       /* Caller parameter                 */
  469.     ULONG      ulTime;           /* OUT--Current time in MS          */
  470.     ULONG      ulReserved1;      /* Unused.                          */
  471.     ULONG      ulReserved2;      /* Unused.                          */
  472. } MCI_MIX_BUFFER;
  473.  
  474. typedef MCI_MIX_BUFFER *PMCI_MIX_BUFFER;
  475.  
  476.  
  477. /*********************************************************************/
  478. /* valid options for the ulFlags field of MCI_MIX_BUFFER             */
  479. /*********************************************************************/
  480.  
  481.  
  482. #define MIX_BUFFER_EOS                0x00000001L
  483.  
  484.  
  485.  
  486. typedef LONG (APIENTRY MIXERPROC)
  487.                                 ( ULONG            ulHandle,
  488.                                   PMCI_MIX_BUFFER  pBuffer,
  489.                                   ULONG            ulFlags        );
  490.  
  491. typedef MIXERPROC *PMIXERPROC;
  492. typedef LONG (APIENTRY MIXEREVENT)
  493.                                 ( ULONG            ulStatus,
  494.                                   PMCI_MIX_BUFFER  pBuffer,
  495.                                   ULONG            ulFlags        );
  496.  
  497. typedef MIXEREVENT  *PMIXEREVENT;
  498.  
  499. /*********************************************************************/
  500. /* valid returns for the ulFlags param of the MIXEREVENT entry       */
  501. /*********************************************************************/
  502.  
  503.  
  504. #define MIX_STREAM_ERROR             0x00000080L
  505. #define MIX_READ_COMPLETE            0x00000001L
  506. #define MIX_WRITE_COMPLETE           0x00000002L
  507.  
  508.  
  509.  
  510. /*********************************************************************/
  511. /* parameter structure for the MCI_MIXSETUP_PARMS message            */
  512. /*********************************************************************/
  513. typedef struct _MCI_MIXSETUP_PARMS {
  514.     HWND         hwndCallback;     /* PM window handle for MCI notify message      */
  515.     ULONG        ulBitsPerSample;  /* IN Number of Bits per Sample                 */
  516.     ULONG        ulFormatTag;      /* IN Format Tag                                */
  517.     ULONG        ulSamplesPerSec;  /* IN Sampling Rate                             */
  518.     ULONG        ulChannels;       /* IN Number of channels                        */
  519.     ULONG        ulFormatMode;     /* IN Either MCI_RECORD or MCI_PLAY             */
  520.     ULONG        ulDeviceType;     /* IN MCI_DEVTYPE (i.e. DEVTYPE_WAVEFORM etc.)  */
  521.     ULONG        ulMixHandle;      /* OUT--mixer returns handle for write/read     */
  522.     PMIXERPROC   pmixWrite;        /* OUT-Mixer Write Routine entry point          */
  523.     PMIXERPROC   pmixRead;         /* OUT-Mixer Read Routine entry point           */
  524.     PMIXEREVENT  pmixEvent;        /* IN--Mixer Read Routine entry point           */
  525.     PVOID        pExtendedInfo;    /* Ptr to extended wave information             */
  526.     ULONG        ulBufferSize;     /* OUT--suggested buffer size for current mode  */
  527.     ULONG        ulNumBuffers;     /* OUT--suggested # of buffers for current mode */
  528. } MCI_MIXSETUP_PARMS;
  529.  
  530. typedef MCI_MIXSETUP_PARMS   *PMCI_MIXSETUP_PARMS;
  531.  
  532. /*********************************************************************/
  533. /* Flags for use with ulParam1                                       */
  534. /*********************************************************************/
  535.  
  536.  
  537.  
  538. #define  MCI_BUFFER_QUERY         0x00010000L
  539. #define  MCI_BUFFER_SET           0x00020000L
  540. #define  MCI_ALLOCATE_MEMORY      0x00040000L
  541. #define  MCI_DEALLOCATE_MEMORY    0x00080000L
  542.  
  543.  
  544. /*********************************************************************/
  545. /* parameter structure for the MCI_BUFFER    message                 */
  546. /*********************************************************************/
  547. typedef struct _MCI_BUFFER_PARMS {
  548.     HWND       hwndCallback;     /* PM window handle for MCI notify message    */
  549.     ULONG      ulStructLength;   /* Length of the MCI Buffer command           */
  550.     ULONG      ulNumBuffers;     /* Number of buffers MCI driver should use    */
  551.     ULONG      ulBufferSize;     /* Size of buffers MCI driver should use      */
  552.     ULONG      ulMinToStart;     /* Min number of buffers to create a stream.  */
  553.     ULONG      ulSrcStart;       /* # of EMPTY buffers required to start Source*/
  554.     ULONG      ulTgtStart;       /* # of FULL buffers required to start Target */
  555.  
  556.     PVOID      pBufList;         /* Pointer to a list of buffers               */
  557.  
  558. } MCI_BUFFER_PARMS;
  559. typedef MCI_BUFFER_PARMS   *PMCI_BUFFER_PARMS;
  560.  
  561.  
  562. /*********************************************************************/
  563. /* parameter structure for the MCI_CONNECTORINFO message             */
  564. /*********************************************************************/
  565. typedef struct _MCI_CONNECTORINFO_PARMS {
  566.     DWORD  dwCallback;        /* PM window handle for MCI notify message    */
  567.     DWORD  dwReturn;          /* Return information                         */
  568.     DWORD  dwDeviceTypeID;    /* MCI device type                            */
  569.     DWORD  dwConnectorType;   /* If specified, dwConnectorIndex is relative */
  570.                               /* to the specified connector type            */
  571.     DWORD  dwConnectorIndex;  /* Connector number                           */
  572.     DWORD  dwToConnectorType; /* Connector type to test if                  */
  573.                               /* MCI_QUERY_VALID_CONNECTION is specified    */
  574. } MCI_CONNECTORINFO_PARMS;
  575. typedef MCI_CONNECTORINFO_PARMS   *LPMCI_CONNECTORINFO_PARMS;
  576.  
  577. /*********************************************************************/
  578. /* flags for the MCI_CUE message                                     */
  579. /*     0x00000x00 are reserved for MCI_CUE flags                     */
  580. /*********************************************************************/
  581. #define MCI_CUE_INPUT                       0x00000100L
  582. #define MCI_CUE_OUTPUT                      0x00000200L
  583. #define MCI_SHOW                            0x00000400L
  584. #define MCI_NOSHOW                          0x00000800L
  585.  
  586.     /*************************************************/
  587.     /* Additional flags for Wave Audio for MCI_CUE   */
  588.     /*************************************************/
  589. #define MCI_WAVE_INPUT                      0x00001000L
  590. #define MCI_WAVE_OUTPUT                     0x00002000L
  591.  
  592.  
  593. /*****************************************************************************/
  594. /* the MCI_CONNLIST structure used in the NETWORK_DEFAULT_CONNECTION message */
  595. /*****************************************************************************/
  596. typedef struct _MCI_CONNLIST {
  597.     ULONG ulFromDevice;  /* Ordinal position of device within pDevices array */
  598.     ULONG ulSrcConnType; /* Type of source connector                         */
  599.     ULONG ulSrcConnNum;  /* Source Connector Number                          */
  600.     ULONG ulToDevice;    /* Ordinal position of device within pDevices array */
  601.     ULONG ulTgtConnType; /* Type of target connector                         */
  602.     ULONG ulTgtConnNum;  /* Target Connector Number                          */
  603. } MCI_CONNLIST;
  604. typedef MCI_CONNLIST *PMCI_CONNLIST;
  605.  
  606.  
  607. /*****************************************************************************/
  608. /* parameter structure for the MCI_NETWORK_DEFAULT_CONNECTION message        */
  609. /*****************************************************************************/
  610. typedef struct _MCI_NETWORK_DEFAULT_CONNECTION_PARMS {
  611.     HWND            hwndCallback;                   /* PM window handle for MCI notify message    */
  612.     CHAR            szInstallName[MAX_DEVICE_NAME]; /* Name of section containing default conn.   */
  613.     ULONG           ulNumDevices;                   /* Number of additional devices in connection */
  614.     ULONG           ulNumPlayConnections;           /* Number of Play connections                 */
  615.     ULONG           ulNumRecordConnections;         /* Number of Record connections               */
  616.     CHAR           (*pDevices)[MAX_DEVICE_NAME];    /* Pointer to array of device names to open   */
  617.     PMCI_CONNLIST   pPlayConnections;               /* Pointer to array of connections to "make"  */
  618.     PMCI_CONNLIST   pRecordConnections;             /* Pointer to array of connections to "make"  */
  619. } MCI_NETWORK_DEFAULT_CONNECTION_PARMS;
  620. typedef MCI_NETWORK_DEFAULT_CONNECTION_PARMS *PMCI_NETWORK_DEFAULT_CONNECTION_PARMS;
  621.  
  622.  
  623. /*******************************************************/
  624. /* Additional flags for MCI_NETWORK_DEFAULT_CONNECTION */
  625. /*******************************************************/
  626. #define MCI_RECORD_DEFAULTS             0x00000004L
  627. #define MCI_PLAY_DEFAULTS               0x00000008L
  628.  
  629.  
  630. /*********************************************************************/
  631. /* parameter structure for the MCI_DEFAULT_CONNECTION message        */
  632. /*********************************************************************/
  633. typedef struct _MCI_DEFAULT_CONNECTION_PARMS {
  634.     DWORD dwCallback;         /* PM window handle for MCI notify message    */
  635.     PSZ   pszDevice;          /* Device name                                */
  636.     DWORD dwConnectorType;    /* If specified, dwConnectorIndex is relative */
  637.                               /* to the specified connector type            */
  638.     DWORD dwConnectorIndex;   /* Connector number                           */
  639.     PSZ   pszToDevice;        /* Return device name to which the connection */
  640.                               /* exists                                     */
  641.     DWORD dwToConnectorType;  /* Connector type                             */
  642.     DWORD dwToConnectorIndex; /* Connector number                           */
  643. } MCI_DEFAULT_CONNECTION_PARMS;
  644. typedef MCI_DEFAULT_CONNECTION_PARMS   *LPMCI_DEFAULT_CONNECTION_PARMS;
  645.  
  646. /*********************************************************************/
  647. /* parameter structure for the MCI_DEVICESETTINGS message            */
  648. /*********************************************************************/
  649. typedef struct _MCI_DEVICESETTINGS_PARMS {
  650.     DWORD   dwCallback;      /* PM window handle for MCI notify message    */
  651.     HWND    hwndNotebook;    /* Hwhd to notebook window                    */
  652.     USHORT  usDeviceType;    /* Device type                                */
  653.     PSZ     pszDeviceName;   /* Device name                                */
  654. } MCI_DEVICESETTINGS_PARMS;
  655. typedef MCI_DEVICESETTINGS_PARMS   *LPMCI_DEVICESETTINGS_PARMS;
  656.  
  657. /**********************************************************************/
  658. /* parameter structure for the MCI_CUT / COPY / DELETE / UNDO / etc...*/
  659. /**********************************************************************/
  660. typedef struct _MCI_EDIT_PARMS {
  661.     ULONG   ulCallback;      /* PM window handle for MCI notify message     */
  662.     ULONG   ulStructLen;     /* Length of the Structure                     */
  663.     ULONG   ulFrom;          /* Beginning Point of Range                    */
  664.     ULONG   ulTo;            /* ending point of range                       */
  665.     PVOID   pBuff;           /* user buffer                                 */
  666.     ULONG   ulBufLen;        /* length of user buffer                       */
  667.     PVOID   pHeader;         /* header which describes the buffer           */
  668. } MCI_EDIT_PARMS;
  669. typedef MCI_EDIT_PARMS   *PMCI_EDIT_PARMS;
  670.  
  671. /*********************************************************************/
  672. /* flags and parameter structure for the MCI_ESCAPE message          */
  673. /*     0x00000X00 are reserved for MCI_ESCAPE flags                  */
  674. /*********************************************************************/
  675. #define MCI_ESCAPE_STRING                   0x00000100L
  676.  
  677. typedef struct _MCI_ESCAPE_PARMS {
  678.     DWORD   dwCallback;      /* PM window handle for MCI notify message    */
  679.     LPSTR   lpstrCommand;    /* Command to send to the device              */
  680. } MCI_ESCAPE_PARMS;
  681. typedef MCI_ESCAPE_PARMS   *LPMCI_ESCAPE_PARMS;
  682.  
  683. /*********************************************************************/
  684. /* flags for the MCI_FREEZE message                                  */
  685. /*     0x0000XX00 are reserved for MCI_FREEZE flags                  */
  686. /*********************************************************************/
  687. #define MCI_OVLY_FREEZE_RECT                0x00000100L
  688. #define MCI_OVLY_FREEZE_RECT_OUTSIDE        0x00000200L
  689.  
  690. /*********************************************************************/
  691. /* flags for the MCI_GETDEVCAPS message                              */
  692. /*     0x00XXXX00 are reserved for MCI_GETDEVCAPS flags              */
  693. /*********************************************************************/
  694. #define MCI_GETDEVCAPS_MESSAGE              0x00000100L
  695. #define MCI_GETDEVCAPS_ITEM                 0x00000200L
  696. #define MCI_GETDEVCAPS_EXTENDED             0x00000400L
  697.  
  698.    /*************************************************/
  699.    /* General MCI_GETDEVCAPS item values            */
  700.    /*************************************************/
  701. #define MCI_GETDEVCAPS_CAN_EJECT            0x00000001L
  702. #define MCI_GETDEVCAPS_CAN_LOCKEJECT        0x00000002L
  703. #define MCI_GETDEVCAPS_CAN_PLAY             0x00000003L
  704. #define MCI_GETDEVCAPS_CAN_PROCESS_INTERNAL 0x00000004L
  705. #define MCI_GETDEVCAPS_CAN_RECORD           0x00000005L
  706. #define MCI_GETDEVCAPS_CAN_RECORD_INSERT    0x00000006L
  707. #define MCI_GETDEVCAPS_CAN_SAVE             0x00000007L
  708. #define MCI_GETDEVCAPS_CAN_SETVOLUME        0x00000008L
  709. #define MCI_GETDEVCAPS_CAN_STREAM           0x00000009L
  710. #define MCI_GETDEVCAPS_DEVICE_TYPE          0x0000000AL
  711. #define MCI_GETDEVCAPS_HAS_AUDIO            0x0000000BL
  712. #define MCI_GETDEVCAPS_HAS_VIDEO            0x0000000CL
  713. #define MCI_GETDEVCAPS_PREROLL_TIME         0x0000000DL
  714. #define MCI_GETDEVCAPS_PREROLL_TYPE         0x0000000EL
  715. #define MCI_GETDEVCAPS_USES_FILES           0x0000000FL
  716. #define MCI_GETDEVCAPS_HAS_IMAGE            0x00000010L
  717. #define MCI_GETDEVCAPS_WAVE_FORMAT          0x00000011L
  718. #define MCI_GETDEVCAPS_CAN_CLOSE_DOOR       0x00000012L
  719.  
  720.     /***********************************************/
  721.     /* return ID's for videodisc MCI_GETDEVCAPS    */
  722.     /***********************************************/
  723. #define MCI_VD_MEDIA_CLV                    0x00000001L
  724. #define MCI_VD_MEDIA_CAV                    0x00000002L
  725. #define MCI_VD_MEDIA_OTHER                  0x00000003L
  726.  
  727.     /*************************************************/
  728.     /* MCI_GETDEVCAPS item values for video devices  */
  729.     /*************************************************/
  730. #define MCI_VID_GETDEVCAPS_CAN_STRETCH       MCI_VID_ITEM_BASE
  731. #define MCI_VID_GETDEVCAPS_CAN_DISTORT       (MCI_VID_ITEM_BASE+1)
  732. #define MCI_VID_GETDEVCAPS_VIDEO_X_EXTENT    (MCI_VID_ITEM_BASE+2)
  733. #define MCI_VID_GETDEVCAPS_VIDEO_Y_EXTENT    (MCI_VID_ITEM_BASE+3)
  734. #define MCI_VID_GETDEVCAPS_IMAGE_X_EXTENT    (MCI_VID_ITEM_BASE+4)
  735. #define MCI_VID_GETDEVCAPS_IMAGE_Y_EXTENT    (MCI_VID_ITEM_BASE+5)
  736. #define MCI_VID_GETDEVCAPS_MAX_WINDOWS       (MCI_VID_ITEM_BASE+6)
  737. #define MCI_VID_GETDEVCAPS_CAN_FREEZE        (MCI_VID_ITEM_BASE+7)
  738. #define MCI_VID_GETDEVCAPS_OVERLAY_GRAPHICS  (MCI_VID_ITEM_BASE+8)
  739.  
  740. #define MCI_VID_GETDEVCAPS_CAN_REVERSE       (MCI_VID_ITEM_BASE+9)
  741. #define MCI_VID_GETDEVCAPS_FAST_RATE         (MCI_VID_ITEM_BASE+10)
  742. #define MCI_VID_GETDEVCAPS_SLOW_RATE         (MCI_VID_ITEM_BASE+11)
  743. #define MCI_VID_GETDEVCAPS_NORMAL_RATE       (MCI_VID_ITEM_BASE+12)
  744. #define MCI_VID_GETDEVCAPS_MINIMUM_RATE      (MCI_VID_ITEM_BASE+13)
  745. #define MCI_VID_GETDEVCAPS_MAXIMUM_RATE      (MCI_VID_ITEM_BASE+14)
  746.  
  747.     /*************************************************/
  748.     /* MCI_GETDEVCAPS flag values for Videodisc      */
  749.     /*************************************************/
  750. #define MCI_VD_GETDEVCAPS_CLV               0x00000400L
  751. #define MCI_VD_GETDEVCAPS_CAV               0x00000800L
  752.  
  753.     /*************************************************/
  754.     /* MCI_GETDEVCAPS item values for Videodisc      */
  755.     /*************************************************/
  756.  
  757. #define MCI_VD_GETDEVCAPS_CAN_REVERSE       MCI_VID_GETDEVCAPS_CAN_REVERSE
  758. #define MCI_VD_GETDEVCAPS_FAST_RATE         MCI_VID_GETDEVCAPS_FAST_RATE
  759. #define MCI_VD_GETDEVCAPS_SLOW_RATE         MCI_VID_GETDEVCAPS_SLOW_RATE
  760. #define MCI_VD_GETDEVCAPS_NORMAL_RATE       MCI_VID_GETDEVCAPS_NORMAL_RATE
  761. #define MCI_VD_GETDEVCAPS_MINIMUM_RATE      MCI_VID_GETDEVCAPS_MINIMUM_RATE
  762. #define MCI_VD_GETDEVCAPS_MAXIMUM_RATE      MCI_VID_GETDEVCAPS_MAXIMUM_RATE
  763.  
  764.     /************************************************/
  765.     /* MCI_GETDEVCAPS item values for Digital Video */
  766.     /************************************************/
  767. #define MCI_DGV_GETDEVCAPS_CAN_REVERSE      MCI_VID_GETDEVCAPS_CAN_REVERSE
  768. #define MCI_DGV_GETDEVCAPS_CAN_STRETCH      MCI_VID_GETDEVCAPS_CAN_STRETCH
  769. #define MCI_DGV_GETDEVCAPS_CAN_DISTORT      MCI_VID_GETDEVCAPS_CAN_DISTORT
  770. #define MCI_DGV_GETDEVCAPS_FAST_RATE        MCI_VID_GETDEVCAPS_FAST_RATE
  771. #define MCI_DGV_GETDEVCAPS_SLOW_RATE        MCI_VID_GETDEVCAPS_SLOW_RATE
  772. #define MCI_DGV_GETDEVCAPS_NORMAL_RATE      MCI_VID_GETDEVCAPS_NORMAL_RATE
  773. #define MCI_DGV_GETDEVCAPS_MINIMUM_RATE     MCI_VID_GETDEVCAPS_MINIMUM_RATE
  774. #define MCI_DGV_GETDEVCAPS_MAXIMUM_RATE     MCI_VID_GETDEVCAPS_MAXIMUM_RATE
  775. #define MCI_DGV_GETDEVCAPS_VIDEO_X_EXTENT   MCI_VID_GETDEVCAPS_VIDEO_X_EXTENT
  776. #define MCI_DGV_GETDEVCAPS_VIDEO_Y_EXTENT   MCI_VID_GETDEVCAPS_VIDEO_Y_EXTENT
  777. #define MCI_DGV_GETDEVCAPS_IMAGE_X_EXTENT   MCI_VID_GETDEVCAPS_IMAGE_X_EXTENT
  778. #define MCI_DGV_GETDEVCAPS_IMAGE_Y_EXTENT   MCI_VID_GETDEVCAPS_IMAGE_Y_EXTENT
  779. #define MCI_DGV_GETDEVCAPS_MAX_WINDOWS      MCI_VID_GETDEVCAPS_MAX_WINDOWS
  780. #define MCI_DGV_GETDEVCAPS_OVERLAY_GRAPHICS MCI_VID_GETDEVCAPS_OVERLAY_GRAPHICS
  781. #define MCI_DGV_GETDEVCAPS_HAS_TUNER        (MCI_DGV_ITEM_BASE)
  782. #define MCI_DGV_GETDEVCAPS_HAS_TELETEX      (MCI_DGV_ITEM_BASE+1)
  783. #define MCI_DGV_GETDEVCAPS_HAS_AFC          (MCI_DGV_ITEM_BASE+2)
  784.  
  785.    /*************************************************/
  786.    /* MCI_GETDEVCAPS item values for Video Overlay  */
  787.    /*************************************************/
  788. #define MCI_OVLY_GETDEVCAPS_CAN_STRETCH     MCI_VID_GETDEVCAPS_CAN_STRETCH
  789. #define MCI_OVLY_GETDEVCAPS_CAN_DISTORT     MCI_VID_GETDEVCAPS_CAN_DISTORT
  790. #define MCI_OVLY_GETDEVCAPS_VIDEO_X_EXTENT  MCI_VID_GETDEVCAPS_VIDEO_X_EXTENT
  791. #define MCI_OVLY_GETDEVCAPS_VIDEO_Y_EXTENT  MCI_VID_GETDEVCAPS_VIDEO_Y_EXTENT
  792. #define MCI_OVLY_GETDEVCAPS_IMAGE_X_EXTENT  MCI_VID_GETDEVCAPS_IMAGE_X_EXTENT
  793. #define MCI_OVLY_GETDEVCAPS_IMAGE_Y_EXTENT  MCI_VID_GETDEVCAPS_IMAGE_Y_EXTENT
  794. #define MCI_OVLY_GETDEVCAPS_MAX_WINDOWS     MCI_VID_GETDEVCAPS_MAX_WINDOWS
  795. #define MCI_OVLY_GETDEVCAPS_CAN_FREEZE      MCI_VID_GETDEVCAPS_CAN_FREEZE
  796. #define MCI_OVLY_GETDEVCAPS_OVERLAY_GRAPHICS MCI_VID_GETDEVCAPS_OVERLAY_GRAPHICS
  797.  
  798.  
  799. #define MCI_PREROLL_NOTIFIED                0x00000001L
  800. #define MCI_PREROLL_DETERMINISTIC           0x00000002L
  801. #define MCI_PREROLL_NONE                    0x00000003L
  802.  
  803. /*********************************************************************/
  804. /* parameter structure for the MCI_GETDEVCAPS message                */
  805. /*********************************************************************/
  806. typedef struct _MCI_GETDEVCAPS_PARMS {
  807.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  808.     DWORD   dwReturn;        /* Return field                            */
  809.     DWORD   dwItem;          /* Item field for GETDEVCAPS item to query */
  810.     WORD    wMessage;        /* Field to hold MCI message to query      */
  811.     WORD    wReserved0;      /* Reserved field                          */
  812. } MCI_GETDEVCAPS_PARMS;
  813. typedef MCI_GETDEVCAPS_PARMS   * LPMCI_GETDEVCAPS_PARMS;
  814.  
  815. /*********************************************************************/
  816. /* parameter structure for the MCI_WAVE_GETDEVCAPS                   */
  817. /*********************************************************************/
  818. typedef struct _MCI_WAVE_GETDEVCAPS_PARMS {
  819.     ULONG   ulCallback;       /* PM window handle for MCI notify message */
  820.     ULONG   ulReturn;         /* Return field                            */
  821.     ULONG   ulItem;           /* Item field for GETDEVCAPS item to query */
  822.     USHORT  usMessage;        /* Field to hold MCI message to query      */
  823.     USHORT  usReserved0;      /* Reserved field                          */
  824.     ULONG   ulLength;         /* Length of structure in ULONGS           */
  825.     ULONG   ulBitsPerSample;  /* Number of Bits per Sample               */
  826.     ULONG   ulFormatTag;      /* Format Tag                              */
  827.     ULONG   ulSamplesPerSec;  /* Sampling Rate                           */
  828.     ULONG   ulChannels;       /* Number of channels                      */
  829.     ULONG   ulFormatMode;     /* Either MCI_RECORD or MCI_PLAY           */
  830. } MCI_WAVE_GETDEVCAPS_PARMS;
  831. typedef MCI_WAVE_GETDEVCAPS_PARMS   * PMCI_WAVE_GETDEVCAPS_PARMS;
  832.  
  833. /*********************************************************************/
  834. /* potential values for the ulValue field of MCI_AMP_GETDEVCAPS  */
  835. /*********************************************************************/
  836. #define  MCI_AMP_CAN_SET_MONITOR           MCI_AMP_SET_MONITOR
  837. #define  MCI_AMP_CAN_SET_BALANCE           MCI_AMP_SET_BALANCE
  838. #define  MCI_AMP_CAN_SET_ALC               MCI_AMP_SET_ALC
  839. #define  MCI_AMP_CAN_SET_MONITOR           MCI_AMP_SET_MONITOR
  840. #define  MCI_AMP_CAN_SET_CROSSOVER         MCI_AMP_SET_CROSSOVER
  841. #define  MCI_AMP_CAN_SET_LOUDNESS          MCI_AMP_SET_LOUDNESS
  842. #define  MCI_AMP_CAN_SET_MUTE              MCI_AMP_SET_MUTE
  843. #define  MCI_AMP_CAN_SET_REVERB            MCI_AMP_SET_REVERB
  844. #define  MCI_AMP_CAN_SET_STEREOENHANCE     MCI_AMP_SET_STEREOENHANCE
  845. #define  MCI_AMP_CAN_SET_CUSTOM1           MCI_AMP_SET_CUSTOM1
  846. #define  MCI_AMP_CAN_SET_CUSTOM2           MCI_AMP_SET_CUSTOM2
  847. #define  MCI_AMP_CAN_SET_CUSTOM3           MCI_AMP_SET_CUSTOM3
  848. #define  MCI_AMP_CAN_SET_LRVOLUME          MCI_AMP_SET_LRVOLUME
  849. #define  MCI_AMP_CAN_SET_BASS              MCI_AMP_SET_BASS
  850. #define  MCI_AMP_CAN_SET_MID               MCI_AMP_SET_MID
  851. #define  MCI_AMP_CAN_SET_TREBLE            MCI_AMP_SET_TREBLE
  852. #define  MCI_AMP_CAN_SET_PITCH             MCI_AMP_SET_PITCH
  853. #define  MCI_AMP_CAN_SET_GAIN              MCI_AMP_SET_GAIN
  854. #define  MCI_AMP_CAN_SET_CHORUS            MCI_AMP_SET_CHORUS
  855. #define  MCI_AMP_CAN_SET_VOLUME            MCI_AMP_SET_VOLUME
  856.  
  857.  
  858. /*************************************************************************/
  859. /* potential values for the ulExtended field of MCI_AMP_GETDEVCAPS_PARMS */
  860. /*************************************************************************/
  861. #define MCI_MIXER_LINE    0x00000001L
  862.  
  863.  
  864. /*********************************************************************/
  865. /* parameter structure for the MCI_AMP_GETDEVCAPS                    */
  866. /*********************************************************************/
  867. typedef struct _MCI_AMP_GETDEVCAPS_PARMS {
  868.     ULONG   hwndCallback;     /* PM window handle for MCI notify message */
  869.     ULONG   ulReturn;         /* Return field                            */
  870.     ULONG   ulItem;           /* Item field for GETDEVCAPS item to query */
  871.     USHORT  usMessage;        /* Field to hold MCI message to query      */
  872.     USHORT  usReserved0;      /* Reserved field                          */
  873.     ULONG   ulLength;         /* Length of structure in ULONGS           */
  874.     ULONG   ulValue;          /* Value to determine caps                 */
  875.     ULONG   ulAttribute;      /* Flags to modified the extended parms    */
  876.     ULONG   ulExtended;       /* Extended flags field                    */
  877. } MCI_AMP_GETDEVCAPS_PARMS;
  878. typedef MCI_AMP_GETDEVCAPS_PARMS   * PMCI_AMP_GETDEVCAPS_PARMS;
  879.  
  880.  
  881. /*********************************************************************/
  882. /* values for the ulFlags field of MCI_MIXEVENT_PARMS                */
  883. /*********************************************************************/
  884. #define MCI_MIX_ATTRIBUTE       0x00000001L
  885. #define MCI_MIX_CONNECTOR       0x00000002L
  886.  
  887. /*********************************************************************/
  888. /* values for the lParam field for mix_notify                        */
  889. /*********************************************************************/
  890.  
  891. #define MCI_MIXNOTIFY_ON        0x00000004L
  892. #define MCI_MIXNOTIFY_OFF       0x00000008L
  893.  
  894. /*********************************************************************/
  895. /* value to indicate type of MM_MCIEVENT                             */
  896. /*********************************************************************/
  897.  
  898. #define MCI_MIXEVENT            0x00000001L
  899.  
  900.  
  901. /*********************************************************************/
  902. /* parameter structure for the MCI_MIXEVENT_PARMS                    */
  903. /*********************************************************************/
  904. typedef struct _MCI_MIXEVENT_PARMS
  905.    {
  906.    ULONG  ulLength;        /* Length of struct                          */
  907.    HWND   hwndMixer;       /* window to inform of mixer changes         */
  908.    ULONG  ulFlags;         /* Either MCI_MIX_ATTRIBUTE                  */
  909.                            /*       or MCI_MIX_CONNECTOR                */
  910.    USHORT usDeviceID;      /* device id to notify of the change         */
  911.    ULONG  ulDeviceType;    /* Device Type which generated the change    */
  912.    ULONG  ulDeviceOrdinal; /* Ordinal of device Type                    */
  913.    ULONG  ulAttribute;     /* Attribute that changed(volume, bass etc.) */
  914.    ULONG  ulValue;         /* new value of the attribute which changed  */
  915.    ULONG  ulConnectorType; /* Connector Type                            */
  916.    ULONG  ulConnectorIndex;/* Connector Index                           */
  917.    ULONG  ulConnStatus;    /* Is connector enabled/disabled.            */
  918.  
  919.    } MCI_MIXEVENT_PARMS;
  920.  
  921. typedef MCI_MIXEVENT_PARMS *PMCI_MIXEVENT_PARMS;
  922.  
  923.  
  924. /*********************************************************************/
  925. /* flag values for the MCI_GETIMAGEBUFFER and MCI_SETIMAGEBUFFER msg */
  926. /*     0x0000XX00 are reserved for MCI_GETIMAGEBUFFER and            */
  927. /*       MCI_SETIMAGEBUFFER Flags                                    */
  928. /*     MCI_CONVERT is defined by MCI_CAPTURE message as 0x00001000L  */
  929. /*********************************************************************/
  930. #define MCI_USE_HW_BUFFER                   0x00000400L
  931. #define MCI_GET_HW_BUFFER_PTR               0x00000800L
  932.  
  933.    /***************************************************/
  934.    /* parm structure for MCI_GETIMAGEBUFFER and       */
  935.    /*                    MCI_SETIMAGEBUFFER messages  */
  936.    /***************************************************/
  937. typedef  struct _MCI_IMAGE_PARMS {
  938.     DWORD   dwCallback;         /* PM window handle for MCI notify message */
  939.     DWORD   dwPelFormat;        /* Format of the image data returned       */
  940.     WORD    wBitCount;          /* Number of bitsimage data returned       */
  941.     WORD    wReserved0;         /* Reserved field                          */
  942.     DWORD   dwImageCompression; /*                                         */
  943.     RECTL   rect;               /* Image area to get/set                   */
  944.     PVOID   pPelBuffer;         /* Pel data buffer                         */
  945.     DWORD   dwPelBufferHeight;  /* Number of rows in buffer                */
  946.     DWORD   dwPelBufferWidth;   /* Pels per row in buffer                  */
  947.     DWORD   dwBufLen;           /* Pel data buffer length in bytes         */
  948.  
  949. } MCI_IMAGE_PARMS;
  950. typedef MCI_IMAGE_PARMS   *LPMCI_IMAGE_PARMS;
  951.  
  952. /*********************************************************************/
  953. /* flags for the MCI_GETIMAGEPALETTE message                         */
  954. /*     0x0000XX00 are reserved for MCI_GETIMAGEPALETTE flags         */
  955. /*********************************************************************/
  956. #define MCI_FIND_BEST_REGISTERED            0x00000100L
  957. #define MCI_QUERY_REGISTERED_MAP            0x00000200L
  958. #define MCI_QUERY_REGISTERED_MAP_SIZE       0x00000400L
  959.  
  960.  
  961.    /***************************************************/
  962.    /* parameter structure for MCI_GETIMAGEPALETTE and */
  963.    /*    MCI_SETIMAGEPALETTE messages                 */
  964.    /***************************************************/
  965. typedef  struct _MCI_PALETTE_PARMS {
  966.     DWORD   dwCallback;      /* PM window handle for MCI notify message   */
  967.     WORD    wRegisteredMap;  /* Id of the palette from the registed color */
  968.                              /* map                                       */
  969.     WORD    wReserved0;      /* Reserved field                            */
  970.     DWORD   dwPalEntries;    /* size of the palette returned              */
  971.     PVOID   pPalette;        /* pointer to the palette                    */
  972. } MCI_PALETTE_PARMS;
  973. typedef MCI_PALETTE_PARMS   *LPMCI_PALETTE_PARMS;
  974.  
  975.  
  976. /*********************************************************************/
  977. /* Parameter structure for the MCI_GETTOC message                    */
  978. /*********************************************************************/
  979. typedef struct _MCI_TOC_REC {
  980.     BYTE      TrackNum;      /* Returned Track Number                          */
  981.     DWORD     dwStartAddr;   /* Starting address of the track in MMTIME format */
  982.     DWORD     dwEndAddr;     /* Ending address of the track in MMTIME format   */
  983.     BYTE      Control;       /* Track Control information                      */
  984.     WORD      wCountry;      /* Country                                        */
  985.     DWORD     dwOwner;       /* Owner                                          */
  986.     DWORD     dwSerialNum;   /* Serial Number                                  */
  987. } MCI_TOC_REC;
  988. typedef MCI_TOC_REC   *LPTOCREC;
  989.  
  990. typedef struct _MCI_TOC_PARMS {
  991.     DWORD     dwCallback;    /* PM window handle for MCI notify message    */
  992.     LPTOCREC  lpBuf;         /* Pointer to array MCI_TOC_REC structures to */
  993.                              /* be filled in by the mci device             */
  994.     DWORD     dwBufSize;     /* Size of the array                          */
  995. } MCI_TOC_PARMS;
  996. typedef MCI_TOC_PARMS   * LPMCI_TOC_PARMS;
  997.  
  998. /*********************************************************************/
  999. /* parameters for the MCI_GROUP message                              */
  1000. /*     0x00XXXX00 are reserved for MCI_GROUP flags                   */
  1001. /*********************************************************************/
  1002. #define MCI_SYNCHRONIZE                     0x00000100L
  1003. #define MCI_NOPIECEMEAL                     0x00000200L
  1004. #define MCI_GROUP_MAKE                      0x00000400L
  1005. #define MCI_GROUP_DELETE                    0x00000800L
  1006. #define MCI_GROUP_ALIAS                     0x00001000L
  1007. #define MCI_GROUP_MASTER                    0x00002000L
  1008.  
  1009. typedef struct _MCI_GROUP_PARMS {
  1010.     HWND    hwndCallback;    /* PM window handle for MCI notify message.    */
  1011.     USHORT  usGroupID;       /* GroupID                                     */
  1012.     USHORT  usReserved0;     /* RESERVED                                    */
  1013.     ULONG   ulStructLength;  /* Length of Structure in ULONGS.              */
  1014.     USHORT  usMasterID;      /* ID of Master device in Synchrounous groups. */
  1015.     USHORT  usReserved1;     /* RESERVED                                    */
  1016.     PSZ     pszGroupAlias;   /* Pointer to Alias Name.                      */
  1017.     ULONG   ulNumDevices;    /* Number of Devices in group.                 */
  1018.     PULONG  paulDeviceID;    /* Array of Device ids in the group.           */
  1019. } MCI_GROUP_PARMS;
  1020. typedef MCI_GROUP_PARMS *PMCI_GROUP_PARMS;
  1021.  
  1022.  
  1023. /*********************************************************************/
  1024. /* flags for the MCI_INFO message                                    */
  1025. /*     0x00000X00 are reserved for MCI_INFO flags                    */
  1026. /*********************************************************************/
  1027. #define MCI_INFO_PRODUCT                    0x00000100L
  1028. #define MCI_INFO_FILE                       0x00000200L
  1029.  
  1030.     /************************************************/
  1031.     /* CD Audio                MCI_INFO             */
  1032.     /************************************************/
  1033. #define MCI_CD_INFO_ID                      0x00010000L
  1034. #define MCI_CD_INFO_UPC                     0x00020000L
  1035.  
  1036.     /************************************************/
  1037.     /* Videodisc               MCI_INFO             */
  1038.     /************************************************/
  1039. #define MCI_VD_INFO_LABEL                   0x00001000L
  1040.  
  1041.     /************************************************/
  1042.     /* Digital Video           MCI_INFO             */
  1043.     /************************************************/
  1044. #define MCI_DGV_INFO_VIDEO_FILE             0x00001000L
  1045. #define MCI_DGV_INFO_IMAGE_FILE             0x00002000L
  1046. #define MCI_DGV_INFO_REGION                 0x00004000L
  1047. #define MCI_DGV_INFO_REGION_TEXT            0x00008000L
  1048. #define MCI_DGV_INFO_TEXT                   0x00010000L
  1049.  
  1050.     /************************************************/
  1051.     /* Video Overlay           MCI_INFO             */
  1052.     /************************************************/
  1053. #define MCI_OVLY_INFO_TEXT                  0x00010000L
  1054.  
  1055.  
  1056. typedef struct _MCI_INFO_PARMS {
  1057.     DWORD     dwCallback;    /* PM window handle for MCI notify message */
  1058.     LPSTR     lpstrReturn;   /* Pointer to return buffer                */
  1059.     DWORD     dwRetSize;     /* Return buffer size                      */
  1060. } MCI_INFO_PARMS;
  1061. typedef MCI_INFO_PARMS   *LPMCI_INFO_PARMS;
  1062.  
  1063. /*********************************************************************/
  1064. /* parameters and flags for the MCI_LOAD message                     */
  1065. /*     0x00000X00 are reserved for MCI_LOAD flags                    */
  1066. /*********************************************************************/
  1067. typedef struct _MCI_LOAD_PARMS {
  1068.     DWORD  dwCallback;       /* PM window handle for MCI notify message */
  1069.     LPSTR  lpstrElementName; /* File name to loads                      */
  1070. } MCI_LOAD_PARMS;
  1071. typedef MCI_LOAD_PARMS   *LPMCI_LOAD_PARMS;
  1072.  
  1073. /*********************************************************************/
  1074. /* parameters and flags for the MCI_MASTERAUDIO                      */
  1075. /*     0x000XXX00 are reserved for MCI_MASTERAUDIO  flags            */
  1076. /*********************************************************************/
  1077. #define MCI_ON                              0x00000100L
  1078. #define MCI_OFF                             0x00000200L
  1079. #define MCI_HEADPHONES                      0x00000400L
  1080. #define MCI_SPEAKERS                        0x00000800L
  1081. #define MCI_MASTERVOL                       0x00001000L
  1082. #define MCI_SAVESETTING                     0x00002000L
  1083. #define MCI_QUERYSAVEDSETTING               0x00004000L
  1084. #define MCI_QUERYCURRENTSETTING             0x00008000L
  1085.  
  1086.  
  1087. typedef struct _MCI_MASTERAUDIO_PARMS {
  1088.     DWORD   dwDummyCallback;   /* Notify not allowed for this message     */
  1089.     DWORD   dwReturn;          /* Return field for query information      */
  1090.     DWORD   dwMasterVolume;    /* Master volume field                     */
  1091. } MCI_MASTERAUDIO_PARMS;
  1092. typedef MCI_MASTERAUDIO_PARMS   *LPMCI_MASTERAUDIO_PARMS;
  1093.  
  1094. /*********************************************************************/
  1095. /* parameters and flags for the MCI_OPEN message                     */
  1096. /*     0x0000XX00 are reserved for MCI_OPEN flags                    */
  1097. /*********************************************************************/
  1098. #define MCI_OPEN_ELEMENT                    0x00000100L
  1099. #define MCI_OPEN_ALIAS                      0x00000200L
  1100. #define MCI_OPEN_ELEMENT_ID                 0x00000400L
  1101. #define MCI_OPEN_PLAYLIST                   0x00000800L
  1102. #define MCI_OPEN_TYPE_ID                    0x00001000L
  1103. #define MCI_OPEN_SHAREABLE                  0x00002000L
  1104. #define MCI_OPEN_MMIO                       0x00004000L
  1105. #define MCI_READONLY                        0x00008000L
  1106.  
  1107.     /***************************************************/
  1108.     /* parameters and flags for the MCI_OPEN message   */
  1109.     /* Digital Video, Video Overlay specific           */
  1110.     /***************************************************/
  1111. #define MCI_VID_OPEN_PARENT                 0x01000000L
  1112. #define MCI_DGV_OPEN_PARENT                 MCI_VID_OPEN_PARENT
  1113. #define MCI_OVLY_OPEN_PARENT                MCI_VID_OPEN_PARENT
  1114.  
  1115. typedef struct _MCI_OPEN_PARMS {
  1116.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  1117.     WORD    wDeviceID;       /* Device ID returned to user              */
  1118.     WORD    wReserved0;      /* Reserved                                */
  1119.     LPSTR   lpstrDeviceType; /* Device name from SYSTEM.INI             */
  1120.     LPSTR   lpstrElementName;/* Typically a file name or NULL           */
  1121.     LPSTR   lpstrAlias;      /* Optional device alias                   */
  1122. } MCI_OPEN_PARMS;
  1123. typedef MCI_OPEN_PARMS   *LPMCI_OPEN_PARMS;
  1124.  
  1125.     /**********************************************************/
  1126.     /* parameters for the AMP MCI_OPEN message                */
  1127.     /**********************************************************/
  1128. typedef struct _MCI_AMP_OPEN_PARMS {
  1129.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  1130.     WORD    wDeviceID;       /* Device ID returned to user              */
  1131.     WORD    wReserved0;      /* Reserved field                          */
  1132.     LPSTR   lpstrDeviceType; /* Device name from SYSTEM.INI             */
  1133.     LPSTR   lpstrElementName;/* Typically a file name or NULL           */
  1134.     LPSTR   lpstrAlias;      /* Optional device alias                   */
  1135.     ULONG   ulDevDataPtr;    /* Pointer to device data                  */
  1136. } MCI_AMP_OPEN_PARMS;
  1137. typedef MCI_AMP_OPEN_PARMS   *LPMCI_AMP_OPEN_PARMS;
  1138.  
  1139.     /**********************************************************/
  1140.     /* parameters for MCI_OPEN message for video devices      */
  1141.     /**********************************************************/
  1142.  
  1143. typedef  struct _MCI_VID_OPEN_PARMS {
  1144.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  1145.     WORD    wDeviceID;       /* Device ID returned to user              */
  1146.     WORD    wReserved0;      /* Reserved field                          */
  1147.     LPSTR   lpstrDeviceType; /* Device name from SYSTEM.INI             */
  1148.     LPSTR   lpstrElementName;/* Typically a file name or NULL           */
  1149.     LPSTR   lpstrAlias;      /* Optional device alias                   */
  1150.     HWND    hwndParent;      /* Parent window handle                    */
  1151. } MCI_VID_OPEN_PARMS;
  1152.  
  1153. typedef MCI_VID_OPEN_PARMS   MCI_DGV_OPEN_PARMS;
  1154. typedef MCI_DGV_OPEN_PARMS   *LPMCI_DGV_OPEN_PARMS;
  1155.  
  1156. typedef MCI_VID_OPEN_PARMS    MCI_OVLY_OPEN_PARMS;
  1157. typedef MCI_OVLY_OPEN_PARMS   *LPMCI_OVLY_OPEN_PARMS;
  1158.  
  1159.     /***************************************************/
  1160.     /* MCI_PLAY flag values for videodisc              */
  1161.     /***************************************************/
  1162. #define MCI_VD_PLAY_REVERSE                 0x00001000L
  1163. #define MCI_VD_PLAY_FAST                    0x00002000L
  1164. #define MCI_VD_PLAY_SPEED                   0x00004000L
  1165. #define MCI_VD_PLAY_SCAN                    0x00008000L
  1166. #define MCI_VD_PLAY_SLOW                    0x00010000L
  1167.  
  1168.     /***************************************************/
  1169.     /* MCI_PLAY flag values for digital video          */
  1170.     /***************************************************/
  1171. #define MCI_DGV_PLAY_REVERSE                0x00001000L
  1172. #define MCI_DGV_PLAY_FAST                   0x00002000L
  1173. #define MCI_DGV_PLAY_SPEED                  0x00004000L
  1174. #define MCI_DGV_PLAY_SCAN                   0x00008000L
  1175. #define MCI_DGV_PLAY_SLOW                   0x00010000L
  1176. #define MCI_DGV_PLAY_REPEAT                 0x00020000L
  1177.  
  1178. typedef struct _MCI_PLAY_PARMS {
  1179.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  1180.     DWORD   dwFrom;          /* Play from this position                 */
  1181.     DWORD   dwTo;            /* Play to this position                   */
  1182. } MCI_PLAY_PARMS;
  1183. typedef MCI_PLAY_PARMS   *LPMCI_PLAY_PARMS;
  1184.  
  1185. typedef struct _MCI_VD_PLAY_PARMS {
  1186.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  1187.     DWORD   dwFrom;          /* Play from this position                 */
  1188.     DWORD   dwTo;            /* Play to this position                   */
  1189.     DWORD   dwFactor;        /* Play at this speed factor               */
  1190. } MCI_VD_PLAY_PARMS;
  1191. typedef MCI_VD_PLAY_PARMS   *LPMCI_VD_PLAY_PARMS;
  1192.  
  1193. typedef  struct _MCI_DGV_PLAY_PARMS {
  1194.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  1195.     DWORD   dwFrom;          /* Play from this position                 */
  1196.     DWORD   dwTo;            /* Play to this position                   */
  1197.     DWORD   dwSpeed;         /* Specifies the play rate in frames per second */
  1198. } MCI_DGV_PLAY_PARMS;
  1199. typedef MCI_DGV_PLAY_PARMS   *LPMCI_DGV_PLAY_PARMS;
  1200.  
  1201. /*********************************************************************/
  1202. /* parameters for the MCI_PUT  message                               */
  1203. /*     0x00000X00 are reserved for MCI_PUT  flags                    */
  1204. /*********************************************************************/
  1205. #define MCI_VID_PUT_RECT                    0x00000100L
  1206. #define MCI_VID_PUT_DESTINATION             0x00000200L
  1207. #define MCI_VID_PUT_SOURCE                  0x00000400L
  1208. #define MCI_VID_PUT_WINDOW_MOVE             0x00000800L
  1209. #define MCI_VID_PUT_WINDOW_SIZE             0x00001000L
  1210.  
  1211. #define MCI_DGV_PUT_RECT                    MCI_VID_PUT_RECT
  1212. #define MCI_DGV_PUT_DESTINATION             MCI_VID_PUT_DESTINATION
  1213. #define MCI_DGV_PUT_SOURCE                  MCI_VID_PUT_SOURCE
  1214. #define MCI_DGV_PUT_WINDOW_MOVE             MCI_VID_PUT_WINDOW_MOVE
  1215. #define MCI_DGV_PUT_WINDOW_SIZE             MCI_VID_PUT_WINDOW_SIZE
  1216. #define MCI_DGV_MONITOR                     0x00010000L
  1217. #define MCI_DGV_RECORD                      0x00020000L
  1218.  
  1219. #define MCI_OVLY_PUT_RECT                   MCI_VID_PUT_RECT
  1220. #define MCI_OVLY_PUT_DESTINATION            MCI_VID_PUT_DESTINATION
  1221. #define MCI_OVLY_PUT_SOURCE                 MCI_VID_PUT_SOURCE
  1222. #define MCI_OVLY_PUT_WINDOW_MOVE            MCI_VID_PUT_WINDOW_MOVE
  1223. #define MCI_OVLY_PUT_WINDOW_SIZE            MCI_VID_PUT_WINDOW_SIZE
  1224.  
  1225.     /***************************************************/
  1226.     /* Rectangle parameters for MCI_PUT, MCI_WHERE,    */
  1227.     /* MCI_FREEZE, and MCI_UNFREEZE                    */
  1228.     /***************************************************/
  1229.  
  1230. typedef  struct _MCI_VID_RECT_PARMS {
  1231.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  1232.     RECTL   rc;              /* rectangle array specifying the offset   */
  1233.                              /* and size of a rectangle                 */
  1234. } MCI_VID_RECT_PARMS;
  1235.  
  1236. typedef MCI_VID_RECT_PARMS   MCI_DGV_RECT_PARMS;
  1237. typedef MCI_DGV_RECT_PARMS   *LPMCI_DGV_RECT_PARMS;
  1238.  
  1239. typedef MCI_VID_RECT_PARMS   MCI_OVLY_RECT_PARMS;
  1240. typedef MCI_OVLY_RECT_PARMS  *LPMCI_OVLY_RECT_PARMS;
  1241.  
  1242. /*********************************************************************/
  1243. /* parameters for the MCI_RECORD message                             */
  1244. /*     0x00000X00 are reserved for MCI_RECORD flags                  */
  1245. /*********************************************************************/
  1246. #define MCI_RECORD_INSERT                   0x00000100L
  1247. #define MCI_RECORD_OVERWRITE                0x00000200L
  1248.  
  1249. #define MCI_DGV_RECORD_RECT                 0x00000400L
  1250.  
  1251. typedef struct _MCI_RECORD_PARMS {
  1252.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  1253.     DWORD   dwFrom;          /* Record from position                    */
  1254.     DWORD   dwTo;            /* Record to position                      */
  1255. } MCI_RECORD_PARMS;
  1256. typedef MCI_RECORD_PARMS   *LPMCI_RECORD_PARMS;
  1257.  
  1258. /*********************************************************************/
  1259. /* parameters for the MCI_RELEASEDEVICE message                      */
  1260. /*     0xXXXXXX00 are reserved for MCI_RELEASEDEVICE message         */
  1261. /*********************************************************************/
  1262. #define MCI_RETURN_RESOURCE                 0x00000100L
  1263.  
  1264. /*********************************************************************/
  1265. /* parameters for the MCI_RESTORE message                            */
  1266. /*     0x0000XX00 are reserved for MCI_RESTORE flags                 */
  1267. /*     MCI_CONVERT is defined by MCI_CAPTURE message as 0x00001000L  */
  1268. /*********************************************************************/
  1269. #define MCI_RESTORE_SRC_RECT                0x00000100L
  1270. #define MCI_RESTORE_DEST_RECT               0x00000200L
  1271.  
  1272. typedef struct _MCI_RESTORE_PARMS {
  1273.     DWORD   dwCallback;      /* PM window handle for MCI notify message     */
  1274.     RECTL   SrcRect;         /* Rectangle array specifying the source       */
  1275.                              /* area to be restored                         */
  1276.     RECTL   DestRect;        /* Rectangle array specifying the destination  */
  1277.                              /* area to be restored                         */
  1278. } MCI_RESTORE_PARMS;
  1279. typedef MCI_RESTORE_PARMS   *LPMCI_RESTORE_PARMS;
  1280.  
  1281. /*********************************************************************/
  1282. /* parameters for the MCI_SAVE  message                              */
  1283. /*     0x00000X00 are reserved for MCI_SAVE  flags                   */
  1284. /*********************************************************************/
  1285. #define MCI_SAVE_FILE                       0x00000100L
  1286.  
  1287.     /*************************************************/
  1288.     /* Digital Video               MCI_SAVE          */
  1289.     /*************************************************/
  1290.  
  1291. #define MCI_DGV_SAVE_VIDEO_FILE             0x00001000L
  1292. #define MCI_DGV_SAVE_IMAGE_FILE             0x00002000L
  1293.  
  1294. typedef struct _MCI_SAVE_PARMS {
  1295.     DWORD   dwCallback;      /* PM window handle for MCI notify message     */
  1296.     DWORD   lpFileName;      /* Filename to save data to                    */
  1297. } MCI_SAVE_PARMS;
  1298. typedef MCI_SAVE_PARMS   *LPMCI_SAVE_PARMS;
  1299.  
  1300. /*********************************************************************/
  1301. /* parameters for the MCI_SEEK message                               */
  1302. /*     0x00000X00 are reserved for MCI_SEEK flags                    */
  1303. /*********************************************************************/
  1304. #define MCI_TO_START                        0x00000100L
  1305. #define MCI_TO_END                          0x00000200L
  1306.  
  1307.     /*************************************************/
  1308.     /* Digital Video               MCI_SEEK          */
  1309.     /*************************************************/
  1310.  
  1311. #define MCI_DGV_SEEK_TO_NEAREST_IFRAME      0x00100000L
  1312.  
  1313.     /*************************************************/
  1314.     /* Videodisc                   MCI_SEEK          */
  1315.     /*************************************************/
  1316. #define MCI_VD_SEEK_REVERSE                 0x00001000L
  1317.  
  1318. typedef struct _MCI_SEEK_PARMS {
  1319.     DWORD   dwCallback;      /* PM window handle for MCI notify message     */
  1320.     DWORD   dwTo;            /* Seek to this position                       */
  1321. } MCI_SEEK_PARMS;
  1322. typedef MCI_SEEK_PARMS   *LPMCI_SEEK_PARMS;
  1323.  
  1324. /*********************************************************************/
  1325. /* Flags for the MCI_SET message                                     */
  1326. /*     0x00XXXX00 are reserved for MCI_SET  flags                    */
  1327. /*********************************************************************/
  1328. #define MCI_SET_ITEM                        0x00000100L
  1329. #define MCI_SET_ON                          0x00000200L
  1330. #define MCI_SET_OFF                         0x00000400L
  1331. #define MCI_SET_VIDEO                       0x00000800L
  1332. #define MCI_SET_AUDIO                       0x00001000L
  1333. #define MCI_SET_DOOR_OPEN                   0x00002000L
  1334. #define MCI_SET_DOOR_CLOSED                 0x00004000L
  1335. #define MCI_SET_SPEED_FORMAT                0x00008000L
  1336. #define MCI_SET_TIME_FORMAT                 0x00010000L
  1337. #define MCI_SET_DOOR_LOCK                   0x00020000L
  1338. #define MCI_SET_DOOR_UNLOCK                 0x00040000L
  1339. #define MCI_SET_VOLUME                      0x00080000L
  1340. #define MCI_SET_ITEM_FOURCC                 0x00100000L
  1341. #define MCI_SET_REVERSE                     0x00200000L
  1342.  
  1343. /*******************************************************/
  1344. /* Values for the dwAudio field                        */
  1345. /*******************************************************/
  1346. #define MCI_SET_AUDIO_ALL                   0x00000000L
  1347. #define MCI_SET_AUDIO_LEFT                  0x00000001L
  1348. #define MCI_SET_AUDIO_RIGHT                 0x00000002L
  1349.  
  1350. /*******************************************************/
  1351. /* MCI_SET flags for amp/mixer                         */
  1352. /*******************************************************/
  1353. #define MCI_AMP_SET_BALANCE                 0x00100000L
  1354. #define MCI_AMP_SET_PITCH                   0x00200000L
  1355. #define MCI_AMP_SET_TREBLE                  0x00400000L
  1356. #define MCI_AMP_SET_BASS                    0x00800000L
  1357. #define MCI_AMP_SET_GAIN                    0x01000000L
  1358.  
  1359. #define MCI_AMP_SET_ALC                     0x00000004L
  1360. #define MCI_AMP_SET_CROSSOVER               0x00000010L
  1361. #define MCI_AMP_SET_LOUDNESS                0x00000020L
  1362. #define MCI_AMP_SET_MUTE                    0x00000040L
  1363. #define MCI_AMP_SET_REVERB                  0x00000080L
  1364. #define MCI_AMP_SET_STEREOENHANCE           0x00000100L
  1365. #define MCI_AMP_SET_CUSTOM1                 0x00000200L
  1366. #define MCI_AMP_SET_CUSTOM2                 0x00000400L
  1367. #define MCI_AMP_SET_CUSTOM3                 0x00000800L
  1368. #define MCI_AMP_SET_LRVOLUME                0x00001000L
  1369. #define MCI_AMP_SET_MID                     0x00020000L
  1370. #define MCI_AMP_SET_CHORUS                  0x00004000L
  1371. #define MCI_AMP_SET_VOLUME                  MCI_SET_VOLUME
  1372.  
  1373. /*******************************************************/
  1374. /* General MCI_SET item values                         */
  1375. /*******************************************************/
  1376. #define MCI_SET_MONITOR                     0x00000001L
  1377. #define MCI_SET_MONITOR_AUDIO               0x00000002L
  1378. #define MCI_SET_MONITOR_VIDEO               0x00000003L
  1379. #define MCI_SET_RECORD                      0x00000004L
  1380.  
  1381. /*******************************************************/
  1382. /* MCI_SET item values for amp/mixer                   */
  1383. /*******************************************************/
  1384. #define MCI_AMP_SET_MONITOR                 MCI_SET_MONITOR_AUDIO
  1385. #define MCI_AMP_SET_AUDIO                   0x00000008L
  1386.  
  1387.  
  1388. /*******************************************************/
  1389. /* MCI_SET flags for CDXA                              */
  1390. /*******************************************************/
  1391. #define MCI_CDXA_SET_CHANNEL                0x01000000L
  1392. #define MCI_CDXA_AUDIO_DEVICE               0x10000000L
  1393. #define MCI_CDXA_AUDIO_BUFFER               0x02000000L
  1394. #define MCI_CDXA_VIDEO_BUFFER               0x04000000L
  1395. #define MCI_CDXA_DATA_BUFFER                0x08000000L
  1396.  
  1397. /*******************************************************/
  1398. /* MCI_SET flags for videodisc                         */
  1399. /*******************************************************/
  1400. #define MCI_VD_SET_ON                       MCI_SET_ON
  1401. #define MCI_VD_SET_OFF                      MCI_SET_OFF
  1402. #define MCI_VD_SET_VIDEO                    MCI_SET_VIDEO
  1403. #define MCI_VD_SET_CHANNEL                  0x00100000L
  1404. #define MCI_VD_SET_DISPLAY                  0x00200000L
  1405.  
  1406. /*******************************************************/
  1407. /* Generic MCI_SET item values for video devices       */
  1408. /*******************************************************/
  1409. #define MCI_VID_SET_VIDEO_COMPRESSION           MCI_VID_ITEM_BASE
  1410. #define MCI_VID_SET_IMAGE_COMPRESSION           (MCI_VID_ITEM_BASE+1)
  1411. #define MCI_VID_SET_IMAGE_BITSPERPEL            (MCI_VID_ITEM_BASE+2)
  1412. #define MCI_VID_SET_IMAGE_PELFORMAT             (MCI_VID_ITEM_BASE+3)
  1413. #define MCI_VID_SET_BRIGHTNESS                  (MCI_VID_ITEM_BASE+4)
  1414. #define MCI_VID_SET_CONTRAST                    (MCI_VID_ITEM_BASE+5)
  1415. #define MCI_VID_SET_HUE                         (MCI_VID_ITEM_BASE+6)
  1416. #define MCI_VID_SET_SATURATION                  (MCI_VID_ITEM_BASE+7)
  1417. #define MCI_VID_SET_SHARPNESS                   (MCI_VID_ITEM_BASE+8)
  1418. #define MCI_VID_SET_GREYSCALE                   (MCI_VID_ITEM_BASE+9)
  1419. #define MCI_VID_SET_IMAGE_QUALITY               (MCI_VID_ITEM_BASE+10)
  1420. #define MCI_VID_SET_VIDEO_QUALITY               (MCI_VID_ITEM_BASE+11)
  1421. #define MCI_VID_SET_IMAGE_COMPRESSION_METHOD    (MCI_VID_ITEM_BASE+12)
  1422. #define MCI_VID_SET_MINIMUM_VIDEO_REFRESH_RATE  (MCI_VID_ITEM_BASE+13)
  1423. #define MCI_VID_SET_IMAGE_FILE_FORMAT           (MCI_VID_ITEM_BASE+14)
  1424. #define MCI_VID_SET_REF_INTERVAL                (MCI_VID_ITEM_BASE+15)
  1425. #define MCI_VID_SET_MAXDATARATE                 (MCI_VID_ITEM_BASE+16)
  1426. #define MCI_VID_SET_VIDEO_FILE_FORMAT           (MCI_VID_ITEM_BASE+17)
  1427.  
  1428. /*******************************************************/
  1429. /* MCI_SET item values for video overlay               */
  1430. /*******************************************************/
  1431. #define MCI_OVLY_SET_IMAGE_COMPRESSION          MCI_VID_SET_IMAGE_COMPRESSION
  1432. #define MCI_OVLY_SET_IMAGE_BITSPERPEL           MCI_VID_SET_IMAGE_BITSPERPEL
  1433. #define MCI_OVLY_SET_IMAGE_PELFORMAT            MCI_VID_SET_IMAGE_PELFORMAT
  1434. #define MCI_OVLY_SET_BRIGHTNESS                 MCI_VID_SET_BRIGHTNESS
  1435. #define MCI_OVLY_SET_CONTRAST                   MCI_VID_SET_CONTRAST
  1436. #define MCI_OVLY_SET_HUE                        MCI_VID_SET_HUE
  1437. #define MCI_OVLY_SET_SATURATION                 MCI_VID_SET_SATURATION
  1438. #define MCI_OVLY_SET_SHARPNESS                  MCI_VID_SET_SHARPNESS
  1439. #define MCI_OVLY_SET_GREYSCALE                  MCI_VID_SET_GREYSCALE
  1440. #define MCI_OVLY_SET_IMAGE_QUALITY              MCI_VID_SET_IMAGE_QUALITY
  1441. #define MCI_OVLY_SET_IMAGE_COMPRESSION_METHOD   MCI_VID_SET_IMAGE_COMPRESSION_METHOD
  1442. #define MCI_OVLY_SET_MINIMUM_VIDEO_REFRESH_RATE MCI_VID_SET_MINIMUM_VIDEO_REFRESH_RATE
  1443. #define MCI_OVLY_SET_IMAGE_FILE_FORMAT          MCI_VID_SET_IMAGE_FILE_FORMAT
  1444.  
  1445. /*******************************************************/
  1446. /* MCI_SET item values for digital video               */
  1447. /*******************************************************/
  1448. #define MCI_DGV_SET_VIDEO_COMPRESSION           MCI_VID_SET_VIDEO_COMPRESSION
  1449. #define MCI_DGV_SET_IMAGE_COMPRESSION           MCI_VID_SET_IMAGE_COMPRESSION
  1450. #define MCI_DGV_SET_IMAGE_BITSPERPEL            MCI_VID_SET_IMAGE_BITSPERPEL
  1451. #define MCI_DGV_SET_IMAGE_PELFORMAT             MCI_VID_SET_IMAGE_PELFORMAT
  1452. #define MCI_DGV_SET_BRIGHTNESS                  MCI_VID_SET_BRIGHTNESS
  1453. #define MCI_DGV_SET_CONTRAST                    MCI_VID_SET_CONTRAST
  1454. #define MCI_DGV_SET_HUE                         MCI_VID_SET_HUE
  1455. #define MCI_DGV_SET_SATURATION                  MCI_VID_SET_SATURATION
  1456. #define MCI_DGV_SET_SHARPNESS                   MCI_VID_SET_SHARPNESS
  1457. #define MCI_DGV_SET_GREYSCALE                   MCI_VID_SET_GREYSCALE
  1458. #define MCI_DGV_SET_IMAGE_QUALITY               MCI_VID_SET_IMAGE_QUALITY
  1459. #define MCI_DGV_SET_VIDEO_QUALITY               MCI_VID_SET_VIDEO_QUALITY
  1460. #define MCI_DGV_SET_IMAGE_COMPRESSION_METHOD    MCI_VID_SET_IMAGE_COMPRESSION_METHOD
  1461. #define MCI_DGV_SET_MONITOR                     MCI_SET_MONITOR
  1462. #define MCI_DGV_SET_MINIMUM_VIDEO_REFRESH_RATE  MCI_VID_SET_MINIMUM_VIDEO_REFRESH_RATE
  1463. #define MCI_DGV_SET_IMAGE_FILE_FORMAT           MCI_VID_SET_IMAGE_FILE_FORMAT
  1464. #define MCI_DGV_SET_REF_INTERVAL                MCI_VID_SET_REF_INTERVAL
  1465. #define MCI_DGV_SET_MAXDATARATE                 MCI_VID_SET_MAXDATARATE
  1466. #define MCI_DGV_SET_VIDEO_FILE_FORMAT           MCI_VID_SET_VIDEO_FILE_FORMAT
  1467.  
  1468. #define MCI_DGV_SET_AUDIO_COMPRESSION           MCI_DGV_ITEM_BASE
  1469. #define MCI_DGV_SET_AUDIO_QUALITY               (MCI_DGV_ITEM_BASE+1)
  1470. #define MCI_DGV_SET_CHANNELS                    (MCI_DGV_ITEM_BASE+2)
  1471. #define MCI_DGV_SET_BITSPERSAMPLE               (MCI_DGV_ITEM_BASE+3)
  1472. #define MCI_DGV_SET_SAMPLESPERSEC               (MCI_DGV_ITEM_BASE+4)
  1473. #define MCI_DGV_SET_FORMATTAG                   (MCI_DGV_ITEM_BASE+5)
  1474. #define MCI_DGV_SET_BLOCKALIGN                  (MCI_DGV_ITEM_BASE+6)
  1475. #define MCI_DGV_SET_AVGBYTESPERSEC              (MCI_DGV_ITEM_BASE+7)
  1476.  
  1477. #define MCI_DGV_SET_VIDEO_COMPRESSION_SUBTYPE   (MCI_DGV_ITEM_BASE+8)
  1478. #define MCI_DGV_SET_VIDEO_RECORD_RATE           (MCI_DGV_ITEM_BASE+9)
  1479. #define MCI_DGV_SET_VIDEO_RECORD_FRAME_DURATION (MCI_DGV_ITEM_BASE+10)
  1480. #define MCI_DGV_SET_RECORD_AUDIO                (MCI_DGV_ITEM_BASE+11)
  1481. #define MCI_DGV_SET_TRANSPARENT_COLOR           (MCI_DGV_ITEM_BASE+12)
  1482. #define MCI_DGV_SET_GRAPHIC_TRANSPARENT_COLOR   (MCI_DGV_ITEM_BASE+12)
  1483. #define MCI_DGV_SET_AUDIOSYNC                   (MCI_DGV_ITEM_BASE+13)
  1484. #define MCI_DGV_SET_VIDEO_TRANSPARENT_COLOR     (MCI_DGV_ITEM_BASE+14)
  1485.  
  1486. /*******************************************************/
  1487. /* Video file format                                   */
  1488. /*******************************************************/
  1489. #define MCI_VID_FILE_FORMAT_AVI       0x20495641L
  1490.  
  1491. /*******************************************************/
  1492. /* Audio/video/image compression types                 */
  1493. /*******************************************************/
  1494. #define MCI_AUD_COMP_ADPCM4          0x00000001L
  1495. #define MCI_AUD_COMP_PCM8            0x00000002L
  1496.  
  1497. #define MCI_VID_COMP_RTV_2_0         0x00000101L
  1498. #define MCI_VID_COMP_RTV_2_1         0x00000102L
  1499. #define MCI_VID_COMP_ULTI            0x49544C55L
  1500. #define MCI_VID_COMP_RT21            0x31325452L
  1501. #define MCI_VID_COMP_NONE            0x20424944L   /* This is 'DIB ' now.    */
  1502.  
  1503. #define MCI_IMG_COMP_NONE            0x00000201L
  1504. #define MCI_IMG_COMP_PIC9_1_0        0x00000202L
  1505. #define MCI_IMG_COMP_PIC16_1_0       0x00000203L
  1506. #define MCI_IMG_COMP_JPEG9           0x00000204L
  1507. #define MCI_IMG_COMP_JPEG9_1_0       MCI_IMG_COMP_JPEG9
  1508. #define MCI_IMG_COMP_BMP_RLE4        0x00000205L
  1509. #define MCI_IMG_COMP_BMP_RLE8        0x00000206L
  1510. #define MCI_IMG_COMP_JPEGN           0x00000207L
  1511.  
  1512. /*******************************************************/
  1513. /* PEL Formats (video/image)                           */
  1514. /*******************************************************/
  1515. #define MCI_VID_PALETTE              0x00000001L
  1516. #define MCI_VID_RGB                  0x00000002L
  1517. #define MCI_VID_YUV                  0x00000003L
  1518.  
  1519. #define MCI_IMG_PALETTE              MCI_VID_PALETTE
  1520. #define MCI_IMG_RGB                  MCI_VID_RGB
  1521. #define MCI_IMG_YUV                  MCI_VID_YUV
  1522.  
  1523.  
  1524. /*******************************************************/
  1525. /* Audio/video/image quality levels                    */
  1526. /*******************************************************/
  1527. #define MCI_AUD_QUALITY_HIGH         0x00000001L
  1528. #define MCI_AUD_QUALITY_MED          0x00000002L
  1529. #define MCI_AUD_QUALITY_LOW          0x00000003L
  1530.  
  1531. #define MCI_VID_QUALITY_HIGH         0x00000101L
  1532. #define MCI_VID_QUALITY_MED          0x00000102L
  1533. #define MCI_VID_QUALITY_LOW          0x00000103L
  1534. #define MCI_VID_QUALITY_BEST         MCI_VID_QUALITY_HIGH
  1535. #define MCI_VID_QUALITY_CDROM        MCI_VID_QUALITY_MED
  1536. #define MCI_VID_QUALITY_COMPACT      MCI_VID_QUALITY_LOW
  1537. #define MCI_VID_QUALITY_BETTER       MCI_VID_QUALITY_MED
  1538. #define MCI_VID_QUALITY_GOOD         MCI_VID_QUALITY_LOW
  1539.  
  1540. #define MCI_IMG_QUALITY_HIGH         0x00000201L
  1541. #define MCI_IMG_QUALITY_MED          0x00000202L
  1542. #define MCI_IMG_QUALITY_LOW          0x00000203L
  1543.  
  1544. /*******************************************************/
  1545. /* MCI_SET flags for wave audio                        */
  1546. /*******************************************************/
  1547. #define MCI_WAVE_SET_SAMPLESPERSEC          0x01000000L
  1548. #define MCI_WAVE_SET_AVGBYTESPERSEC         0x02000000L
  1549. #define MCI_WAVE_SET_BLOCKALIGN             0x04000000L
  1550. #define MCI_WAVE_SET_FORMATTAG              0x08000000L
  1551. #define MCI_WAVE_SET_CHANNELS               0x10000000L
  1552. #define MCI_WAVE_SET_BITSPERSAMPLE          0x80000000L
  1553.  
  1554. /*******************************************************/
  1555. /* Wave format tag defines                             */
  1556. /*******************************************************/
  1557. #define MCI_WAVE_FORMAT_PCM                 DATATYPE_WAVEFORM
  1558. #define MCI_WAVE_FORMAT_ADPCM               0x0002L
  1559. #define MCI_WAVE_FORMAT_IBM_CVSD            0x0005L
  1560. #define MCI_WAVE_FORMAT_ALAW                DATATYPE_RIFF_ALAW
  1561. #define MCI_WAVE_FORMAT_MULAW               DATATYPE_RIFF_MULAW
  1562. #define MCI_WAVE_FORMAT_OKI_ADPCM           0x0010L
  1563. #define MCI_WAVE_FORMAT_DVI_ADPCM           0x0011L
  1564. #define MCI_WAVE_FORMAT_DIGISTD             0x0015L
  1565. #define MCI_WAVE_FORMAT_DIGIFIX             0x0016L
  1566. #define MCI_WAVE_FORMAT_AVC_ADPCM           DATATYPE_ADPCM_AVC
  1567. #define MCI_WAVE_FORMAT_IBM_ADPCM           DATATYPE_ADPCM_AVC
  1568. #define MCI_WAVE_FORMAT_IBM_MULAW           DATATYPE_MULAW
  1569. #define MCI_WAVE_FORMAT_IBM_ALAW            DATATYPE_ALAW
  1570. #define MCI_WAVE_FORMAT_CT_ADPCM            DATATYPE_CT_ADPCM
  1571. #define MCI_WAVE_FORMAT_MPEG1               DATATYPE_MPEG1AUDIO
  1572.  
  1573. /*******************************************************/
  1574. /* MCI_SET flags for sequencer                         */
  1575. /*******************************************************/
  1576. #define MCI_SEQ_SET_TEMPO                   0x00100000L
  1577. #define MCI_SEQ_SET_PORT                    0x00200000L
  1578. #define MCI_SEQ_ENABLE_PORT_MAPPER          0x00400000L
  1579. #define MCI_SEQ_DISABLE_PORT_MAPPER         0x00800000L
  1580. #define MCI_SEQ_SET_OFFSET                  0x01000000L
  1581. #define MCI_SEQ_SET_MASTER                  0x02000000L
  1582. #define MCI_SEQ_SET_SLAVE                   0x04000000L
  1583.  
  1584.    /**********************************************/
  1585.    /* SEQ time formats                           */
  1586.    /**********************************************/
  1587.    #define MCI_SEQ_SET_SMPTE_24             0x00000100L
  1588.    #define MCI_SEQ_SET_SMPTE_25             0x00000200L
  1589.    #define MCI_SEQ_SET_SMPTE_30             0x00000300L
  1590.    #define MCI_SEQ_SET_SMPTE_30DROP         0x00000400L
  1591.    #define MCI_SEQ_SET_SONGPTR              0x00000500L
  1592.  
  1593.    /**********************************************/
  1594.    /* SEQ synchronization types                  */
  1595.    /**********************************************/
  1596.    #define MCI_SEQ_MIDI                     0x00000001L
  1597.    #define MCI_SEQ_SMPTE                    0x00000002L
  1598.    #define MCI_SEQ_FILE                     0x00000003L
  1599.    #define MCI_SEQ_NONE                     0x00000004L
  1600.  
  1601.    /**********************************************/
  1602.    /* SEQ PORT TYPES                             */
  1603.    /**********************************************/
  1604.    #define MCI_SET_NONE                     0x10000000L
  1605.    #define MIDI_MAPPER                      0x20000000L
  1606.    #define MCI_MIDI_MAPPER                  MIDI_MAPPER
  1607.  
  1608. typedef struct _MCI_SET_PARMS {
  1609.     DWORD   dwCallback;      /* PM window handle for MCI notify message        */
  1610.     DWORD   dwTimeFormat;    /* Time format to be used by the device           */
  1611.     DWORD   dwSpeedFormat;   /* Speed format used by this device               */
  1612.     DWORD   dwAudio;         /* Channel number for this operation              */
  1613.                              /* (MCI_SET_AUDIO_LEFT, MCI_SET_AUDIO_RIGHT,      */
  1614.                              /*  MCI_SET_AUDIO_ALL)                            */
  1615.     DWORD   dwLevel;         /* Volume, treble or bass level as % of max.      */
  1616.     DWORD   dwOver;          /* Delay time for vectored change in milliseconds */
  1617.     DWORD   dwItem;          /* Item field for set item flags                  */
  1618.     DWORD   dwValue;         /* Value associated with item flag                */
  1619. } MCI_SET_PARMS;
  1620. typedef MCI_SET_PARMS       *LPMCI_SET_PARMS;
  1621.  
  1622. typedef MCI_SET_PARMS       MCI_AMP_SET_PARMS;
  1623. typedef MCI_AMP_SET_PARMS   *LPMCI_AMP_SET_PARMS;
  1624.  
  1625. typedef MCI_SET_PARMS       MCI_DGV_SET_PARMS;
  1626. typedef MCI_DGV_SET_PARMS   *LPMCI_DGV_SET_PARMS;
  1627.  
  1628. typedef MCI_SET_PARMS       MCI_OVLY_SET_PARMS;
  1629. typedef MCI_OVLY_SET_PARMS  *LPMCI_OVLY_SET_PARMS;
  1630.  
  1631. typedef struct _MCI_CDXA_SET_PARMS {
  1632.     DWORD   dwCallback;      /* PM window handle for MCI notify message        */
  1633.     DWORD   dwTimeFormat;    /* Time format to be used by the device           */
  1634.     DWORD   dwSpeedFormat;   /* Speed format used by this device               */
  1635.     DWORD   dwAudio;         /* Channel number for this operation              */
  1636.                              /* (MCI_SET_AUDIO_LEFT, MCI_SET_AUDIO_RIGHT,      */
  1637.                              /*  MCI_SET_AUDIO_ALL)                            */
  1638.     DWORD   dwLevel;         /* Volume, treble or bass level as % of max.      */
  1639.     DWORD   dwOver;          /* Delay time for vectored change in milliseconds */
  1640.     DWORD   dwItem;          /* Item field for set item flags                  */
  1641.     DWORD   dwValue;         /* Value associated with item flag                */
  1642.     DWORD   dwChannel;       /* Channel number                                 */
  1643.     PVOID   pPlayList;       /* Pointer to play list                           */
  1644.     DWORD   dwPlayListSize;  /* Play list size                                 */
  1645. } MCI_CDXA_SET_PARMS;
  1646. typedef MCI_CDXA_SET_PARMS   *LPMCI_CDXA_SET_PARMS;
  1647.  
  1648. typedef struct _MCI_VD_SET_PARMS {
  1649.     DWORD   dwCallback;      /* PM window handle for MCI notify message        */
  1650.     DWORD   dwTimeFormat;    /* Time format to be used by the device           */
  1651.     DWORD   dwSpeedFormat;   /* Speed format used by this device               */
  1652.     DWORD   dwAudio;         /* Channel number for this operation              */
  1653.                              /* (MCI_SET_AUDIO_LEFT, MCI_SET_AUDIO_RIGHT,      */
  1654.                              /*  MCI_SET_AUDIO_ALL)                            */
  1655.     DWORD   dwLevel;         /* Volume, treble or bass level as % of max.      */
  1656.     DWORD   dwOver;          /* Delay time for vectored change in milliseconds */
  1657.     DWORD   dwItem;          /* Item field for set item flags                  */
  1658.     DWORD   dwValue;         /* Value associated with item flag                */
  1659.     DWORD   dwChannel;       /* Videodisc channel                              */
  1660. } MCI_VD_SET_PARMS;
  1661. typedef MCI_VD_SET_PARMS   *LPMCI_VD_SET_PARMS;
  1662.  
  1663. typedef struct _MCI_WAVE_SET_PARMS {
  1664.     DWORD   dwCallback;      /* PM window handle for MCI notify message        */
  1665.     DWORD   dwTimeFormat;    /* Time format to be used by the device           */
  1666.     DWORD   dwSpeedFormat;   /* Speed format used by this device               */
  1667.     DWORD   dwAudio;         /* Channel number for this operation              */
  1668.                              /* (MCI_SET_AUDIO_LEFT, MCI_SET_AUDIO_RIGHT,      */
  1669.                              /*  MCI_SET_AUDIO_ALL)                            */
  1670.     DWORD   dwLevel;         /* Volume, trebble or bass level as % of max.     */
  1671.     DWORD   dwOver;          /* Delay time for vectored change in milliseconds */
  1672.     DWORD   dwItem;          /* Item field for set item flags                  */
  1673.     DWORD   dwValue;         /* Value associated with item flag                */
  1674.     WORD    wInput;          /* Channel for input                              */
  1675.     WORD    wReserved0;      /* Reserved field                                 */
  1676.     WORD    wOutput;         /* Channel for output                             */
  1677.     WORD    wReserved1;      /* Reserved field                                 */
  1678.     WORD    wFormatTag;      /* Format tag                                     */
  1679.     WORD    wReserved2;      /* Reserved field                                 */
  1680.     WORD    nChannels;       /* mono(1) or stereo(2)                           */
  1681.     WORD    wReserved3;      /* Reserved field                                 */
  1682.     DWORD   nSamplesPerSec;  /* Samples per seconds                            */
  1683.     DWORD   nAvgBytesPerSec; /* Bytes per seconds                              */
  1684.     WORD    nBlockAlign;     /* Block alignment of data                        */
  1685.     WORD    wReserved4;      /* Reserved field                                 */
  1686.     WORD    wBitsPerSample;  /* Bits per seconds                               */
  1687.     WORD    wReserved5;      /* Reserved field                                 */
  1688. } MCI_WAVE_SET_PARMS;
  1689. typedef MCI_WAVE_SET_PARMS   *LPMCI_WAVE_SET_PARMS;
  1690.  
  1691. typedef struct _MCI_SEQ_SET_PARMS {
  1692.     DWORD   dwCallback;      /* PM window handle for MCI notify message        */
  1693.     DWORD   dwTimeFormat;    /* Time format to be used by the device           */
  1694.     DWORD   dwSpeedFormat;   /* Speed format used by this device               */
  1695.     DWORD   dwAudio;         /* Channel number for this operation              */
  1696.                              /* (MCI_SET_AUDIO_LEFT, MCI_SET_AUDIO_RIGHT,      */
  1697.                              /*  MCI_SET_AUDIO_ALL)                            */
  1698.     DWORD   dwLevel;         /* Volume, trebble or bass level as % of max.     */
  1699.     DWORD   dwOver;          /* Delay time for vectored change in milliseconds */
  1700.     DWORD   dwItem;          /* Item field for set item flags                  */
  1701.     DWORD   dwValue;         /* Value associated with item flag                */
  1702.     DWORD   dwTempo;         /* Specified the tempo                            */
  1703.     DWORD   dwPort;          /* Output port                                    */
  1704.     DWORD   dwSlave;         /* Unused field                                   */
  1705.     DWORD   dwMaster;        /* Unused field                                   */
  1706.     DWORD   dwOffset;        /* Specified the data offset                      */
  1707. } MCI_SEQ_SET_PARMS;
  1708. typedef MCI_SEQ_SET_PARMS   *LPMCI_SEQ_SET_PARMS;
  1709.  
  1710.  
  1711. /*********************************************************************/
  1712. /* parameters for the MCI_SET_CUEPOINT message                       */
  1713. /*     0x00000x00 are reserved for MCI_SET_CUEPOINT flags            */
  1714. /*********************************************************************/
  1715. #define MCI_SET_CUEPOINT_ON                 0x00000100L
  1716. #define MCI_SET_CUEPOINT_OFF                0x00000200L
  1717.  
  1718. typedef struct _MCI_CUEPOINT_PARMS {
  1719.     DWORD   dwCallback;      /* PM window handle for MCI notify message        */
  1720.     DWORD   dwCuepoint;      /* Specifies the cuepoint location                */
  1721.     WORD    wUserParm;       /* User parmameter returned on cuepoint           */
  1722.                              /* notify message                                 */
  1723.     WORD    wReserved0;      /* Reserved field                                 */
  1724. } MCI_CUEPOINT_PARMS;
  1725. typedef MCI_CUEPOINT_PARMS   *LPMCI_CUEPOINT_PARMS;
  1726.  
  1727. /*********************************************************************/
  1728. /* parameters for the MCI_SETIMAGEPALETTE message                    */
  1729. /*     0x000XXX00 are reserved for MCI_SETIMAGEPALETTE flags         */
  1730. /*********************************************************************/
  1731. #define MCI_SET_REGISTERED                  0x00000100L
  1732.  
  1733. /*********************************************************************/
  1734. /* flags and parameter structure for the MCI_SET_POSITION_ADVISE msg */
  1735. /*     0x00000X00 are reserved for MCI_SET_POSITION_ADVISE flags     */
  1736. /*********************************************************************/
  1737. #define MCI_SET_POSITION_ADVISE_ON          0x00000100L
  1738. #define MCI_SET_POSITION_ADVISE_OFF         0x00000200L
  1739.  
  1740. typedef struct _MCI_POSITION_PARMS {
  1741.     DWORD   dwCallback;      /* PM window handle for MCI notify message        */
  1742.     DWORD   dwUnits;         /* Specifies position change notifiication        */
  1743.                              /* granularity                                    */
  1744.     WORD    wUserParm;       /* User parameter returned on position change     */
  1745.                              /* notification message.                          */
  1746.     WORD    Reserved0;       /* Reserved field                                 */
  1747.     DWORD   Reserved1;       /* Reserved field                                 */
  1748.     } MCI_POSITION_PARMS;
  1749. typedef MCI_POSITION_PARMS   *LPMCI_POSITION_PARMS;
  1750.  
  1751. /*********************************************************************/
  1752. /* parameter structure for the MCI_SET_SYNC_OFFSET message           */
  1753. /*********************************************************************/
  1754. typedef struct _MCI_SYNC_OFFSET_PARMS {
  1755.     DWORD   dwCallback;      /* PM window handle for MCI notify message        */
  1756.     DWORD   dwOffset;        /* Specifies the device media position offset     */
  1757.                              /* in the currently specified device units.       */
  1758. } MCI_SYNC_OFFSET_PARMS;
  1759. typedef MCI_SYNC_OFFSET_PARMS   *LPMCI_SYNC_OFFSET_PARMS;
  1760.  
  1761. /*********************************************************************/
  1762. /* flags for the MCI_SPIN message                                    */
  1763. /*     0x00000X00 are reserved for MCI_SPIN flags                    */
  1764. /*********************************************************************/
  1765. #define MCI_SPIN_UP                         0x00000100L
  1766. #define MCI_SPIN_DOWN                       0x00000200L
  1767.  
  1768. /*********************************************************************/
  1769. /* MCI_STATUS message flags                                          */
  1770. /*     0x000XXX00 are reserved for MCI_STATUS flags                  */
  1771. /*     MCI_VOLUME and MCI_VOLUME_DELAY are 0x00000100 and 0x00000200 */
  1772. /*********************************************************************/
  1773. #define MCI_STATUS_ITEM                     0x00000100L
  1774. #define MCI_STATUS_START                    0x00000200L
  1775. #define MCI_STATUS_CONNECTOR                0x00000400L
  1776.  
  1777. /*************************************************/
  1778. /* General MCI_STATUS item values                */
  1779. /*************************************************/
  1780. #define MCI_STATUS_CURRENT_TRACK            0x00000001L
  1781. #define MCI_STATUS_LENGTH                   0x00000002L
  1782. #define MCI_STATUS_MODE                     0x00000003L
  1783. #define MCI_STATUS_NUMBER_OF_TRACKS         0x00000004L
  1784. #define MCI_STATUS_POSITION                 0x00000005L
  1785. #define MCI_STATUS_POSITION_IN_TRACK        0x00000006L
  1786. #define MCI_STATUS_MEDIA_PRESENT            0x00000007L
  1787. #define MCI_STATUS_VOLUME                   0x00000008L
  1788. #define MCI_STATUS_READY                    0x00000009L
  1789. #define MCI_STATUS_TIME_FORMAT              0x0000000AL
  1790. #define MCI_STATUS_SPEED_FORMAT             0x0000000BL
  1791. #define MCI_STATUS_MONITOR                  0x0000000CL
  1792. #define MCI_STATUS_AUDIO                    0x0000000DL
  1793. #define MCI_STATUS_VIDEO                    0x0000000EL
  1794. #define MCI_STATUS_CLIPBOARD                0x0000000FL
  1795. #define MCI_STATUS_CAN_PASTE                0x00000010L
  1796. #define MCI_STATUS_CAN_REDO                 0x00000020L
  1797. #define MCI_STATUS_CAN_UNDO                 0x00000030L
  1798.  
  1799.    /*************************************************/
  1800.    /* dwValue field values for MCI_STATUS_AUDIO     */
  1801.    /*************************************************/
  1802. #define MCI_STATUS_AUDIO_ALL                   0x00000000L
  1803. #define MCI_STATUS_AUDIO_LEFT                  0x00000001L
  1804. #define MCI_STATUS_AUDIO_RIGHT                 0x00000002L
  1805.  
  1806. /*************************************************/
  1807. /* MCI_STATUS item values for amp/mixer          */
  1808. /*************************************************/
  1809. #define MCI_AMP_STATUS_PITCH                MCI_AMP_ITEM_BASE
  1810. #define MCI_AMP_STATUS_TREBLE               (MCI_AMP_ITEM_BASE+1)
  1811. #define MCI_AMP_STATUS_BASS                 (MCI_AMP_ITEM_BASE+2)
  1812. #define MCI_AMP_STATUS_BALANCE              (MCI_AMP_ITEM_BASE+3)
  1813. #define MCI_AMP_STATUS_GAIN                 (MCI_AMP_ITEM_BASE+4)
  1814. #define MCI_AMP_STATUS_MONITOR              (MCI_AMP_ITEM_BASE+5)
  1815. #define MCI_AMP_STATUS_MID                  (MCI_AMP_ITEM_BASE+6)
  1816. #define MCI_AMP_STATUS_VOLUME               MCI_STATUS_VOLUME
  1817. #define MCI_AMP_STATUS_LOUDNESS             (MCI_AMP_ITEM_BASE+7)
  1818. #define MCI_AMP_STATUS_CROSSOVER            (MCI_AMP_ITEM_BASE+8)
  1819. #define MCI_AMP_STATUS_REVERB               (MCI_AMP_ITEM_BASE+9)
  1820. #define MCI_AMP_STATUS_ALC                  (MCI_AMP_ITEM_BASE+10)
  1821. #define MCI_AMP_STATUS_CHORUS               (MCI_AMP_ITEM_BASE+11)
  1822. #define MCI_AMP_STATUS_CUSTOM1              (MCI_AMP_ITEM_BASE+12)
  1823. #define MCI_AMP_STATUS_CUSTOM2              (MCI_AMP_ITEM_BASE+13)
  1824. #define MCI_AMP_STATUS_CUSTOM3              (MCI_AMP_ITEM_BASE+14)
  1825. #define MCI_AMP_STATUS_MUTE                 (MCI_AMP_ITEM_BASE+15)
  1826. #define MCI_AMP_STATUS_STEREOENHANCE        (MCI_AMP_ITEM_BASE+16)
  1827.  
  1828.  
  1829. /*************************************************/
  1830. /* MCI_STATUS item values for cd audio           */
  1831. /*************************************************/
  1832. #define MCI_CD_STATUS_TRACK_TYPE            MCI_CD_ITEM_BASE
  1833. #define MCI_CD_STATUS_TRACK_COPYPERMITTED   (MCI_CD_ITEM_BASE+1)
  1834. #define MCI_CD_STATUS_TRACK_CHANNELS        (MCI_CD_ITEM_BASE+2)
  1835. #define MCI_CD_STATUS_TRACK_PREEMPHASIS     (MCI_CD_ITEM_BASE+3)
  1836.  
  1837.     /************************************************/
  1838.     /* return values for CD MCI_STATUS message with */
  1839.     /*   MCI_CD_STATUS_TRACK_TYPE set               */
  1840.     /************************************************/
  1841. #define MCI_CD_TRACK_AUDIO                  0x00000001L
  1842. #define MCI_CD_TRACK_DATA                   0x00000002L
  1843. #define MCI_CD_TRACK_OTHER                  0x00000003L
  1844.  
  1845. /*************************************************/
  1846. /* MCI_STATUS item values for CDXA               */
  1847. /*************************************************/
  1848. #define MCI_CDXA_STATUS_CHANNEL             MCI_CDXA_ITEM_BASE
  1849.  
  1850.     /************************************************/
  1851.     /*returned from call for MCI_CDXA_STATUS_CHANNEL*/
  1852.     /************************************************/
  1853. #define MCI_CDXA_NONE                       0x00000000L
  1854.  
  1855.  
  1856. /*************************************************/
  1857. /* MCI_STATUS item values for sequencer          */
  1858. /*************************************************/
  1859. #define MCI_SEQ_STATUS_TEMPO                MCI_SEQ_ITEM_BASE
  1860. #define MCI_SEQ_STATUS_OFFSET               (MCI_SEQ_ITEM_BASE+1)
  1861. #define MCI_SEQ_STATUS_DIVTYPE              (MCI_SEQ_ITEM_BASE+2)
  1862. #define MCI_SEQ_STATUS_MASTER               (MCI_SEQ_ITEM_BASE+3)
  1863. #define MCI_SEQ_STATUS_PORT                 (MCI_SEQ_ITEM_BASE+4)
  1864. #define MCI_SEQ_STATUS_SLAVE                (MCI_SEQ_ITEM_BASE+5)
  1865.  
  1866.    /**********************************************/
  1867.    /* Return value for current division type     */
  1868.    /**********************************************/
  1869. #define MCI_SEQ_DIV_PPQN                    0x00000001L
  1870. #define MCI_SEQ_DIV_SMPTE_24                0x00000002L
  1871. #define MCI_SEQ_DIV_SMPTE_25                0x00000003L
  1872. #define MCI_SEQ_DIV_SMPTE_30DROP            0x00000004L
  1873. #define MCI_SEQ_DIV_SMPTE_30                0x00000005L
  1874.  
  1875.    /*************************************************/
  1876.    /* MCI_STATUS items for videodisc                */
  1877.    /*************************************************/
  1878. #define MCI_VD_STATUS_SPEED                 MCI_VD_ITEM_BASE
  1879. #define MCI_VD_STATUS_FORWARD               (MCI_VD_ITEM_BASE+1)
  1880. #define MCI_VD_MEDIA_TYPE                   (MCI_VD_ITEM_BASE+2)
  1881. #define MCI_VD_STATUS_SIDE                  (MCI_VD_ITEM_BASE+3)
  1882. #define MCI_VD_STATUS_DISC_SIZE             (MCI_VD_ITEM_BASE+4)
  1883.  
  1884.     /***********************************************/
  1885.     /* return values for videodisc status command  */
  1886.     /***********************************************/
  1887. #define MCI_VD_SPEED_NORMAL                 0x00000000L
  1888. #define MCI_VD_SPEED_FAST                   0x00000001L
  1889. #define MCI_VD_SPEED_SLOW                   0x00000002L
  1890.  
  1891. /*************************************************/
  1892. /* MCI_STATUS items for wave audio               */
  1893. /*************************************************/
  1894. #define MCI_WAVE_STATUS_LEVEL               MCI_WAVE_ITEM_BASE
  1895. #define MCI_WAVE_STATUS_SAMPLESPERSEC       (MCI_WAVE_ITEM_BASE+1)
  1896. #define MCI_WAVE_STATUS_AVGBYTESPERSEC      (MCI_WAVE_ITEM_BASE+2)
  1897. #define MCI_WAVE_STATUS_BLOCKALIGN          (MCI_WAVE_ITEM_BASE+3)
  1898. #define MCI_WAVE_STATUS_FORMATTAG           (MCI_WAVE_ITEM_BASE+4)
  1899. #define MCI_WAVE_STATUS_CHANNELS            (MCI_WAVE_ITEM_BASE+5)
  1900. #define MCI_WAVE_STATUS_BITSPERSAMPLE       (MCI_WAVE_ITEM_BASE+6)
  1901.  
  1902. /*************************************************/
  1903. /* Common video MCI_STATUS items                 */
  1904. /*************************************************/
  1905. #define MCI_VID_STATUS_HWND                 MCI_VID_ITEM_BASE
  1906. #define MCI_VID_STATUS_AUDIO_COMPRESSION    (MCI_VID_ITEM_BASE+1)
  1907. #define MCI_VID_STATUS_VIDEO_COMPRESSION    (MCI_VID_ITEM_BASE+2)
  1908. #define MCI_VID_STATUS_IMAGE_COMPRESSION    (MCI_VID_ITEM_BASE+3)
  1909. #define MCI_VID_STATUS_AUDIO_QUALITY        (MCI_VID_ITEM_BASE+4)
  1910. #define MCI_VID_STATUS_VIDEO_QUALITY        (MCI_VID_ITEM_BASE+5)
  1911. #define MCI_VID_STATUS_IMAGE_QUALITY        (MCI_VID_ITEM_BASE+6)
  1912. #define MCI_VID_STATUS_IMAGE_BITSPERPEL     (MCI_VID_ITEM_BASE+7)
  1913. #define MCI_VID_STATUS_IMAGE_PELFORMAT      (MCI_VID_ITEM_BASE+8)
  1914. #define MCI_VID_STATUS_FORWARD              (MCI_VID_ITEM_BASE+9)
  1915. #define MCI_VID_STATUS_NORMAL_RATE          (MCI_VID_ITEM_BASE+10)
  1916. #define MCI_VID_STATUS_VIDEO_X_EXTENT       (MCI_VID_ITEM_BASE+11)
  1917. #define MCI_VID_STATUS_VIDEO_Y_EXTENT       (MCI_VID_ITEM_BASE+12)
  1918. #define MCI_VID_STATUS_IMAGE_X_EXTENT       (MCI_VID_ITEM_BASE+13)
  1919. #define MCI_VID_STATUS_IMAGE_Y_EXTENT       (MCI_VID_ITEM_BASE+14)
  1920. #define MCI_VID_STATUS_BRIGHTNESS           (MCI_VID_ITEM_BASE+15)
  1921. #define MCI_VID_STATUS_CONTRAST             (MCI_VID_ITEM_BASE+16)
  1922. #define MCI_VID_STATUS_HUE                  (MCI_VID_ITEM_BASE+17)
  1923. #define MCI_VID_STATUS_SATURATION           (MCI_VID_ITEM_BASE+18)
  1924. #define MCI_VID_STATUS_GREYSCALE            (MCI_VID_ITEM_BASE+19)
  1925. #define MCI_VID_STATUS_SHARPNESS            (MCI_VID_ITEM_BASE+20)
  1926. #define MCI_VID_STATUS_SPEED                (MCI_VID_ITEM_BASE+21)
  1927. #define MCI_VID_STATUS_IMAGE_FILE_FORMAT    (MCI_VID_ITEM_BASE+22)
  1928. #define MCI_VID_STATUS_TRANSPARENT_TYPE     (MCI_VID_ITEM_BASE+23)
  1929. #define MCI_VID_STATUS_REF_INTERVAL         (MCI_VID_ITEM_BASE+24)
  1930. #define MCI_VID_STATUS_MAXDATARATE          (MCI_VID_ITEM_BASE+25)
  1931. #define MCI_VID_STATUS_VIDEO_FILE_FORMAT    (MCI_VID_ITEM_BASE+26)
  1932.  
  1933.    /*************************************************/
  1934.    /* Status Transparent Type returns               */
  1935.    /* MCI_VID_PALETTE                               */
  1936.    /* MCI_VID_RGB                                   */
  1937.    /* MCI_VID_YUV                                   */
  1938.    /*************************************************/
  1939. #define MCI_VID_STATUS_TRANSPARENT_COLOR    (MCI_VID_ITEM_BASE+24)
  1940.  
  1941. /*************************************************/
  1942. /* MCI_STATUS items for digital video            */
  1943. /*************************************************/
  1944. #define MCI_DGV_STATUS_HWND                 MCI_VID_STATUS_HWND
  1945. #define MCI_DGV_STATUS_AUDIO_COMPRESSION    MCI_VID_STATUS_AUDIO_COMPRESSION
  1946. #define MCI_DGV_STATUS_VIDEO_COMPRESSION    MCI_VID_STATUS_VIDEO_COMPRESSION
  1947. #define MCI_DGV_STATUS_IMAGE_COMPRESSION    MCI_VID_STATUS_IMAGE_COMPRESSION
  1948. #define MCI_DGV_STATUS_AUDIO_QUALITY        MCI_VID_STATUS_AUDIO_QUALITY
  1949. #define MCI_DGV_STATUS_VIDEO_QUALITY        MCI_VID_STATUS_VIDEO_QUALITY
  1950. #define MCI_DGV_STATUS_IMAGE_QUALITY        MCI_VID_STATUS_IMAGE_QUALITY
  1951. #define MCI_DGV_STATUS_IMAGE_BITSPERPEL     MCI_VID_STATUS_IMAGE_BITSPERPEL
  1952. #define MCI_DGV_STATUS_IMAGE_PELFORMAT      MCI_VID_STATUS_IMAGE_PELFORMAT
  1953. #define MCI_DGV_STATUS_FORWARD              MCI_VID_STATUS_FORWARD
  1954. #define MCI_DGV_STATUS_NORMAL_RATE          MCI_VID_STATUS_NORMAL_RATE
  1955. #define MCI_DGV_STATUS_VIDEO_X_EXTENT       MCI_VID_STATUS_VIDEO_X_EXTENT
  1956. #define MCI_DGV_STATUS_VIDEO_Y_EXTENT       MCI_VID_STATUS_VIDEO_Y_EXTENT
  1957. #define MCI_DGV_STATUS_IMAGE_X_EXTENT       MCI_VID_STATUS_IMAGE_X_EXTENT
  1958. #define MCI_DGV_STATUS_IMAGE_Y_EXTENT       MCI_VID_STATUS_IMAGE_Y_EXTENT
  1959. #define MCI_DGV_STATUS_BRIGHTNESS           MCI_VID_STATUS_BRIGHTNESS
  1960. #define MCI_DGV_STATUS_CONTRAST             MCI_VID_STATUS_CONTRAST
  1961. #define MCI_DGV_STATUS_HUE                  MCI_VID_STATUS_HUE
  1962. #define MCI_DGV_STATUS_SATURATION           MCI_VID_STATUS_SATURATION
  1963. #define MCI_DGV_STATUS_SPEED                MCI_VID_STATUS_SPEED
  1964. #define MCI_DGV_STATUS_SHARPNESS            MCI_VID_STATUS_SHARPNESS
  1965. #define MCI_DGV_STATUS_REF_INTERVAL         MCI_VID_STATUS_REF_INTERVAL
  1966. #define MCI_DGV_STATUS_MAXDATARATE          MCI_VID_STATUS_MAXDATARATE
  1967. #define MCI_DGV_STATUS_VIDEO_FILE_FORMAT    MCI_VID_STATUS_VIDEO_FILE_FORMAT
  1968.  
  1969. #define MCI_DGV_STATUS_CHANNELS             (MCI_DGV_ITEM_BASE+13)
  1970. #define MCI_DGV_STATUS_BITSPERSAMPLE        (MCI_DGV_ITEM_BASE+14)
  1971. #define MCI_DGV_STATUS_SAMPLESPERSEC        (MCI_DGV_ITEM_BASE+15)
  1972. #define MCI_DGV_STATUS_FORMATTAG            (MCI_DGV_ITEM_BASE+16)
  1973. #define MCI_DGV_STATUS_BLOCKALIGN           (MCI_DGV_ITEM_BASE+17)
  1974. #define MCI_DGV_STATUS_AVGBYTESPERSEC       (MCI_DGV_ITEM_BASE+18)
  1975. #define MCI_DGV_STATUS_VIDEO_COMPRESSION_SUBTYPE   (MCI_DGV_ITEM_BASE+19)
  1976. #define MCI_DGV_STATUS_VIDEO_RECORD_RATE           (MCI_DGV_ITEM_BASE+20)
  1977. #define MCI_DGV_STATUS_VIDEO_RECORD_FRAME_DURATION (MCI_DGV_ITEM_BASE+21)
  1978. #define MCI_DGV_STATUS_RECORD_AUDIO         (MCI_DGV_ITEM_BASE+22)
  1979. #define MCI_DGV_STATUS_TRANSPARENT_COLOR    (MCI_DGV_ITEM_BASE+23)
  1980. #define MCI_DGV_STATUS_GRAPHIC_TRANSPARENT_COLOR (MCI_DGV_ITEM_BASE+23)  /* MUST BE SAME AS TRANSPARENT COLOR */
  1981. #define MCI_DGV_STATUS_HWND_MONITOR         (MCI_DGV_ITEM_BASE+24)
  1982. #define MCI_DGV_STATUS_DROPPED_FRAME_PCT    (MCI_DGV_ITEM_BASE+25)
  1983. #define MCI_DGV_STATUS_AUDIOSYNC            (MCI_DGV_ITEM_BASE+26)
  1984. #define MCI_DGV_STATUS_AUDIOSYNC_DIRECTION  (MCI_DGV_ITEM_BASE+27)
  1985. #define MCI_DGV_STATUS_VIDEO_TRANSPARENT_COLOR (MCI_DGV_ITEM_BASE+28)  /* MUST BE SAME AS TRANSPARENT COLOR */
  1986. #define MCI_DGV_STATUS_TUNER_TV_CHANNEL     (MCI_DGV_ITEM_BASE+29)
  1987. #define MCI_DGV_STATUS_TUNER_LOW_TV_CHANNEL (MCI_DGV_ITEM_BASE+30)
  1988. #define MCI_DGV_STATUS_TUNER_HIGH_TV_CHANNEL (MCI_DGV_ITEM_BASE+31)
  1989. #define MCI_DGV_STATUS_TUNER_REGION          (MCI_DGV_ITEM_BASE+32)
  1990. #define MCI_DGV_STATUS_TUNER_FINETUNE        (MCI_DGV_ITEM_BASE+33)
  1991. #define MCI_DGV_STATUS_TUNER_FREQUENCY       (MCI_DGV_ITEM_BASE+34)
  1992. #define MCI_DGV_STATUS_TUNER_AUDIO_CHANNEL   (MCI_DGV_ITEM_BASE+35)
  1993. #define MCI_DGV_STATUS_TUNER_AFC             (MCI_DGV_ITEM_BASE+36)
  1994. #define MCI_DGV_STATUS_VALID_SIGNAL          (MCI_DGV_ITEM_BASE+37)
  1995.  
  1996. /*************************************************/
  1997. /* MCI_STATUS item values for video overlay      */
  1998. /*************************************************/
  1999. #define MCI_OVLY_STATUS_HWND                 MCI_VID_STATUS_HWND
  2000. #define MCI_OVLY_STATUS_IMAGE_COMPRESSION    MCI_VID_STATUS_IMAGE_COMPRESSION
  2001. #define MCI_OVLY_STATUS_IMAGE_BITSPERPEL     MCI_VID_STATUS_IMAGE_BITSPERPEL
  2002. #define MCI_OVLY_STATUS_IMAGE_PELFORMAT      MCI_VID_STATUS_IMAGE_PELFORMAT
  2003. #define MCI_OVLY_STATUS_IMAGE_X_EXTENT       MCI_VID_STATUS_IMAGE_X_EXTENT
  2004. #define MCI_OVLY_STATUS_IMAGE_Y_EXTENT       MCI_VID_STATUS_IMAGE_Y_EXTENT
  2005. #define MCI_OVLY_STATUS_BRIGHTNESS           MCI_VID_STATUS_BRIGHTNESS
  2006. #define MCI_OVLY_STATUS_CONTRAST             MCI_VID_STATUS_CONTRAST
  2007. #define MCI_OVLY_STATUS_HUE                  MCI_VID_STATUS_HUE
  2008. #define MCI_OVLY_STATUS_SATURATION           MCI_VID_STATUS_SATURATION
  2009. #define MCI_OVLY_STATUS_GREYSCALE            MCI_VID_STATUS_GREYSCALE
  2010. #define MCI_OVLY_STATUS_IMAGE_QUALITY        MCI_VID_STATUS_IMAGE_QUALITY
  2011. #define MCI_OVLY_STATUS_SHARPNESS            MCI_VID_STATUS_SHARPNESS
  2012. #define MCI_OVLY_STATUS_IMAGE_FILE_FORMAT    MCI_VID_STATUS_IMAGE_FILE_FORMAT
  2013. #define MCI_OVLY_STATUS_TRANSPARENT_TYPE     MCI_VID_STATUS_TRANSPARENT_TYPE
  2014. #define MCI_OVLY_STATUS_TRANSPARENT_COLOR    MCI_VID_STATUS_TRANSPARENT_COLOR
  2015.  
  2016.    /*************************************************/
  2017.    /* Status Mode return values                     */
  2018.    /*************************************************/
  2019. #define MCI_MODE_NOT_READY                  0x00000001L
  2020. #define MCI_MODE_PAUSE                      0x00000002L
  2021. #define MCI_MODE_PLAY                       0x00000003L
  2022. #define MCI_MODE_STOP                       0x00000004L
  2023. #define MCI_MODE_RECORD                     0x00000005L
  2024. #define MCI_MODE_SEEK                       0x00000006L
  2025.  
  2026.    /*************************************************/
  2027.    /* Status Direction return values                */
  2028.    /*************************************************/
  2029. #define MCI_FORWARD                         0x00000000L
  2030. #define MCI_REVERSE                         0x00000001L
  2031.  
  2032. typedef struct _MCI_STATUS_PARMS {
  2033.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  2034.     DWORD   dwReturn;        /* Return field                            */
  2035.     DWORD   dwItem;          /* Item field for STATUS item to query     */
  2036.     DWORD   dwValue;         /* Status value field (this used to be)    */
  2037.                              /*  dwTrack but was changed in Rel 1.1     */
  2038.                              /*  to extend the status structure.        */
  2039.                              /*  See the programming reference on when  */
  2040.                              /*  dwValue is used and how...             */
  2041. } MCI_STATUS_PARMS;
  2042. typedef MCI_STATUS_PARMS   *LPMCI_STATUS_PARMS;
  2043.  
  2044.  
  2045. typedef struct _MCI_CDXA_STATUS_PARMS {
  2046.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  2047.     DWORD   dwReturn;        /* Return field                            */
  2048.     DWORD   dwItem;          /* Item field for STATUS item to query     */
  2049.     DWORD   dwValue;         /* Status value field (this used to be)    */
  2050.                              /*  dwTrack but was changed in Rel 1.1     */
  2051.                              /*  to extend the status structure.        */
  2052.                              /*  See the programming reference on when  */
  2053.                              /*  dwValue is used and how...             */
  2054.     DWORD   dwChannel;       /* Channel                                 */
  2055. } MCI_CDXA_STATUS_PARMS;
  2056. typedef MCI_CDXA_STATUS_PARMS   *LPMCI_CDXA_STATUS_PARMS;
  2057.  
  2058. /*********************************************************************/
  2059. /* flags and parameter structure for the MCI_STEP message            */
  2060. /*     0x00000X00 are reserved for MCI_STEP flags                    */
  2061. /*********************************************************************/
  2062. #define MCI_STEP_FRAMES                     0x00000100L
  2063. #define MCI_STEP_REVERSE                    0x00000200L
  2064.  
  2065. typedef struct _MCI_STEP_PARMS {
  2066.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  2067.     DWORD   dwStep;          /* amount to step in current time format   */
  2068. } MCI_STEP_PARMS;
  2069. typedef MCI_STEP_PARMS   *LPMCI_STEP_PARMS;
  2070.  
  2071. /*********************************************************************/
  2072. /* flags for the MCI_SYSINFO message                                 */
  2073. /*     0xXXXXXX00 are reserved for MCI_SYSINFO flags                 */
  2074. /*********************************************************************/
  2075. #define MCI_SYSINFO_QUANTITY                0x00000100L
  2076. #define MCI_SYSINFO_OPEN                    0x00000200L
  2077. #define MCI_SYSINFO_NAME                    0x00000400L
  2078. #define MCI_SYSINFO_INSTALLNAME             0x00000800L
  2079. #define MCI_SYSINFO_ITEM                    0x00001000L
  2080. #define MCI_SYSINFO_INI_LOCK                0x00002000L
  2081.  
  2082.     /********************************************************/
  2083.     /* Extended SYSINFO functions                           */
  2084.     /********************************************************/
  2085.     #define MCI_SYSINFO_INSTALL_DRIVER      0x00000001L
  2086.     #define MCI_SYSINFO_QUERY_DRIVER        0x00000002L
  2087.     #define MCI_SYSINFO_DELETE_DRIVER       0x00000004L
  2088.     #define MCI_SYSINFO_SET_PARAMS          0x00000008L
  2089.     #define MCI_SYSINFO_QUERY_PARAMS        0x00000010L
  2090.     #define MCI_SYSINFO_SET_CONNECTORS      0x00000020L
  2091.     #define MCI_SYSINFO_QUERY_CONNECTORS    0x00000040L
  2092.     #define MCI_SYSINFO_SET_EXTENSIONS      0x00000080L
  2093.     #define MCI_SYSINFO_QUERY_EXTENSIONS    0x00000100L
  2094.     #define MCI_SYSINFO_SET_ALIAS           0x00000200L
  2095.     #define MCI_SYSINFO_QUERY_NAMES         0x00000400L
  2096.     #define MCI_SYSINFO_SET_DEFAULT         0x00000800L
  2097.     #define MCI_SYSINFO_QUERY_DEFAULT       0x00001000L
  2098.     #define MCI_SYSINFO_SET_TYPES           0x00002000L
  2099.     #define MCI_SYSINFO_QUERY_TYPES         0x00004000L
  2100.  
  2101.     /********************************************************/
  2102.     /* Device Flags                                         */
  2103.     /********************************************************/
  2104.     #define MCI_SYSINFO_DEV_CONTROLLABLE    0x00000001L
  2105.     #define MCI_SYSINFO_DEV_NONCONTROLLABLE 0x00000002L
  2106.     #define MCI_SYSINFO_DEVICESETTINGS      0x00000004L
  2107.  
  2108. /*********************************************************************/
  2109. /* parameter structures for the MCI_SYSINFO message                  */
  2110. /*********************************************************************/
  2111. typedef struct _MCI_SYSINFO_PARMS {
  2112.     DWORD   dwDummyCallback;   /* NOTIFY not allowed for SYSINFO          */
  2113.     LPSTR   lpstrReturn;       /* Pointer to return buffer                */
  2114.     DWORD   dwRetSize;         /* Return buffer size                      */
  2115.     DWORD   dwNumber;          /* Ordinal Number                          */
  2116.     WORD    wDeviceType;       /* MCI device type number                  */
  2117.     WORD    wReserved0;        /* Reserved field                          */
  2118.     DWORD   dwItem;            /* Used to indicate the MCI_SYSINFO        */
  2119.                                /* extended function to perform            */
  2120.     PVOID   pSysInfoParm;
  2121. } MCI_SYSINFO_PARMS;
  2122. typedef MCI_SYSINFO_PARMS   *LPMCI_SYSINFO_PARMS;
  2123.  
  2124. typedef struct _MCI_SYSINFO_LOGDEVICE {
  2125.     CHAR    szInstallName[MAX_DEVICE_NAME];       /* Device install name            */
  2126.     USHORT  usDeviceType;                         /* Device type number             */
  2127.     ULONG   ulDeviceFlag;                         /* Flag indicating whether device */
  2128.                                                   /*  device is controllable or not */
  2129.     CHAR    szVersionNumber[MAX_VERSION_NUMBER];  /* INI file version number        */
  2130.     CHAR    szProductInfo[MAX_PRODINFO];          /* Textual product description    */
  2131.     CHAR    szMCDDriver[MAX_DEVICE_NAME];         /* MCI Driver dll name            */
  2132.     CHAR    szVSDDriver[MAX_DEVICE_NAME];         /* VSD dll name                   */
  2133.     CHAR    szPDDName[MAX_PDD_NAME];              /* Device PDD name                */
  2134.     CHAR    szMCDTable[MAX_DEVICE_NAME];          /* Device type command table      */
  2135.     CHAR    szVSDTable[MAX_DEVICE_NAME];          /* Device specific command table  */
  2136.     USHORT  usShareType;                          /* Device sharing mode            */
  2137.     CHAR    szResourceName[MAX_DEVICE_NAME];      /* Resource name                  */
  2138.     USHORT  usResourceUnits;                      /* Total resource units available */
  2139.                                                   /*  for this device               */
  2140.     USHORT  usResourceClasses;                    /* Number of resource classes for */
  2141.                                                   /*  this device                   */
  2142.     USHORT  ausClassArray[MAX_CLASSES];           /* Maximum number of resource     */
  2143.                                                   /*  units for each class          */
  2144.     USHORT  ausValidClassArray[MAX_CLASSES][MAX_CLASSES]; /* Valid class combinations */
  2145. } MCI_SYSINFO_LOGDEVICE;
  2146. typedef MCI_SYSINFO_LOGDEVICE  *LPMCI_SYSINFO_LOGDEVICE;
  2147.  
  2148.  
  2149. typedef struct _MCI_SYSINFO_DEVPARAMS {
  2150.     CHAR    szInstallName[MAX_DEVICE_NAME];       /* Device install name            */
  2151.     CHAR    szDevParams[MAX_DEV_PARAMS];          /* Device specific parameters     */
  2152. } MCI_SYSINFO_DEVPARAMS;
  2153. typedef MCI_SYSINFO_DEVPARAMS *LPMCI_SYSINFO_DEVPARAMS;
  2154.  
  2155. typedef struct _CONNECT {
  2156.     WORD   wConnectType;                          /* Connector type                 */
  2157.     CHAR   szToInstallName[MAX_DEVICE_NAME];      /* Install name this connector    */
  2158.                                                   /*  is connected to               */
  2159.     WORD   wToConnectIndex;                       /* Connector index this connector */
  2160.                                                   /*  is connected to               */
  2161. } CONNECT;
  2162. typedef CONNECT *PCONNECT;
  2163.  
  2164.  
  2165. typedef struct _MCI_SYSINFO_CONPARAMS {
  2166.     CHAR    szInstallName[MAX_DEVICE_NAME];       /* Device install name            */
  2167.     USHORT  usNumConnectors;                      /* Number of device connectors    */
  2168.     CONNECT ConnectorList[MAX_CONNECTORS];        /* Connector list array           */
  2169. } MCI_SYSINFO_CONPARAMS;
  2170. typedef MCI_SYSINFO_CONPARAMS *LPMCI_SYSINFO_CONPARAMS;
  2171.  
  2172. typedef struct _MCI_SYSINFO_EXTENSION {
  2173.     CHAR    szInstallName[MAX_DEVICE_NAME];       /* Device install name            */
  2174.     USHORT  usNumExtensions;                      /* Number of extensions           */
  2175.     CHAR    szExtension[MAX_EXTENSIONS][MAX_EXTENSION_NAME];
  2176.                                                   /* Extension name array           */
  2177. } MCI_SYSINFO_EXTENSION;
  2178. typedef MCI_SYSINFO_EXTENSION *LPMCI_SYSINFO_EXTENSION;
  2179.  
  2180. typedef struct _MCI_SYSINFO_ALIAS {
  2181.     CHAR    szInstallName[MAX_DEVICE_NAME];       /* Device install name  */
  2182.     CHAR    szAliasName[MAX_ALIAS_NAME];          /* Alias name           */
  2183. } MCI_SYSINFO_ALIAS;
  2184. typedef MCI_SYSINFO_ALIAS *LPMCI_SYSINFO_ALIAS;
  2185.  
  2186. typedef struct _MCI_SYSINFO_DEFAULTDEVICE {
  2187.     CHAR    szInstallName[MAX_DEVICE_NAME];       /* Device install name  */
  2188.     USHORT  usDeviceType;                         /* Device type number   */
  2189. } MCI_SYSINFO_DEFAULTDEVICE;
  2190. typedef MCI_SYSINFO_DEFAULTDEVICE *LPMCI_SYSINFO_DEFAULTDEVICE;
  2191.  
  2192. typedef struct _MCI_SYSINFO_QUERY_NAME {
  2193.     CHAR    szInstallName[MAX_DEVICE_NAME];       /* Device install name  */
  2194.     CHAR    szLogicalName[MAX_DEVICE_NAME];       /* Logical device name  */
  2195.     CHAR    szAliasName[MAX_ALIAS_NAME];          /* Alias name           */
  2196.     USHORT  usDeviceType;                         /* Device type number   */
  2197.     USHORT  usDeviceOrd;                          /* Device type ordinal  */
  2198. } MCI_SYSINFO_QUERY_NAME;
  2199. typedef MCI_SYSINFO_QUERY_NAME *LPMCI_SYSINFO_QUERY_NAME;
  2200.  
  2201. typedef struct _MCI_SYSINFO_TYPES {
  2202.     CHAR    szInstallName[MAX_DEVICE_NAME];       /* Device install name  */
  2203.     CHAR    szTypes[MAX_TYPEBUFFER+1];            /* EA types             */
  2204. } MCI_SYSINFO_TYPES;
  2205. typedef MCI_SYSINFO_TYPES *LPMCI_SYSINFO_TYPES;
  2206.  
  2207.  
  2208. /*********************************************************************/
  2209. /* flags for the MCI_UNFREEZE message                                */
  2210. /*     0x00000X00 are reserved for MCI_UNFREEZE flags                */
  2211. /*********************************************************************/
  2212. #define MCI_OVLY_UNFREEZE_RECT              0x00000100L
  2213. #define MCI_OVLY_UNFREEZE_RECT_OUTSIDE      0x00000200L
  2214.  
  2215. /*********************************************************************/
  2216. /* flags for the MCI_WHERE message                                   */
  2217. /*     0x0000XX00 are reserved for MCI_WHERE flags                   */
  2218. /*********************************************************************/
  2219. #define MCI_VID_WHERE_DESTINATION           0x00000100L
  2220. #define MCI_VID_WHERE_SOURCE                0x00000200L
  2221. #define MCI_VID_WHERE_WINDOW                0x00000400L
  2222.  
  2223. #define MCI_DGV_WHERE_DESTINATION           MCI_VID_WHERE_DESTINATION
  2224. #define MCI_DGV_WHERE_SOURCE                MCI_VID_WHERE_SOURCE
  2225. #define MCI_DGV_WHERE_WINDOW                MCI_VID_WHERE_WINDOW
  2226. #define MCI_DGV_WHERE_ADJUSTED              0x00000800L
  2227.  
  2228. #define MCI_OVLY_WHERE_DESTINATION          MCI_VID_WHERE_DESTINATION
  2229. #define MCI_OVLY_WHERE_SOURCE               MCI_VID_WHERE_SOURCE
  2230. #define MCI_OVLY_WHERE_WINDOW               MCI_VID_WHERE_WINDOW
  2231.  
  2232. /*********************************************************************/
  2233. /* flags and parameter structure for the MCI_WINDOW message          */
  2234. /*     0x0000XX00   are reserved for MCI_WINDOW flags                */
  2235. /*********************************************************************/
  2236. #define MCI_VID_WINDOW_HWND                 0x00000100L
  2237. #define MCI_VID_WINDOW_STATE                0x00000200L
  2238. #define MCI_VID_WINDOW_TEXT                 0x00000400L
  2239. #define MCI_VID_WINDOW_DEFAULT              0x00000800L
  2240.  
  2241. #define MCI_DGV_WINDOW_HWND                 MCI_VID_WINDOW_HWND
  2242. #define MCI_DGV_WINDOW_STATE                MCI_VID_WINDOW_STATE
  2243. #define MCI_DGV_WINDOW_TEXT                 MCI_VID_WINDOW_TEXT
  2244. #define MCI_DGV_WINDOW_DEFAULT              MCI_VID_WINDOW_DEFAULT
  2245.  
  2246. #define MCI_OVLY_WINDOW_HWND                MCI_VID_WINDOW_HWND
  2247. #define MCI_OVLY_WINDOW_STATE               MCI_VID_WINDOW_STATE
  2248. #define MCI_OVLY_WINDOW_TEXT                MCI_VID_WINDOW_TEXT
  2249. #define MCI_OVLY_WINDOW_DEFAULT             MCI_VID_WINDOW_DEFAULT
  2250.  
  2251. typedef  struct _MCI_VID_WINDOW_PARMS {
  2252.     DWORD   dwCallback;      /* PM window handle for MCI notify message */
  2253.     HWND    hwndDest;        /* Handle to the client window used for    */
  2254.                              /* the destination of the video image      */
  2255.     WORD    wCmdShow;        /* Specifies how the window is displayed   */
  2256.     WORD    wReserved1;      /* Reserved                                */
  2257.     LPSTR   lpstrText;       /* The text to use as the window caption   */
  2258.     LPSTR   lpstrAlias;      /* The window alias for the display window */
  2259. } MCI_VID_WINDOW_PARMS;
  2260.  
  2261. typedef MCI_VID_WINDOW_PARMS   MCI_DGV_WINDOW_PARMS;
  2262. typedef MCI_DGV_WINDOW_PARMS   *LPMCI_DGV_WINDOW_PARMS;
  2263.  
  2264. typedef MCI_VID_WINDOW_PARMS   MCI_OVLY_WINDOW_PARMS;
  2265. typedef MCI_OVLY_WINDOW_PARMS  *LPMCI_OVLY_WINDOW_PARMS;
  2266.  
  2267.  
  2268. /*********************************************************************/
  2269. /* flags and parameter structure for the MCI_TUNER  message          */
  2270. /*********************************************************************/
  2271. #define MCI_DGV_AUDIO_CHANNEL               0x00010000L
  2272. #define MCI_DGV_TV_CHANNEL                  0x00020000L
  2273. #define MCI_DGV_FREQUENCY                   0x00040000L
  2274. #define MCI_DGV_FINETUNE_PLUS               0x00080000L
  2275. #define MCI_DGV_FINETUNE_MINUS              0x00100000L
  2276. #define MCI_DGV_REGION                      0x00200000L
  2277. #define MCI_DGV_AFC_ON                      0x00400000L
  2278. #define MCI_DGV_AFC_OFF                     0x00800000L
  2279. #define MCI_DGV_POLARIZATION                0x00800000L
  2280. #define MCI_DGV_QUERY                       0x01000000L
  2281.  
  2282. typedef struct _MCI_DGV_TUNER_PARMS {
  2283.     ULONG  ulCallback;       /* PM window handle for MCI notify message    */
  2284.     ULONG  ulFrequency;      /* Tuner Frequency                            */
  2285.     ULONG  ulAudioChannel;   /* Audio Channel                              */
  2286.     ULONG  ulTVChannel;      /* TV Channel                                 */
  2287.     LONG   lFineTune;        /* Fine tuning adjustments.                   */
  2288.     LPSTR  lpstrRegion;      /* TV Channel Region                          */
  2289.     ULONG  ulReserved1;      /* Reserved 1                                 */
  2290.     ULONG  ulReserved2;      /* Reserved 2                                 */
  2291. } MCI_DGV_TUNER_PARMS;
  2292. typedef MCI_DGV_TUNER_PARMS   *LPMCI_DGV_TUNER_PARMS;
  2293.  
  2294. #pragma pack()
  2295. /*********************************************************************/
  2296. /*                                                                   */
  2297. /*  MCI system value defines                                         */
  2298. /*                                                                   */
  2299. /*********************************************************************/
  2300. #define MSV_CLOSEDCAPTION                   0x0
  2301. #define MSV_MASTERVOLUME                    0x1
  2302. #define MSV_HEADPHONES                      0x2
  2303. #define MSV_SPEAKERS                        0x3
  2304. #define MSV_WORKPATH                        0x4
  2305. #define MSV_SYSQOSVALUE                     0x5
  2306. #define MSV_SYSQOSERRORFLAG                 0x6
  2307.  
  2308. #define MSV_MAX                             0x7
  2309.  
  2310. #endif                       /* INCL_32 */
  2311.  
  2312. /*********************************************************************/
  2313. /* Playlist defines                                                  */
  2314. /*********************************************************************/
  2315. #define DATA_OPERATION                      0
  2316. #define BRANCH_OPERATION                    1
  2317. #define LOOP_OPERATION                      2
  2318. #define CALL_OPERATION                      3
  2319. #define RETURN_OPERATION                    4
  2320. #define EXIT_OPERATION                      5
  2321. #define NOP_OPERATION                       6
  2322. #define MESSAGE_OPERATION                   7
  2323. #define CUEPOINT_OPERATION                  8
  2324. #define SEMWAIT_OPERATION                   9
  2325. #define SEMPOST_OPERATION                  10
  2326.  
  2327. /*********************************************************************/
  2328. /*                                                                   */
  2329. /*  MCI Function prototypes                                          */
  2330. /*                                                                   */
  2331. /*********************************************************************/
  2332.  
  2333. #ifdef INCL_32
  2334.  
  2335. DWORD APIENTRY mciSendCommand   (WORD   wDeviceID,
  2336.                                  WORD   wMessage,
  2337.                                  DWORD  dwParam1,
  2338.                                  DWORD  dwParam2,
  2339.                                  WORD   wUserParm);
  2340.  
  2341. DWORD APIENTRY  mciSendString   (LPSTR lpstrCommandBuf,
  2342.                                  LPSTR lpstrReturnString,
  2343.                                  WORD  wReturnLength,
  2344.                                  HWND  hCallBack,
  2345.                                  WORD  wUserParm );
  2346.  
  2347. DWORD APIENTRY mciGetErrorString(DWORD   dwError,
  2348.                                  LPSTR   lpstrBuffer,
  2349.                                  WORD    wLength);
  2350.  
  2351.  
  2352. DWORD APIENTRY mciMakeGroup     (PW      pwDeviceGroupID,
  2353.                                  WORD    wDeviceCount,
  2354.                                  PAW     pawDeviceList,
  2355.                                  DWORD   dwFlags,
  2356.                                  DWORD   dwMMTime);
  2357.  
  2358.  
  2359. DWORD APIENTRY mciDeleteGroup   (WORD   wGroupID);
  2360.  
  2361.  
  2362.  
  2363. BOOL APIENTRY mciSetSysValue (USHORT iSysValue, PVOID pValue);
  2364.  
  2365. BOOL  APIENTRY mciQuerySysValue (USHORT iSysValue, PVOID pValue);
  2366.  
  2367. DWORD  APIENTRY mciGetDeviceID  (LPSTR  lpstrName);
  2368.  
  2369. #else                        /* INCL_32 */
  2370.  
  2371. #define mciSendString mci16SendString
  2372. #define mciGetErrorString mci16GetErrorString
  2373. #define mciGetDeviceID mci16GetDeviceID
  2374.  
  2375. ULONG APIENTRY  mciSendString   (LPSTR   lpstrCommandBuf,
  2376.                                  LPSTR   lpstrReturnString,
  2377.                                  WORD    wReturnLength,
  2378.                                  HWND    hCallBack,
  2379.                                  WORD    wUserParm );
  2380.  
  2381. ULONG APIENTRY mciGetErrorString    (DWORD  dwError,
  2382.                                      LPSTR  lpstrBuffer,
  2383.                                      WORD   wLength);
  2384.  
  2385. ULONG APIENTRY mciGetDeviceID  (LPSTR  lpstrName);
  2386.  
  2387.  
  2388. #endif                       /* INCL_32 */
  2389. #endif
  2390.  
  2391.