/*************************************************************************** * * * THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY * * KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE * * IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR * * PURPOSE. * * * * Copyright (c) 1993 - 1995 Microsoft Corporation. All Rights Reserved. * * * * File: vcr.h * * Title: VCR-MCI Command Table Include File * * * ***************************************************************************/ /* string resource base for vcr device type */ #define MCI_VCR_OFFSET 1280 /* system MCI commands */ #define MCI_LIST 0x0878 #define MCI_SETAUDIO 0x0873 #define MCI_SETVIDEO 0x0876 #define MCI_SIGNAL 0x0875 /* custom MCI commands for VCRs */ #define MCI_MARK (MCI_USER_MESSAGES + 0) #define MCI_INDEX (MCI_USER_MESSAGES + 1) #define MCI_SETTUNER (MCI_USER_MESSAGES + 2) #define MCI_SETVCR (MCI_USER_MESSAGES + 3) #define MCI_SETTIMECODE (MCI_USER_MESSAGES + 4) /* Test is appplicable to all commands */ #define MCI_TEST 0x00000020L /* flags for dwItem field of MCI_GETDEVCAPS_PARMS parameter block */ #define MCI_VCR_GETDEVCAPS_CAN_DETECT_LENGTH 0x00004001L #define MCI_VCR_GETDEVCAPS_SEEK_ACCURACY 0x00004002L #define MCI_VCR_GETDEVCAPS_HAS_CLOCK 0x00004003L #define MCI_VCR_GETDEVCAPS_CAN_REVERSE 0x00004004L #define MCI_VCR_GETDEVCAPS_NUMBER_OF_MARKS 0x00004005L #define MCI_VCR_GETDEVCAPS_CAN_TEST 0x00004006L #define MCI_VCR_GETDEVCAPS_CAN_PREROLL 0x00004007L #define MCI_VCR_GETDEVCAPS_CAN_PREVIEW 0x00004008L #define MCI_VCR_GETDEVCAPS_CAN_MONITOR_SOURCES 0x00004009L #define MCI_VCR_GETDEVCAPS_HAS_TIMECODE 0x0000400AL #define MCI_VCR_GETDEVCAPS_CAN_FREEZE 0x0000401BL #define MCI_VCR_GETDEVCAPS_CLOCK_INCREMENT_RATE 0x0000401CL /* flags for dwFlags parameter of MCI_INFO command message */ #define MCI_VCR_INFO_VERSION 0x00010000L /* flags for dwFlags parameter of MCI_PLAY command message */ #define MCI_VCR_PLAY_REVERSE 0x00010000L #define MCI_VCR_PLAY_AT 0x00020000L #define MCI_VCR_PLAY_SCAN 0x00040000L /* flags for dwFlags parameter of MCI_RECORD command message */ #define MCI_VCR_RECORD_INITIALIZE 0x00010000L #define MCI_VCR_RECORD_AT 0x00020000L #define MCI_VCR_RECORD_PREVIEW 0x00040000L /* flags for dwFlags parameter of MCI_CUE command message */ #define MCI_VCR_CUE_INPUT 0x00010000L #define MCI_VCR_CUE_OUTPUT 0x00020000L #define MCI_VCR_CUE_PREROLL 0x00040000L #define MCI_VCR_CUE_REVERSE 0x00080000L /* flags for dwFlags parameter of MCI_SEEK command message */ #define MCI_VCR_SEEK_REVERSE 0x00010000L #define MCI_VCR_SEEK_MARK 0x00020000L #define MCI_VCR_SEEK_AT 0x00040000L /* flags for dwFlags parameter of MCI_SETTUNER command message */ #define MCI_VCR_SETTUNER_CHANNEL 0x00010000L #define MCI_VCR_SETTUNER_CHANNEL_UP 0x00020000L #define MCI_VCR_SETTUNER_CHANNEL_DOWN 0x00040000L #define MCI_VCR_SETTUNER_CHANNEL_SEEK_UP 0x00080000L #define MCI_VCR_SETTUNER_CHANNEL_SEEK_DOWN 0x00100000L #define MCI_VCR_SETTUNER_NUMBER 0x00200000L /* flags for dwFlags parameter of MCI_SET command message */ #define MCI_VCR_SET_TIME_MODE 0x00010000L #define MCI_VCR_SET_POWER 0x00020000L #define MCI_VCR_SET_RECORD_FORMAT 0x00040000L #define MCI_VCR_SET_COUNTER_FORMAT 0x00080000L #define MCI_VCR_SET_INDEX 0x00100000L #define MCI_VCR_SET_ASSEMBLE_RECORD 0x00200000L #define MCI_VCR_SET_TRACKING 0x00400000L #define MCI_VCR_SET_SPEED 0x00800000L #define MCI_VCR_SET_TAPE_LENGTH 0x01000000L #define MCI_VCR_SET_COUNTER_VALUE 0x02000000L #define MCI_VCR_SET_CLOCK 0x04000000L #define MCI_VCR_SET_PAUSE_TIMEOUT 0x08000000L #define MCI_VCR_SET_PREROLL_DURATION 0x10000000L #define MCI_VCR_SET_POSTROLL_DURATION 0x20000000L /* flags for dwItem parameter of MCI_SETTIMECODE commmand message */ #define MCI_VCR_SETTIMECODE_RECORD 0x00010000L /* flags for dwItem field of MCI_STATUS_PARMS parameter block */ #define MCI_VCR_STATUS_FRAME_RATE 0x00004001L /* Frame rate */ #define MCI_VCR_STATUS_SPEED 0x00004002L /* Speed */ #define MCI_VCR_STATUS_MEDIA_TYPE 0x00004003L #define MCI_VCR_STATUS_RECORD_FORMAT 0x00004004L #define MCI_VCR_STATUS_PLAY_FORMAT 0x00004005L #define MCI_VCR_STATUS_AUDIO_SOURCE 0x00004006L #define MCI_VCR_STATUS_AUDIO_SOURCE_NUMBER 0x00004007L #define MCI_VCR_STATUS_VIDEO_SOURCE 0x00004008L #define MCI_VCR_STATUS_VIDEO_SOURCE_NUMBER 0x00004009L #define MCI_VCR_STATUS_AUDIO_MONITOR 0x0000400AL #define MCI_VCR_STATUS_AUDIO_MONITOR_NUMBER 0x0000400BL #define MCI_VCR_STATUS_VIDEO_MONITOR 0x0000400CL #define MCI_VCR_STATUS_VIDEO_MONITOR_NUMBER 0x0000400DL #define MCI_VCR_STATUS_INDEX_ON 0x0000400EL #define MCI_VCR_STATUS_INDEX 0x0000400FL #define MCI_VCR_STATUS_COUNTER_FORMAT 0x00004010L #define MCI_VCR_STATUS_COUNTER_RESOLUTION 0x00004011L #define MCI_VCR_STATUS_TIMECODE_TYPE 0x00004012L #define MCI_VCR_STATUS_COUNTER_VALUE 0x00004013L #define MCI_VCR_STATUS_TUNER_CHANNEL 0x00004014L #define MCI_VCR_STATUS_WRITE_PROTECTED 0x00004015L #define MCI_VCR_STATUS_TIMECODE_RECORD 0x00004016L #define MCI_VCR_STATUS_VIDEO_RECORD 0x00004017L #define MCI_VCR_STATUS_AUDIO_RECORD 0x00004018L #define MCI_VCR_STATUS_TIME_TYPE 0x00004019L #define MCI_VCR_STATUS_TIME_MODE 0x0000401AL #define MCI_VCR_STATUS_POWER_ON 0x0000401BL #define MCI_VCR_STATUS_CLOCK 0x0000401CL #define MCI_VCR_STATUS_ASSEMBLE_RECORD 0x0000401DL #define MCI_VCR_STATUS_TIMECODE_PRESENT 0x0000401EL #define MCI_VCR_STATUS_NUMBER_OF_VIDEO_TRACKS 0x0000401FL #define MCI_VCR_STATUS_NUMBER_OF_AUDIO_TRACKS 0x00004020L #define MCI_VCR_STATUS_CLOCK_ID 0x00004021L #define MCI_VCR_STATUS_PAUSE_TIMEOUT 0x00004022L #define MCI_VCR_STATUS_PREROLL_DURATION 0x00004023L #define MCI_VCR_STATUS_POSTROLL_DURATION 0x00004024L #define MCI_VCR_STATUS_VIDEO 0x00004025L #define MCI_VCR_STATUS_AUDIO 0x00004026L #define MCI_VCR_STATUS_NUMBER 0x00080000L /* flags for dwFlags parameter of MCI_ESCAPE command message */ #define MCI_VCR_ESCAPE_STRING 0x00000100L /* flags for dwFlags parameter of MCI_LIST command message */ #define MCI_VCR_LIST_VIDEO_SOURCE 0x00010000L #define MCI_VCR_LIST_AUDIO_SOURCE 0x00020000L #define MCI_VCR_LIST_COUNT 0x00040000L #define MCI_VCR_LIST_NUMBER 0x00080000L /* flags for dwFlags parameter of MCI_MARK command message */ #define MCI_VCR_MARK_WRITE 0x00010000L #define MCI_VCR_MARK_ERASE 0x00020000L /* flags for dwFlags parameter for MCI_SETAUDIO command message */ #define MCI_VCR_SETAUDIO_RECORD 0x00010000L #define MCI_VCR_SETAUDIO_SOURCE 0x00020000L #define MCI_VCR_SETAUDIO_MONITOR 0x00040000L #define MCI_VCR_SETAUDIO_TO 0x00200000L #define MCI_VCR_SETAUDIO_NUMBER 0x00400000L /* flags for dwFlags parameter for MCI_SETVIDEO command message */ #define MCI_VCR_SETVIDEO_RECORD 0x00010000L #define MCI_VCR_SETVIDEO_SOURCE 0x00020000L #define MCI_VCR_SETVIDEO_MONITOR 0x00040000L #define MCI_VCR_SETVIDEO_TO 0x00100000L #define MCI_VCR_SETVIDEO_NUMBER 0x00200000L /* The following is the function digitalvideo drivers must use * to signal when a frame marked by the SIGNAL command has been rendered: * * SEND_VCRSIGNAL(dwFlags, dwCallback, hDriver, wDeviceID, dwUser, dwPos ) * * The following is a description of the parameters: * * dwFlags - the dwFlags parameter passed when the signal was set * dwCallback - the dwCallback value from the MCI_VCR_SIGNAL_PARMS struct * used to set the signal * hDriver - the handle assigned to the driver by MMSYSTEM when the * device was opened * wDeviceID - the device ID * dwUser - the dwUserParm value from the MCI_VCR_SIGNAL_PARMS struct * used to set the signal * dwPos - the position at which the signal was sent, in the current * time format. * * The window indicated by the handle in the dwCallback field is notified * by means of a Windows message with the following form: * * msg = MM_MCISIGNAL * wParam = wDeviceID of the sending driver * lParam = the uservalue specified or the position the signal was sent * at; the latter if the MCI_VCR_SIGNAL_POSITION flag was set * in the dwFlags parameter when the signal was created. */ #define SEND_VCRSIGNAL(dwFlags, dwCallback, hDriver, wDeviceID, dwUser, dwPos ) \ DriverCallback( (dwCallback), DCB_WINDOW, (HANDLE)(wDeviceID), MM_MCISIGNAL,\ hDriver, ((dwFlags) & MCI_VCR_SIGNAL_POSITION) ? (dwPos):(dwUser),\ ((dwFlags) & MCI_VCR_SIGNAL_POSITION) ? (dwUser):(dwPos)) /* Window message for signal notification */ #define MM_MCISIGNAL 0x3CB /* flags for dwFlags parameter of MCI_SIGNAL command message */ #define MCI_VCR_SIGNAL_AT 0x00010000L #define MCI_VCR_SIGNAL_EVERY 0x00020000L #define MCI_VCR_SIGNAL_USERVAL 0x00040000L #define MCI_VCR_SIGNAL_CANCEL 0x00080000L #define MCI_VCR_SIGNAL_POSITION 0x00100000L /* flags for dwFlags parameter of MCI_STEP command message */ #define MCI_VCR_STEP_FRAMES 0x00010000L #define MCI_VCR_STEP_REVERSE 0x00020000L /* flags for dwFlags parameter of MCI_FREEZE command message */ #define MCI_VCR_FREEZE_INPUT 0x00010000L #define MCI_VCR_FREEZE_OUTPUT 0x00020000L #define MCI_VCR_FREEZE_FIELD 0x00040000L #define MCI_VCR_FREEZE_FRAME 0x00080000L /* flags for dwFlags parameter of MCI_UNFREEZE command message */ #define MCI_VCR_UNFREEZE_INPUT 0x00010000L #define MCI_VCR_UNFREEZE_OUTPUT 0x00020000L /* string resource values for vcr media types */ #define MCI_VCR_MEDIA_8MM (MCI_VCR_OFFSET + 1) #define MCI_VCR_MEDIA_HI8 (MCI_VCR_OFFSET + 2) #define MCI_VCR_MEDIA_VHS (MCI_VCR_OFFSET + 3) #define MCI_VCR_MEDIA_SVHS (MCI_VCR_OFFSET + 4) #define MCI_VCR_MEDIA_BETA (MCI_VCR_OFFSET + 5) #define MCI_VCR_MEDIA_EDBETA (MCI_VCR_OFFSET + 6) #define MCI_VCR_MEDIA_OTHER (MCI_VCR_OFFSET + 7) /* string resource values for vcr play/record formats */ #define MCI_VCR_FORMAT_SP (MCI_VCR_OFFSET + 8) #define MCI_VCR_FORMAT_LP (MCI_VCR_OFFSET + 9) #define MCI_VCR_FORMAT_EP (MCI_VCR_OFFSET + 10) #define MCI_VCR_FORMAT_OTHER (MCI_VCR_OFFSET + 11) /* string resource values for timecode types */ #define MCI_VCR_TIME_TIMECODE (MCI_VCR_OFFSET + 12) #define MCI_VCR_TIME_COUNTER (MCI_VCR_OFFSET + 13) #define MCI_VCR_TIME_DETECT (MCI_VCR_OFFSET + 14) /* string resource values for src types */ #define MCI_VCR_SRC_TYPE_TUNER (MCI_VCR_OFFSET + 15) #define MCI_VCR_SRC_TYPE_LINE (MCI_VCR_OFFSET + 16) #define MCI_VCR_SRC_TYPE_SVIDEO (MCI_VCR_OFFSET + 17) #define MCI_VCR_SRC_TYPE_RGB (MCI_VCR_OFFSET + 18) #define MCI_VCR_SRC_TYPE_AUX (MCI_VCR_OFFSET + 19) #define MCI_VCR_SRC_TYPE_GENERIC (MCI_VCR_OFFSET + 20) #define MCI_VCR_SRC_TYPE_MUTE (MCI_VCR_OFFSET + 21) #define MCI_VCR_SRC_TYPE_OUTPUT (MCI_VCR_OFFSET + 22) /* string resource values for vcr counters */ #define MCI_VCR_INDEX_TIMECODE (MCI_VCR_OFFSET + 23) #define MCI_VCR_INDEX_COUNTER (MCI_VCR_OFFSET + 24) #define MCI_VCR_INDEX_DATE (MCI_VCR_OFFSET + 25) #define MCI_VCR_INDEX_TIME (MCI_VCR_OFFSET + 26) /* string resources for timecode type and counter resolution */ #define MCI_VCR_COUNTER_RES_SECONDS (MCI_VCR_OFFSET + 27) #define MCI_VCR_COUNTER_RES_FRAMES (MCI_VCR_OFFSET + 28) #define MCI_VCR_TIMECODE_TYPE_SMPTE (MCI_VCR_OFFSET + 29) #define MCI_VCR_TIMECODE_TYPE_SMPTE_DROP (MCI_VCR_OFFSET + 30) #define MCI_VCR_TIMECODE_TYPE_OTHER (MCI_VCR_OFFSET + 31) #define MCI_VCR_TIMECODE_TYPE_NONE (MCI_VCR_OFFSET + 32) #define MCI_VCR_PLUS (MCI_VCR_OFFSET + 33) #define MCI_VCR_MINUS (MCI_VCR_OFFSET + 34) #define MCI_VCR_RESET (MCI_VCR_OFFSET + 35) #ifndef RC_INVOKED /* parameter block for MCI_SEEK command message */ typedef struct tagMCI_VCR_SEEK_PARMS { DWORD dwCallback; DWORD dwTo; DWORD dwMark; DWORD dwAt; } MCI_VCR_SEEK_PARMS; typedef MCI_VCR_SEEK_PARMS FAR *LPMCI_VCR_SEEK_PARMS; /* parameter block for MCI_SET command message */ typedef struct tagMCI_VCR_SET_PARMS { DWORD dwCallback; DWORD dwTimeFormat; DWORD dwAudio; DWORD dwTimeMode; DWORD dwRecordFormat; DWORD dwCounterFormat; DWORD dwIndex; DWORD dwTracking; DWORD dwSpeed; DWORD dwLength; DWORD dwCounter; DWORD dwClock; DWORD dwPauseTimeout; DWORD dwPrerollDuration; DWORD dwPostrollDuration; } MCI_VCR_SET_PARMS; typedef MCI_VCR_SET_PARMS FAR *LPMCI_VCR_SET_PARMS; /* parameter block for MCI_VCR_SETTUNER command message */ typedef struct tagMCI_VCR_SETTUNER_PARMS { DWORD dwCallback; DWORD dwChannel; DWORD dwNumber; } MCI_VCR_SETTUNER_PARMS; typedef MCI_VCR_SETTUNER_PARMS FAR *LPMCI_VCR_SETTUNER_PARMS; /* parameter block for MCI_ESCAPE command message */ typedef struct tagMCI_VCR_ESCAPE_PARMS { DWORD dwCallback; LPCSTR lpstrCommand; } MCI_VCR_ESCAPE_PARMS; typedef MCI_VCR_ESCAPE_PARMS FAR *LPMCI_VCR_ESCAPE_PARMS; /* parameter block for MCI_LIST command message */ typedef struct tagMCI_VCR_LIST_PARMS { DWORD dwCallback; DWORD dwReturn; DWORD dwNumber; } MCI_VCR_LIST_PARMS; typedef MCI_VCR_LIST_PARMS FAR *LPMCI_VCR_LIST_PARMS; /* parameter block for MCI_RECORD command message */ typedef struct tagMCI_VCR_RECORD_PARMS { DWORD dwCallback; DWORD dwFrom; DWORD dwTo; DWORD dwAt; } MCI_VCR_RECORD_PARMS; typedef MCI_VCR_RECORD_PARMS FAR *LPMCI_VCR_RECORD_PARMS; /* parameter block for MCI_PLAY command message */ typedef struct tagMCI_VCR_PLAY_PARMS { DWORD dwCallback; DWORD dwFrom; DWORD dwTo; DWORD dwAt; } MCI_VCR_PLAY_PARMS; typedef MCI_VCR_PLAY_PARMS FAR *LPMCI_VCR_PLAY_PARMS; /* parameter block for MCI_SETAUDIO command message */ typedef struct tagMCI_VCR_SETAUDIO_PARMS { DWORD dwCallback; DWORD dwTrack; DWORD dwTo; DWORD dwNumber; } MCI_VCR_SETAUDIO_PARMS; typedef MCI_VCR_SETAUDIO_PARMS FAR *LPMCI_VCR_SETAUDIO_PARMS; /* parameter block for MCI_SIGNAL command message */ typedef struct tagMCI_VCR_SIGNAL_PARMS { DWORD dwCallback; DWORD dwPosition; DWORD dwPeriod; DWORD dwUserParm; } MCI_VCR_SIGNAL_PARMS; typedef MCI_VCR_SIGNAL_PARMS FAR * LPMCI_VCR_SIGNAL_PARMS; /* parameter block for MCI_VCR_STATUS command message */ typedef struct tagMCI_VCR_STATUS_PARMS { DWORD dwCallback; DWORD dwReturn; DWORD dwItem; DWORD dwTrack; DWORD dwNumber; } MCI_VCR_STATUS_PARMS; typedef MCI_VCR_STATUS_PARMS FAR * LPMCI_VCR_STATUS_PARMS; /* parameter block for MCI_SETVIDEO command message */ typedef struct tagMCI_VCR_SETVIDEO_PARMS { DWORD dwCallback; DWORD dwTrack; DWORD dwTo; DWORD dwNumber; } MCI_VCR_SETVIDEO_PARMS; typedef MCI_VCR_SETVIDEO_PARMS FAR *LPMCI_VCR_SETVIDEO_PARMS; /* parameter block for MCI_STEP command message */ typedef struct tagMCI_VCR_STEP_PARMS { DWORD dwCallback; DWORD dwFrames; } MCI_VCR_STEP_PARMS; typedef MCI_VCR_STEP_PARMS FAR *LPMCI_VCR_STEP_PARMS; /* parameter block for MCI_CUE command message */ typedef struct tagMCI_VCR_CUE_PARMS { DWORD dwCallback; DWORD dwFrom; DWORD dwTo; } MCI_VCR_CUE_PARMS; typedef MCI_VCR_CUE_PARMS FAR *LPMCI_VCR_CUE_PARMS; #endif /* NOT RC_INVOKED */ /* VCR error codes */ #define MCIERR_VCR_CANNOT_OPEN_COMM (MCIERR_CUSTOM_DRIVER_BASE + 1) #define MCIERR_VCR_CANNOT_WRITE_COMM (MCIERR_CUSTOM_DRIVER_BASE + 2) #define MCIERR_VCR_READ_TIMEOUT (MCIERR_CUSTOM_DRIVER_BASE + 3) #define MCIERR_VCR_COMMAND_BUFFER_FULL (MCIERR_CUSTOM_DRIVER_BASE + 4) #define MCIERR_VCR_COMMAND_CANCELLED (MCIERR_CUSTOM_DRIVER_BASE + 5) #define MCIERR_VCR_POWER_OFF (MCIERR_CUSTOM_DRIVER_BASE + 6) #define MCIERR_VCR_COMMAND_FAILED (MCIERR_CUSTOM_DRIVER_BASE + 7) #define MCIERR_VCR_SEARCH (MCIERR_CUSTOM_DRIVER_BASE + 8) #define MCIERR_VCR_CONDITION (MCIERR_CUSTOM_DRIVER_BASE + 9) #define MCIERR_VCR_CAMERA_MODE (MCIERR_CUSTOM_DRIVER_BASE + 10) #define MCIERR_VCR_VCR_MODE (MCIERR_CUSTOM_DRIVER_BASE + 11) #define MCIERR_VCR_COUNTER_TYPE (MCIERR_CUSTOM_DRIVER_BASE + 12) #define MCIERR_VCR_TUNER (MCIERR_CUSTOM_DRIVER_BASE + 13) #define MCIERR_VCR_EMERGENCY_STOP (MCIERR_CUSTOM_DRIVER_BASE + 14) #define MCIERR_VCR_MEDIA_UNMOUNTED (MCIERR_CUSTOM_DRIVER_BASE + 15) #define MCIERR_VCR_REGISTER (MCIERR_CUSTOM_DRIVER_BASE + 16) #define MCIERR_VCR_TRACK_FAILURE (MCIERR_CUSTOM_DRIVER_BASE + 17) #define MCIERR_VCR_CUE_FAILED_FLAGS (MCIERR_CUSTOM_DRIVER_BASE + 18) #define MCIERR_VCR_ISWRITEPROTECTED (MCIERR_CUSTOM_DRIVER_BASE + 19)