windows-nt/Source/XPSP1/NT/enduser/netmeeting/h/vcmstrm.h

1274 lines
50 KiB
C
Raw Normal View History

2020-09-26 03:20:57 -05:00
#ifndef _INC_VCM
#define _INC_VCM /* #defined if vcmStrm.h has been included */
#if defined(UNICODE) && !defined(_UNICODE)
#define _UNICODE
#endif
#pragma pack(1) /* Assume 1 byte packing throughout */
#ifdef __cplusplus
extern "C" { /* Assume C declarations for C++ */
#endif /* __cplusplus */
/****************************************************************************
Table Of Contents
****************************************************************************/
/****************************************************************************
@doc EXTERNAL
@contents1 Contents | To display a list of topics by category, click any
of the contents entries below. To display an alphabetical list of
topics, choose the Index button.
@head3 Introduction |
The vcmStreamXXX APIs are defined to simplify integration of video
compression and decompression in NetMeeting's datapump. Currently, the datapump
behavior relies a lot on the acmStreamXXX APIs. In order to limit the amount of modifications that need to be applied
to the datapump, we define video compression APIs with a behavior similar to
the audio compression APIs. Integration in the datapump will be achieved by defining
a FilterVideoManager class identical to the FilterManager class, where calls to
acmStreamXXX functions are simply replaced by calls to vcmStreamXXX functions.
@head3 vcmStreamXXX Compression/Decompression API |
@subindex Functions
@subindex Structures and Enums
@subindex Messages
@head3 vcmDevCapsXXX Capture Device Capabilities API |
@subindex Functions
@subindex Structures and Enums
@subindex Messages
@head3 Other |
@subindex Modules
@subindex Constants
***********************************************************************
@contents2 Compression/Decompression Functions |
@index func | COMPFUNC
***********************************************************************
@contents2 Compression/Decompression Structures and Enums |
@index struct,enum | COMPSTRUCTENUM
***********************************************************************
@contents2 Compression/Decompression Messages |
@index msg | COMPMSG
***********************************************************************
@contents2 Capture Device Capabilities Functions |
@index func | DEVCAPSFUNC
***********************************************************************
@contents2 Capture Device Capabilities Structures and Enums |
@index struct,enum | DEVCAPSSTRUCTENUM
***********************************************************************
@contents2 Modules |
@index module |
***********************************************************************
@contents2 Constants |
@index const |
****************************************************************************/
/*****************************************************************************
* @doc EXTERNAL COMPSTRUCTENUM
*
* @struct VIDEOFORMATEX | The <t VIDEOFORMATEX> structure defines the format used to
* capture video data and settings for the capture device.
*
* @field DWORD | dwFormatTag | Specifies the video format type (FOURCC code).
*
* @field DWORD | nSamplesPerSec | Specifies the sample rate, in frames per second.
*
* @field DWORD | nAvgBytesPerSec | Specifies the average data-transfer rate, in bytes per second.
*
* @field DWORD | nMinBytesPerSec | Specifies the minimum data-transfer rate, in bytes per second.
*
* @field DWORD | nMaxBytesPerSec | Specifies the maximum data-transfer rate, in bytes per second.
*
* @field DWORD | nBlockAlign | Specifies the block alignment, in bytes.
*
* @field DWORD | wBitsPerSample | Specifies the bits per sample for the wFormatTag format type.
*
* @field DWORD | dwRequestMicroSecPerFrame | Specifies the requested frame rate, in microseconds.
*
* @field DWORD | dwPercentDropForError | Specifies the maximum allowable percentage of dropped frames during capture.
*
* @field DWORD | dwNumVideoRequested | This specifies the maximum number of video buffers to allocate.
*
* @field DWORD | dwSupportTSTradeOff | Specifies the usage of temporal/spatial trade off.
*
* @field BOOL | bLive | Specifies if the preview is to be allowed.
*
* @field HWND | hWndParent | Specifies handle of the parent window.
*
* @field DWORD | dwFormatSize | Specifies the size of the actual video format.
*
* @field DWORD | biSize | Specifies the number of bytes required by the spatial information.
*
* @field LONG | biWidth | Specifies the width of the bitmap, in pixels.
*
* @field LONG | biHeight | Specifies the height of the bitmap, in pixels.
*
* @field WORD | biPlanes | Specifies the number of planes for the target device.
*
* @field WORD | biBitCount | Specifies the number of bits per pixel.
*
* @field DWORD | biCompression | Specifies the type of compression.
*
* @field DWORD | biSizeImage | Specifies the size, in bytes, of the image.
*
* @field LONG | biXPelsPerMeter | Specifies the horizontal resolution, in pixels per meter, of the target device for the bitmap.
*
* @field LONG | biYPelsPerMeter | Specifies the vertical resolution, in pixels per meter, of the target device for the bitmap.
*
* @field DWORD | biClrUsed | Specifies the number of color indices in the color table that are actually used by the bitmap.
*
* @field DWORD | biClrImportant | Specifies the number of color indices that are considered important for displaying the bitmap.
*
* @field DWORD | bmiColors[256] | Specifies an array of 256 RGBQUADs.
*
* @type PVIDEOFORMATEX | Pointer to a <t VIDEOFORMATEX> structure.
*
****************************************************************************/
#define VCMAPI WINAPI
/****************************************************************************
vcmStrm Constants
****************************************************************************/
/*****************************************************************************
* @doc EXTERNAL CONSTANTS
*
* @const WAVE_FORMAT_UNKNOWN | VIDEO_FORMAT_UNKNOWN | Constant for unknown video format.
*
* @const BI_RGB | VIDEO_FORMAT_BI_RGB | RGB video format.
*
* @const BI_RLE8 | VIDEO_FORMAT_BI_RLE8 | RLE 8 video format.
*
* @const BI_RLE4 | VIDEO_FORMAT_BI_RLE4 | RLE 4 video format.
*
* @const BI_BITFIELDS | VIDEO_FORMAT_BI_BITFIELDS | RGB Bit Fields video format.
*
* @const MAKEFOURCC('c','v','i','d') | VIDEO_FORMAT_CVID | Cinepack video format.
*
* @const MAKEFOURCC('I','V','3','2') | VIDEO_FORMAT_IV32 | Intel Indeo IV32 video format.
*
* @const MAKEFOURCC('Y','V','U','9') | VIDEO_FORMAT_YVU9 | Intel Indeo YVU9 video format.
*
* @const MAKEFOURCC('M','S','V','C') | VIDEO_FORMAT_MSVC | Microsoft CRAM video format.
*
* @const MAKEFOURCC('M','R','L','E') | VIDEO_FORMAT_MRLE | Microsoft RLE video format.
*
* @const MAKEFOURCC('h','2','6','3') | VIDEO_FORMAT_INTELH263 | Intel H.263 video format.
*
* @const MAKEFOURCC('h','2','6','1') | VIDEO_FORMAT_INTELH261 | Intel H.261 video format.
*
* @const MAKEFOURCC('M','2','6','3') | VIDEO_FORMAT_MSH263 | Microsoft H.263 video format.
*
* @const MAKEFOURCC('M','2','6','1') | VIDEO_FORMAT_MSH261 | Microsoft H.261 video format.
*
* @const MAKEFOURCC('V','D','E','C') | VIDEO_FORMAT_VDEC | Color QuickCam video format.
*
****************************************************************************/
#define VIDEO_FORMAT_UNKNOWN WAVE_FORMAT_UNKNOWN
#define VIDEO_FORMAT_BI_RGB BI_RGB
#define VIDEO_FORMAT_BI_RLE8 BI_RLE8
#define VIDEO_FORMAT_BI_RLE4 BI_RLE4
#define VIDEO_FORMAT_BI_BITFIELDS BI_BITFIELDS
#define VIDEO_FORMAT_CVID MAKEFOURCC('C','V','I','D') // hex: 0x44495643
#define VIDEO_FORMAT_IV31 MAKEFOURCC('I','V','3','1') // hex: 0x31335649
#define VIDEO_FORMAT_IV32 MAKEFOURCC('I','V','3','2') // hex: 0x32335649
#define VIDEO_FORMAT_YVU9 MAKEFOURCC('Y','V','U','9') // hex: 0x39555659
#define VIDEO_FORMAT_I420 MAKEFOURCC('I','4','2','0')
#define VIDEO_FORMAT_IYUV MAKEFOURCC('I','Y','U','V')
#define VIDEO_FORMAT_MSVC MAKEFOURCC('M','S','V','C') // hex: 0x4356534d
#define VIDEO_FORMAT_MRLE MAKEFOURCC('M','R','L','E') // hex: 0x454c524d
#define VIDEO_FORMAT_INTELH263 MAKEFOURCC('H','2','6','3') // hex: 0x33363248
#define VIDEO_FORMAT_INTELH261 MAKEFOURCC('H','2','6','1') // hex: 0x31363248
#define VIDEO_FORMAT_INTELI420 MAKEFOURCC('I','4','2','0') // hex: 0x30323449
#define VIDEO_FORMAT_INTELRT21 MAKEFOURCC('R','T','2','1') // hex: 0x31325452
#define VIDEO_FORMAT_MSH263 MAKEFOURCC('M','2','6','3') // hex: 0x3336324d
#define VIDEO_FORMAT_MSH261 MAKEFOURCC('M','2','6','1') // hex: 0x3136324d
#if !defined(_ALPHA_) && defined(USE_BILINEAR_MSH26X)
#define VIDEO_FORMAT_MSH26X MAKEFOURCC('M','2','6','X') // hex: 0x5836324d
#endif
#define VIDEO_FORMAT_Y411 MAKEFOURCC('Y','4','1','1') // hex:
#define VIDEO_FORMAT_YUY2 MAKEFOURCC('Y','U','Y','2') // hex:
#define VIDEO_FORMAT_YVYU MAKEFOURCC('Y','V','Y','U') // hex:
#define VIDEO_FORMAT_UYVY MAKEFOURCC('U','Y','V','Y') // hex:
#define VIDEO_FORMAT_Y211 MAKEFOURCC('Y','2','1','1') // hex:
// VDOnet VDOWave codec
#define VIDEO_FORMAT_VDOWAVE MAKEFOURCC('V','D','O','W') // hex:
// Color QuickCam video codec
#define VIDEO_FORMAT_VDEC MAKEFOURCC('V','D','E','C') // hex: 0x43454456
// Dec Alpha
#define VIDEO_FORMAT_DECH263 MAKEFOURCC('D','2','6','3') // hex: 0x33363248
#define VIDEO_FORMAT_DECH261 MAKEFOURCC('D','2','6','1') // hex: 0x31363248
// MPEG4 Scrunch codec
#ifdef USE_MPEG4_SCRUNCH
#define VIDEO_FORMAT_MPEG4_SCRUNCH MAKEFOURCC('M','P','G','4') // hex:
#endif
//--------------------------------------------------------------------------;
//
// VCM General API's and Defines
//
//
//
//
//--------------------------------------------------------------------------;
//
// there are four types of 'handles' used by the VCM. the first three
// are unique types that define specific objects:
//
// HVCMDRIVERID: used to _identify_ an VCM driver. this identifier can be
// used to _open_ the driver for querying details, etc about the driver.
//
// HVCMDRIVER: used to manage a driver (codec, filter, etc). this handle
// is much like a handle to other media drivers--you use it to send
// messages to the converter, query for capabilities, etc.
//
// HVCMSTREAM: used to manage a 'stream' (conversion channel) with the
// VCM. you use a stream handle to convert data from one format/type
// to another--much like dealing with a file handle.
//
//
// the fourth handle type is a generic type used on VCM functions that
// can accept two or more of the above handle types (for example the
// vcmMetrics and vcmDriverID functions).
//
// HVCMOBJ: used to identify VCM objects. this handle is used on functions
// that can accept two or more VCM handle types.
//
DECLARE_HANDLE(HVCMDRIVERID);
typedef HVCMDRIVERID *PHVCMDRIVERID;
DECLARE_HANDLE(HVCMDRIVER);
typedef HVCMDRIVER *PHVCMDRIVER;
DECLARE_HANDLE(HVCMSTREAM);
typedef HVCMSTREAM *PHVCMSTREAM;
DECLARE_HANDLE(HVCMOBJ);
typedef HVCMOBJ *PHVCMOBJ;
/****************************************************************************
callback function type
****************************************************************************/
typedef void (CALLBACK* VCMSTREAMPROC) (HVCMSTREAM hvs, UINT uMsg, DWORD_PTR dwInstance, DWORD_PTR dwParam1, DWORD_PTR dwParam2);
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// VCM Error Codes
//
// Note that these error codes are specific errors that apply to the VCM
// directly--general errors are defined as MMSYSERR_*.
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
#ifndef _MMRESULT_
#define _MMRESULT_
typedef UINT MMRESULT;
#endif
/*****************************************************************************
* @doc EXTERNAL CONSTANTS
*
* @const ACMERR_BASE | VCMERR_BASE | Base for video errors.
*
* @const (VCMERR_BASE + 0) | VCMERR_NOTPOSSIBLE | Unsupported video compression format.
*
* @const (VCMERR_BASE + 1) | VCMERR_BUSY | Compression header is already or still queued.
*
* @const (VCMERR_BASE + 2) | VCMERR_UNPREPARED | Compression header is not prepared.
*
* @const (VCMERR_BASE + 3) | VCMERR_CANCELED | User canceled operation.
*
* @const (VCMERR_BASE + 4) | VCMERR_FAILED | Compression operation failed.
*
* @const (VCMERR_BASE + 5) | VCMERR_NOREGENTRY | Failed to read/write registry entry.
*
* @const (VCMERR_BASE + 6) | VCMERR_NONSPECIFIC | Some error occured.
*
* @const (VCMERR_BASE + 7) | VCERR_NOMOREPACKETS | No more packets to receive a payload header.
*
****************************************************************************/
#define VCMERR_BASE ACMERR_BASE
#define VCMERR_NOTPOSSIBLE (VCMERR_BASE + 0)
#define VCMERR_BUSY (VCMERR_BASE + 1)
#define VCMERR_UNPREPARED (VCMERR_BASE + 2)
#define VCMERR_CANCELED (VCMERR_BASE + 3)
#define VCMERR_FAILED (VCMERR_BASE + 4)
#define VCMERR_NOREGENTRY (VCMERR_BASE + 5)
#define VCMERR_NONSPECIFIC (VCMERR_BASE + 6)
#define VCMERR_NOMOREPACKETS (VCMERR_BASE + 7)
#define VCMERR_PSCMISSING (VCMERR_BASE + 8)
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// VCM Window Messages
//
// These window messages are sent by the VCM or VCM drivers to notify
// applications of events.
//
// Note that these window message numbers will also be defined in
// mmsystem.
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
/*****************************************************************************
* @doc EXTERNAL COMPMSG
*
* @msg VCM_OPEN | This message is sent to a video compression callback function when
* a video compression stream is opened.
*
* @parm DWORD | dwParam1 | Currently unused.
*
* @parm DWORD | dwParam2 | Currently unused.
*
* @rdesc None
*
* @xref <m MM_VCM_OPEN>
****************************************************************************/
/*****************************************************************************
* @doc EXTERNAL COMPMSG
*
* @msg MM_VCM_OPEN | This message is sent to a window when a video compression
* stream is opened.
*
* @parm WORD | wParam | Specifies a handle to the video compression stream
* that was opened.
*
* @parm LONG | lParam | Currently unused.
*
* @rdesc None
*
* @xref <m VCM_OPEN>
****************************************************************************/
/*****************************************************************************
* @doc EXTERNAL COMPMSG
*
* @msg VCM_CLOSE | This message is sent to a video compression stream function when
* a video ccompression stream is closed. The stream handle is no longer
* valid once this message has been sent.
*
* @parm DWORD | dwParam1 | Currently unused.
*
* @parm DWORD | dwParam2 | Currently unused.
*
* @rdesc None
*
* @xref <m MM_VCM_CLOSE>
****************************************************************************/
/*****************************************************************************
* @doc EXTERNAL COMPMSG
*
* @msg MM_VCM_CLOSE | This message is sent to a window when a video compression
* stream is closed. The stream handle is no longer valid once this message
* has been sent.
*
* @parm WORD | wParam | Specifies a handle to the video compression stream
* that was closed.
*
* @parm LONG | lParam | Currently unused.
*
* @rdesc None
*
* @xref <m VCM_CLOSE>
****************************************************************************/
/*****************************************************************************
* @doc EXTERNAL COMPMSG
*
* @msg VCM_DONE | This message is sent to a video compression stream callback function when
* video data is present in the compression buffer and the buffer is being
* returned to the application. The message can be sent either when the
* buffer is full, or after the <f acmStreamReset> function is called.
*
* @parm DWORD | dwParam1 | Specifies a far pointer to a <t VCMSTREAMHDR> structure
* identifying the buffer containing the compressed video data.
*
* @parm DWORD | dwParam2 | Currently unused.
*
* @rdesc None
*
* @comm The returned buffer may not be full. Use the <e VCMSTREAMHDR.dwDstBytesUsed>
* field of the <t VCMSTREAMHDR> structure specified by <p dwParam1> to
* determine the number of valid bytes into the returned buffer.
*
* @xref <m MM_VCM_DONE>
****************************************************************************/
/*****************************************************************************
* @doc EXTERNAL COMPMSG
*
* @msg MM_VCM_DONE | This message is sent to a window when video data is
* present in the compression buffer and the buffer is being returned to the
* application. The message can be sent either when the buffer is full, or
* after the <f acmStreamReset> function is called.
*
* @parm WORD | wParam | Specifies a handle to the video compression stream
* that received the compressed video data.
*
* @parm LONG | lParam | Specifies a far pointer to a <t VCMSTREAMHDR> structure
* identifying the buffer containing the compressed video data.
*
* @rdesc None
*
* @comm The returned buffer may not be full. Use the <e VCMSTREAMHDR.dwDstBytesUsed>
* field of the <t VCMSTREAMHDR> structure specified by <p lParam> to
* determine the number of valid bytes into the returned buffer.
*
* @xref <m VCM_DONE>
****************************************************************************/
#define MM_VCM_OPEN (MM_STREAM_OPEN) // conversion callback messages
#define MM_VCM_CLOSE (MM_STREAM_CLOSE)
#define MM_VCM_DONE (MM_STREAM_DONE)
#define VCM_OPEN (MM_STREAM_OPEN) // conversion states
#define VCM_CLOSE (MM_STREAM_CLOSE)
#define VCM_DONE (MM_STREAM_DONE)
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// vcmMetrics()
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
MMRESULT VCMAPI vcmMetrics
(
HVCMOBJ hvo,
UINT uMetric,
LPVOID pMetric
);
#define VCM_METRIC_COUNT_DRIVERS 1
#define VCM_METRIC_COUNT_CODECS 2
#define VCM_METRIC_COUNT_CONVERTERS 3
#define VCM_METRIC_COUNT_FILTERS 4
#define VCM_METRIC_COUNT_DISABLED 5
#define VCM_METRIC_COUNT_HARDWARE 6
#define VCM_METRIC_COUNT_COMPRESSORS 7
#define VCM_METRIC_COUNT_DECOMPRESSORS 8
#define VCM_METRIC_COUNT_LOCAL_DRIVERS 20
#define VCM_METRIC_COUNT_LOCAL_CODECS 21
#define VCM_METRIC_COUNT_LOCAL_CONVERTERS 22
#define VCM_METRIC_COUNT_LOCAL_FILTERS 23
#define VCM_METRIC_COUNT_LOCAL_DISABLED 24
#define VCM_METRIC_HARDWARE_VIDEO_INPUT 30
#define VCM_METRIC_HARDWARE_VIDEO_OUTPUT 31
#define VCM_METRIC_MAX_SIZE_FORMAT 50
#define VCM_METRIC_MAX_SIZE_FILTER 51
#define VCM_METRIC_MAX_SIZE_BITMAPINFOHEADER 52
#define VCM_METRIC_DRIVER_SUPPORT 100
#define VCM_METRIC_DRIVER_PRIORITY 101
//--------------------------------------------------------------------------;
//
// VCM Drivers
//
//
//
//
//--------------------------------------------------------------------------;
#define VCMDM_USER (DRV_USER + 0x0000)
#define VCMDM_RESERVED_LOW (DRV_USER + 0x2000)
#define VCMDM_RESERVED_HIGH (DRV_USER + 0x2FFF)
#define VCMDM_BASE VCMDM_RESERVED_LOW
#define VCMDM_DRIVER_ABOUT (VCMDM_BASE + 11)
//
// VCMDRIVERDETAILS
//
// the VCMDRIVERDETAILS structure is used to get various capabilities from
// an VCM driver (codec, converter, filter).
//
#define VCMDRIVERDETAILS_SHORTNAME_CHARS 16
#define VCMDRIVERDETAILS_LONGNAME_CHARS 128
#define VCMDRIVERDETAILS_MODULE_CHARS 128
/*****************************************************************************
* @doc EXTERNAL COMPSTRUCTENUM
*
* @struct VCMDRIVERDETAILS | The <t VCMDRIVERDETAILS> structure describes
* various details of a Video Compression Manager (VCM) driver.
*
* @field DWORD | dwSize | Specifies the size, in bytes, of the valid
* information contained in the <t VCMDRIVERDETAILS> structure.
* An application should initialize this member to the size, in bytes, of
* the desired information. The size specified in this member must be
* large enough to contain the <e VCMDRIVERDETAILS.dwSize> member of
* the <t VCMDRIVERDETAILS> structure. When the <f vcmDriverDetails>
* function returns, this member contains the actual size of the
* information returned. The returned information will never exceed
* the requested size.
*
* @field FOURCC | fccType | Specifies the type of the driver. For VCM drivers, set
* this member to <p vidc>, which represents VCMDRIVERDETAILS_FCCTYPE_VIDEOCODEC.
*
* @field FOURCC | fccHandler | Specifies a four-character code identifying a specific compressor.
*
* @field DWORD | dwFlags | Specifies applicable flags.
*
* @field DWORD | dwVersion | Specifies version number of the driver.
*
* @field DWORD | dwVersionICM | Specifies theersion of VCM supported by the driver.
* This member should be set to ICVERSION.
*
* @field WCHAR | szName[VCMDRIVERDETAILS_SHORTNAME_CHARS] | Specifies
* a NULL-terminated string that describes the short version of the compressor name.
*
* @field WCHAR | szDescription[VCMDRIVERDETAILS_LONGNAME_CHARS] | Specifies a
* NULL-terminated string that describes the long version of the compressor name.
*
* @field WCHAR | szDriver[VCMDRIVERDETAILS_MODULE_CHARS] | Specifies
* a NULL-terminated string that provides the name of the module containing the VCM compression driver.
*
* @xref <f vcmDriverDetails>
****************************************************************************/
// This structure is equivalent to ICINFO
typedef struct tVCMDRIVERDETAILS
{
DWORD dwSize; // Size, in bytes, of this structure
DWORD fccType; // Four-character code indicating the type of stream being compressed or decompressed. Specify "VIDC" for video streams.
DWORD fccHandler; // A four-character code identifying a specific compressor
DWORD dwFlags; // Applicable flags
DWORD dwVersion; // Version number of the driver
DWORD dwVersionICM; // Version of VCM supported by the driver. This member should be set to ICVERSION
WCHAR szName[VCMDRIVERDETAILS_SHORTNAME_CHARS]; // Short version of the compressor name
WCHAR szDescription[VCMDRIVERDETAILS_LONGNAME_CHARS]; // Long version of the compressor name
WCHAR szDriver[VCMDRIVERDETAILS_MODULE_CHARS]; // Name of the module containing VCM compression driver. Normally, a driver does not need to fill this out.
} VCMDRIVERDETAILS, *PVCMDRIVERDETAILS;
#define VCMDRIVERDETAILS_FCCTYPE_VIDEOCODEC mmioFOURCC('v', 'i', 'd', 'c')
#define VCMDRIVERDETAILS_FCCCOMP_UNDEFINED mmioFOURCC('\0', '\0', '\0', '\0')
MMRESULT VCMAPI vcmDriverDetails
(
PVCMDRIVERDETAILS pvdd
);
//--------------------------------------------------------------------------;
//
// VCM Format Tags
//
//
//
//
//--------------------------------------------------------------------------;
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// vcmFormatTagDetails()
//
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
#define VCMFORMATTAGDETAILS_FORMATTAG_CHARS 48
typedef struct tVCMFORMATTAGDETAILSA
{
DWORD cbStruct;
DWORD dwFormatTagIndex;
DWORD dwFormatTag;
DWORD cbFormatSize;
DWORD fdwSupport;
DWORD cStandardFormats;
char szFormatTag[VCMFORMATTAGDETAILS_FORMATTAG_CHARS];
} VCMFORMATTAGDETAILSA, *PVCMFORMATTAGDETAILSA;
typedef struct tVCMFORMATTAGDETAILSW
{
DWORD cbStruct;
DWORD dwFormatTagIndex;
DWORD dwFormatTag;
DWORD cbFormatSize;
DWORD fdwSupport;
DWORD cStandardFormats;
WCHAR szFormatTag[VCMFORMATTAGDETAILS_FORMATTAG_CHARS];
} VCMFORMATTAGDETAILSW, *PVCMFORMATTAGDETAILSW;
#ifdef _UNICODE
#define VCMFORMATTAGDETAILS VCMFORMATTAGDETAILSW
#define PVCMFORMATTAGDETAILS PVCMFORMATTAGDETAILSW
#else
#define VCMFORMATTAGDETAILS VCMFORMATTAGDETAILSA
#define PVCMFORMATTAGDETAILS PVCMFORMATTAGDETAILSA
#endif
#define VCM_FORMATTAGDETAILSF_INDEX 0x00000000L
#define VCM_FORMATTAGDETAILSF_FORMATTAG 0x00000001L
#define VCM_FORMATTAGDETAILSF_LARGESTSIZE 0x00000002L
#define VCM_FORMATTAGDETAILSF_QUERYMASK 0x0000000FL
//--------------------------------------------------------------------------;
//
// VCM Formats
//
//
//
//
//--------------------------------------------------------------------------;
#define VCMFORMATDETAILS_FORMAT_CHARS 128
/*****************************************************************************
* @doc EXTERNAL COMPSTRUCTENUM
*
* @struct VCMFORMATDETAILS | The <t VCMFORMATDETAILS> structure details a
* video format.
*
* @field DWORD | cbStruct | Specifies the size, in bytes, of the
* <t VCMFORMATDETAILS> structure. This member must be initialized
* before calling the <f vcmFormatDetails> or <f vcmFormatEnum>
* functions. The size specified in this member must be large enough to
* contain the base <t VCMFORMATDETAILS> structure. When the
* <f vcmFormatDetails> function returns, this member contains the
* actual size of the information returned. The returned information
* will never exceed the requested size.
*
* @field DWORD | dwFormatTag | Specifies the video format tag that the
* <t VCMFORMATDETAILS> structure describes. This member is always
* returned if the <f vcmFormatDetails> is successful. This member
* should be set to VIDEO_FORMAT_UNKNOWN before calling <f vcmFormatDetails>.
*
* @field DWORD | dwFlags | Specifies if the format the <p pvfx> field points
* to is a format that can be generated by the capture driver + codec, decompressed
* by the codec, or both.
*
* @flag VCM_FORMATENUMF_INPUT | Specifies that the format enumerated can be transmitted.
*
* @flag VCM_FORMATENUMF_OUTPUT | Specifies that the format enumerated can be received.
*
* @flag VCM_FORMATENUMF_BOTH | Specifies that the format enumerated can be transmitted and received.
*
* @field PVIDEOFORMATEX | pvfx | Specifies a pointer to a <t VIDEOFORMATEX>
* data structure that will receive the format details. This structure requires no initialization
* by the application.
*
* @field DWORD | cbvfx | Specifies the size, in bytes, available for
* the <e VCMFORMATDETAILS.pvfx> to receive the format details. The
* <f vcmMetrics> function can be used to
* determine the maximum size required for any format available for
* all installed VCM drivers.
*
* @field char | szFormat[VCMFORMATDETAILS_FORMAT_CHARS] |
* Specifies a string that describes the format for the
* <e VCMFORMATDETAILS.dwFormatTag> type. This string is always returned
* if the <f vcmFormatDetails> function is successful.
*
* @xref <f vcmFormatDetails> <f vcmFormatEnum>
****************************************************************************/
typedef struct tVCMFORMATDETAILS
{
DWORD cbStruct;
DWORD dwFormatTag;
DWORD dwFlags;
PVIDEOFORMATEX pvfx;
DWORD cbvfx;
WCHAR szFormat[VCMFORMATDETAILS_FORMAT_CHARS];
} VCMFORMATDETAILS, *PVCMFORMATDETAILS;
MMRESULT VCMAPI vcmFormatDetails
(
PVCMFORMATDETAILS pvfd
);
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// vcmFormatEnum()
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
/****************************************************************************
* @doc EXTERNAL COMPFUNC
*
* @func BOOL VCMFORMATENUMCB | vcmFormatEnumCallback |
* The <f ccmFormatEnumCallback> function refers to the callback function used for
* Video Compression Manager (VCM) video format detail enumeration. The
* <f vcmFormatEnumCallback> is a placeholder for the application-supplied
* function name.
*
* @parm HVCMDRIVERID | hvdid | Specifies a VCM driver identifier.
*
* @parm PVCMDRIVERDETAILS | pvfd | Specifies a pointer to a
* <t VCMDRIVERDETAILS> structure that contains the enumerated
* driver details.
*
* @parm PVCMFORMATDETAILS | pvfd | Specifies a pointer to a
* <t VCMFORMATDETAILS> structure that contains the enumerated
* format details.
*
* @parm DWORD | dwInstance | Specifies the application-defined value
* specified in the <f vcmFormatEnum> function.
*
* @rdesc The callback function must return TRUE to continue enumeration;
* to stop enumeration, it must return FALSE.
*
* @comm The <f vcmFormatEnum> function will return MMSYSERR_NOERROR
* (zero) if no formats are to be enumerated. Moreover, the callback
* function will not be called.
*
* @xref <f vcmFormatEnum> <f vcmFormatDetails>
***************************************************************************/
typedef BOOL (CALLBACK *VCMFORMATENUMCB)
(
HVCMDRIVERID hvdid,
PVCMDRIVERDETAILS pvdd,
PVCMFORMATDETAILS pvfd,
DWORD_PTR dwInstance
);
MMRESULT VCMAPI vcmFormatEnum
(
UINT uDevice,
VCMFORMATENUMCB fnCallback,
PVCMDRIVERDETAILS pvdd,
PVCMFORMATDETAILS pvfd,
DWORD_PTR dwInstance,
DWORD fdwEnum
);
//#define VCM_FORMATENUMF_WFORMATTAG 0x00010000L
//#define VCM_FORMATENUMF_NCHANNELS 0x00020000L
//#define VCM_FORMATENUMF_NSAMPLESPERSEC 0x00040000L
//#define VCM_FORMATENUMF_WBITSPERSAMPLE 0x00080000L
//#define VCM_FORMATENUMF_CONVERT 0x00100000L
//#define VCM_FORMATENUMF_SUGGEST 0x00200000L
#define VCM_FORMATENUMF_INPUT 0x00400000L
#define VCM_FORMATENUMF_OUTPUT 0x00800000L
#define VCM_FORMATENUMF_BOTH 0x01000000L
#define VCM_FORMATENUMF_TYPEMASK 0x01C00000L
#define VCM_FORMATENUMF_APP 0x00000000L
#define VCM_FORMATENUMF_ALL 0x02000000L
#define VCM_FORMATENUMF_ALLMASK VCM_FORMATENUMF_ALL
typedef struct
{
WORD biWidth;
WORD biHeight;
} MYFRAMESIZE;
typedef struct
{
DWORD fccType;
DWORD fccHandler;
MYFRAMESIZE framesize[3];
} VCM_APP_ICINFO, *PVCM_APP_ICINFO;
typedef struct
{
DWORD dwRes;
MYFRAMESIZE framesize;
} NCAP_APP_INFO, *PNCAP_APP_INFO;
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// vcmFormatSuggest()
//
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
MMRESULT VCMAPI vcmFormatSuggest
(
UINT uDevice,
HVCMDRIVER hvd,
PVIDEOFORMATEX pvfxSrc,
PVIDEOFORMATEX pvfxDst,
DWORD cbvfxDst,
DWORD fdwSuggest
);
#define VCM_FORMATSUGGESTF_DST_WFORMATTAG 0x00010000L
#define VCM_FORMATSUGGESTF_DST_NSAMPLESPERSEC 0x00020000L
#define VCM_FORMATSUGGESTF_DST_WBITSPERSAMPLE 0x00040000L
#define VCM_FORMATSUGGESTF_SRC_WFORMATTAG 0x00100000L
#define VCM_FORMATSUGGESTF_SRC_NSAMPLESPERSEC 0x00200000L
#define VCM_FORMATSUGGESTF_SRC_WBITSPERSAMPLE 0x00400000L
#define VCM_FORMATSUGGESTF_TYPEMASK 0x00FF0000L
//--------------------------------------------------------------------------;
//
// VCM Stream API's
//
//
//
//--------------------------------------------------------------------------;
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// vcmStreamOpen()
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
/*****************************************************************************
* @doc EXTERNAL COMPSTRUCTENUM
*
* @struct VCMSTREAMHEADER | The <t VCMSTREAMHEADER> structure defines the
* header used to identify an Video Compression Manager (VCM) conversion
* source and destination buffer pair for a conversion stream.
*
* @field DWORD | cbStruct | Specifies the size, in bytes, of the
* <t VCMSTREAMHEADER> structure. This member must be initialized
* before calling any VCM stream functions using this structure.
* The size specified in this member must be large enough to contain
* the base <t VCMSTREAMHEADER> structure.
*
* @field DWORD | fdwStatus | Specifies flags giving information about
* the conversion buffers. This member must be initialized to zero
* before calling <f vcmStreamPrepareHeader> and should not be modified
* by the application while the stream header remains prepared.
*
* @flag VCMSTREAMHEADER_STATUSF_DONE | Set by the VCM or driver to
* indicate that it is finished with the conversion and is returning it
* to the application.
*
* @flag VCMSTREAMHEADER_STATUSF_PREPARED | Set by the VCM to indicate
* that the data buffers have been prepared with <f acmStreamPrepareHeader>.
*
* @flag VCMSTREAMHEADER_STATUSF_INQUEUE | Set by the VCM or driver to
* indicate that the data buffers are queued for conversion.
*
* @field DWORD | dwUser | Specifies 32 bits of user data. This can be any
* instance data specified by the application.
*
* @field PBYTE | pbSrc | Specifies a pointer to the source data buffer.
* This pointer must always refer to the same location while the stream
* header remains prepared. If an application needs to change the
* source location, it must unprepare the header and re-prepare it
* with the alternate location.
*
* @field DWORD | cbSrcLength | Specifies the length, in bytes, of the source
* data buffer pointed to by <e VCMSTREAMHEADER.pbSrc>. When the
* header is prepared, this member must specify the maximum size
* that will be used in the source buffer. Conversions can be performed
* on source lengths less than or equal to the original prepared size.
* However, this member must be reset to the original size when
* unpreparing the header.
*
* @field DWORD | cbSrcLengthUsed | Specifies the amount of data, in bytes,
* used for the conversion. This member is not valid until the
* conversion is complete. Note that this value can be less than or
* equal to <e VCMSTREAMHEADER.cbSrcLength>. An application must use
* the <e VCMSTREAMHEADER.cbSrcLengthUsed> member when advancing to
* the next piece of source data for the conversion stream.
*
* @field DWORD | dwSrcUser | Specifies 32 bits of user data. This can be
* any instance data specified by the application.
*
* @field PBYTE | pbDst | Specifies a pointer to the destination data
* buffer. This pointer must always refer to the same location while
* the stream header remains prepared. If an application needs to change
* the destination location, it must unprepare the header and re-prepare
* it with the alternate location.
*
* @field DWORD | cbDstLength | Specifies the length, in bytes, of the
* destination data buffer pointed to by <e VCMSTREAMHEADER.pbDst>.
* When the header is prepared, this member must specify the maximum
* size that will be used in the destination buffer. Conversions can be
* performed to destination lengths less than or equal to the original
* prepared size. However, this member must be reset to the original
* size when unpreparing the header.
*
* @field DWORD | cbDstLengthUsed | Specifies the amount of data, in bytes,
* returned by a conversion. This member is not valid until the
* conversion is complete. Note that this value may be less than or
* equal to <e ACMSTREAMHEADER.cbDstLength>. An application must use
* the <e ACMSTREAMHEADER.cbDstLengthUsed> member when advancing to
* the next destination location for the conversion stream.
*
* @field DWORD | dwDstUser | Specifies 32 bits of user data. This can be
* any instance data specified by the application.
*
* @field PBYTE | pbPrev | Specifies a pointer to the previous destination data
* buffer. This pointer must always refer to the same location while
* the stream header remains prepared. If an application needs to change
* the destination location, it must unprepare the header and re-prepare
* it with the alternate location.
*
* @field DWORD | cbPrevLength | Specifies the length, in bytes, of the previous
* destination data buffer pointed to by <e VCMSTREAMHEADER.pbPrev>.
* When the header is prepared, this member must specify the maximum
* size that will be used in the destination buffer. Conversions can be
* performed to destination lengths less than or equal to the original
* prepared size. However, this member must be reset to the original
* size when unpreparing the header.
*
* @field DWORD | cbPrevLengthUsed | Specifies the amount of data, in bytes,
* returned by a conversion. This member is not valid until the
* conversion is complete. Note that this value may be less than or
* equal to <e VCMSTREAMHEADER.cbPrevLength>. An application must use
* the <e VCMSTREAMHEADER.cbPrevLengthUsed> member when advancing to
* the next destination location for the conversion stream.
*
* @field DWORD | dwDstUser | Specifies 32 bits of user data. This can be
* any instance data specified by the application.
*
* @field struct tVCMSTREAMHEADER * | lpNext | Reserved for driver use and should not be
* used. Typically, this maintains a linked list of buffers in the queue.
*
* @field DWORD | reserved | Reserved for driver use and should not be used.
*
* @type PVCMSTREAMHEADER | Pointer to a <t VCMSTREAMHEADER> structure.
*
* @comm Before an <t VCMSTREAMHEADER> structure can be used for a conversion, it must
* be prepared with <f vcmStreamPrepareHeader>. When an application
* is finished with an <t VCMSTREAMHEADER> structure, the <f vcmStreamUnprepareHeader>
* function must be called before freeing the source and destination buffers.
*
* @xref <f vcmStreamPrepareHeader> <f vcmStreamUnprepareHeader>
* <f vcmStreamConvert>
****************************************************************************/
typedef struct tVCMSTREAMHEADER
{
DWORD cbStruct; // sizeof(VCMSTREAMHEADER)
DWORD fdwStatus; // status flags
DWORD dwUser; // user instance data for hdr
PBYTE pbSrc;
DWORD cbSrcLength;
DWORD cbSrcLengthUsed;
DWORD dwSrcUser; // user instance data for src
PBYTE pbDst;
DWORD cbDstLength;
DWORD cbDstLengthUsed;
DWORD dwDstUser; // user instance data for dst
PBYTE pbPrev;
DWORD cbPrevLength;
DWORD cbPrevLengthUsed;
DWORD dwPrevUser; // user instance data for prev
struct tVCMSTREAMHEADER *pNext; // reserved for driver
DWORD reserved; // reserved for driver
} VCMSTREAMHEADER, *PVCMSTREAMHEADER;
typedef struct tVCMSTREAM
{
HVCMDRIVER hIC; // Handle to driver (HIC)
DWORD dwICInfoFlags; // Some properties of the compressor
HWND hWndParent; // Handle to the parent window
DWORD_PTR dwCallback; // Callback function, event, thread or window
DWORD_PTR dwCallbackInstance; // User instance data
DWORD fdwOpen; // Defines type of callback
struct tVCMSTREAMHEADER *pvhLast; // Last of the list
struct tVCMSTREAMHEADER *pvhFirst; // First of the list
PVIDEOFORMATEX pvfxSrc; // Format of input buffers
PVIDEOFORMATEX pvfxDst; // Format of output buffers
BITMAPINFOHEADER *pbmiPrev; // Format of previous buffers
UINT cSrcPrepared; // Number of input headers prepared
UINT cDstPrepared; // Number of output headers prepared
DWORD dwFrame; // Current frame number
DWORD dwQuality; // Compression quality value
DWORD dwMaxPacketSize; // Targeted max packet size for encode
DWORD fdwStream; // Stream state flags, etc.
CRITICAL_SECTION crsFrameNumber; // Used to allow the UI to request an I-Frame
DWORD dwLastTimestamp; // Last known good timestamp
DWORD dwTargetByterate; // Target bitrate
DWORD dwTargetFrameRate; // Target frame rate
BOOL fPeriodicIFrames; // Set to TRUE if we need to generate I-Frames periodically
DWORD dwLastIFrameTime; // Holds the last time an I-Frame was generated
} VCMSTREAM, *PVCMSTREAM;
//
// VCMSTREAMHEADER.fdwStatus
//
// VCMSTREAMHEADER_STATUSF_DONE: done bit for async conversions.
//
#define VCMSTREAMHEADER_STATUSF_DONE 0x00010000L
#define VCMSTREAMHEADER_STATUSF_PREPARED 0x00020000L
#define VCMSTREAMHEADER_STATUSF_INQUEUE 0x00100000L
MMRESULT VCMAPI vcmStreamOpen
(
PHVCMSTREAM phas, // pointer to stream handle
HVCMDRIVER had, // optional driver handle
PVIDEOFORMATEX pvfxSrc, // source format to convert
PVIDEOFORMATEX pvfxDst, // required destination format
DWORD dwImageQuality, // image compression factor
DWORD dwPacketSize, // target fragment size
DWORD_PTR dwCallback, // callback
DWORD_PTR dwInstance, // callback instance data
DWORD fdwOpen // VCM_STREAMOPENF_* and CALLBACK_*
);
#define VCM_STREAMOPENF_QUERY 0x00000001
#define VCM_STREAMOPENF_ASYNC 0x00000002
#define VCM_STREAMOPENF_NONREALTIME 0x00000004
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// vcmStreamClose()
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
MMRESULT VCMAPI vcmStreamClose
(
HVCMSTREAM hvs
);
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// vcmStreamSize()
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
MMRESULT VCMAPI vcmStreamSize
(
HVCMSTREAM has,
DWORD cbInput,
PDWORD pdwOutputBytes,
DWORD fdwSize
);
#define VCM_STREAMSIZEF_SOURCE 0x00000000L
#define VCM_STREAMSIZEF_DESTINATION 0x00000001L
#define VCM_STREAMSIZEF_QUERYMASK 0x0000000FL
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// vcmStreamReset()
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
MMRESULT VCMAPI vcmStreamReset
(
HVCMSTREAM has
);
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// vcmStreamMessage()
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
MMRESULT VCMAPI vcmStreamMessage
(
HVCMSTREAM has,
UINT uMsg,
LPARAM lParam1,
LPARAM lParam2
);
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// vcmStreamConvert()
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
MMRESULT VCMAPI vcmStreamConvert
(
HVCMSTREAM has,
PVCMSTREAMHEADER pash,
DWORD fdwConvert
);
#define VCM_STREAMCONVERTF_BLOCKALIGN 0x00000004
#define VCM_STREAMCONVERTF_START 0x00000010
#define VCM_STREAMCONVERTF_END 0x00000020
#define VCM_STREAMCONVERTF_FORCE_KEYFRAME 0x00000040
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// vcmStreamPrepareHeader()
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
MMRESULT VCMAPI vcmStreamPrepareHeader
(
HVCMSTREAM has,
PVCMSTREAMHEADER pash,
DWORD fdwPrepare
);
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// vcmStreamUnprepareHeader()
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
MMRESULT VCMAPI vcmStreamUnprepareHeader
(
HVCMSTREAM has,
PVCMSTREAMHEADER pash,
DWORD fdwUnprepare
);
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// Device Capabilities Functions
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
MMRESULT VCMAPI vcmGetDevCaps(UINT uDevice, PVIDEOINCAPS pvc, UINT cbvc);
MMRESULT VCMAPI vcmDevCapsReadFromReg(LPSTR szDeviceName, LPSTR szDeviceVersion, PVIDEOINCAPS pvc, UINT cbvc);
MMRESULT VCMAPI vcmDevCapsProfile(UINT uDevice, PVIDEOINCAPS pvc, UINT cbvc);
MMRESULT VCMAPI vcmDevCapsWriteToReg(LPSTR szDeviceName, LPSTR szDeviceVersion, PVIDEOINCAPS pvc, UINT cbvc);
MMRESULT VCMAPI vcmGetDevCapsFrameSize(PVIDEOFORMATEX pvfx, PINT piWidth, PINT piHeight);
MMRESULT VCMAPI vcmGetDevCapsPreferredFormatTag(UINT uDevice, PDWORD pdwFormatTag);
MMRESULT VCMAPI vcmGetDevCapsStreamingMode(UINT uDevice, PDWORD pdwStreamingMode);
MMRESULT VCMAPI vcmGetDevCapsDialogs(UINT uDevice, PDWORD pdwDialogs);
MMRESULT VCMAPI vcmReleaseResources();
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// Post-processing Functions
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
BOOL VCMAPI vcmStreamIsPostProcessingSupported(HVCMSTREAM hvs);
MMRESULT VCMAPI vcmStreamSetBrightness(HVCMSTREAM hvs, DWORD dwBrightness);
MMRESULT VCMAPI vcmStreamSetContrast(HVCMSTREAM hvs, DWORD dwContrast);
MMRESULT VCMAPI vcmStreamSetSaturation(HVCMSTREAM hvs, DWORD dwSaturation);
MMRESULT VCMAPI vcmStreamSetImageQuality(HVCMSTREAM hvs, DWORD dwImageQuality);
#define PLAYBACK_CUSTOM_START (ICM_RESERVED_HIGH + 1)
#define PLAYBACK_CUSTOM_CHANGE_BRIGHTNESS (PLAYBACK_CUSTOM_START + 0)
#define PLAYBACK_CUSTOM_CHANGE_CONTRAST (PLAYBACK_CUSTOM_START + 1)
#define PLAYBACK_CUSTOM_CHANGE_SATURATION (PLAYBACK_CUSTOM_START + 2)
#define G723MAGICWORD1 0xf7329ace
#define G723MAGICWORD2 0xacdeaea2
#define CUSTOM_ENABLE_CODEC (ICM_RESERVED_HIGH+201)
#define VCM_MAX_BRIGHTNESS 255UL
#define VCM_MIN_BRIGHTNESS 1UL
#define VCM_RESET_BRIGHTNESS 256UL
#define VCM_DEFAULT_BRIGHTNESS 128UL
#define VCM_MAX_CONTRAST 255UL
#define VCM_MIN_CONTRAST 1UL
#define VCM_RESET_CONTRAST 256UL
#define VCM_DEFAULT_CONTRAST 128UL
#define VCM_MAX_SATURATION 255UL
#define VCM_MIN_SATURATION 1UL
#define VCM_RESET_SATURATION 256UL
#define VCM_DEFAULT_SATURATION 128UL
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// Custom Encoder Control Functions
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
MMRESULT VCMAPI vcmStreamSetMaxPacketSize(HVCMSTREAM hvs, DWORD dwMaxPacketSize);
#define CUSTOM_START (ICM_RESERVED_HIGH + 1)
#define CODEC_CUSTOM_ENCODER_CONTROL (CUSTOM_START + 9)
// CUSTOM_ENCODER_CONTROL: HIWORD(lParam1)
#define EC_SET_CURRENT 0
#define EC_GET_FACTORY_DEFAULT 1
#define EC_GET_FACTORY_LIMITS 2
#define EC_GET_CURRENT 3
#define EC_RESET_TO_FACTORY_DEFAULTS 4
// CUSTOM_ENCODER_CONTROL: LOWORD(lParam1)
#define EC_RTP_HEADER 0
#define EC_RESILIENCY 1
#define EC_PACKET_SIZE 2
#define EC_PACKET_LOSS 3
#define EC_BITRATE_CONTROL 4
#define EC_BITRATE 5
#define VCM_MAX_PACKET_SIZE 9600UL
#define VCM_MIN_PACKET_SIZE 64UL
#define VCM_RESET_PACKET_SIZE 512UL
#define VCM_DEFAULT_PACKET_SIZE 512UL
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// Compression Ratio and Compression Options Functions
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
MMRESULT VCMAPI vcmStreamSetImageQuality(HVCMSTREAM hvs, DWORD dwImageQuality);
MMRESULT VCMAPI vcmStreamRequestIFrame(HVCMSTREAM hvs);
MMRESULT VCMAPI vcmStreamPeriodicIFrames(HVCMSTREAM hvs, BOOL fPeriodicIFrames);
MMRESULT VCMAPI vcmStreamSetTargetRates(HVCMSTREAM hvs, DWORD dwTargetFrameRate, DWORD dwTargetByterate);
#define MIN_IFRAME_REQUEST_INTERVAL 15000
#define VCM_MAX_IMAGE_QUALITY 0UL
#define VCM_MIN_IMAGE_QUALITY 31UL
#define VCM_RESET_IMAGE_QUALITY VCM_MAX_IMAGE_QUALITY
#define VCM_DEFAULT_IMAGE_QUALITY VCM_MAX_IMAGE_QUALITY
#define VCM_MAX_FRAME_RATE 2997UL
#define VCM_MIN_FRAME_RATE 20UL
#define VCM_RESET_FRAME_RATE 700UL
#define VCM_DEFAULT_FRAME_RATE 700UL
#define VCM_MAX_BYTE_RATE 187500UL
#define VCM_MIN_BYTE_RATE 1UL
#define VCM_RESET_BYTE_RATE 1664UL
#define VCM_DEFAULT_BYTE_RATE 1664UL
#define VCM_MAX_FRAME_SIZE 32768UL
#define VCM_MIN_FRAME_SIZE 1UL
#define VCM_RESET_FRAME_SIZE 235UL
#define VCM_DEFAULT_FRAME_SIZE 235UL
#define VCM_MAX_TRADE_OFF 31UL
#define VCM_MIN_TRADE_OFF 1UL
#define VCM_RESET_TRADE_OFF 31UL
#define VCM_DEFAULT_TRADE_OFF 31UL
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
//
// RTP Payload Functions
//
//
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ;
MMRESULT VCMAPI vcmStreamFormatPayload(HVCMSTREAM hvs, PBYTE pDataSrc, DWORD dwDataSize, PBYTE *ppDataPkt, PDWORD pdwPktSize,
PDWORD pdwPktCount, UINT *pfMark, PBYTE *pHdrInfo,PDWORD pdwHdrSize);
MMRESULT VCMAPI vcmStreamRestorePayload(HVCMSTREAM hvs, WSABUF *ppDataPkt, DWORD dwPktCount, PBYTE pbyFrame, PDWORD pdwFrameSize, BOOL *pfReceivedKeyframe);
MMRESULT VCMAPI vcmStreamGetPayloadHeaderSize(HVCMSTREAM hvs, PDWORD pdwPayloadHeaderSize);
#ifdef __cplusplus
} /* End of extern "C" { */
#endif /* __cplusplus */
#pragma pack() /* Revert to default packing */
#endif /* _INC_VCM */