2012-03-22 06:04:31 +00:00
|
|
|
/* -LICENSE-START-
|
2020-10-07 16:33:35 +00:00
|
|
|
** Copyright (c) 2019 Blackmagic Design
|
2012-03-22 06:04:31 +00:00
|
|
|
**
|
|
|
|
** Permission is hereby granted, free of charge, to any person or organization
|
|
|
|
** obtaining a copy of the software and accompanying documentation covered by
|
|
|
|
** this license (the "Software") to use, reproduce, display, distribute,
|
|
|
|
** execute, and transmit the Software, and to prepare derivative works of the
|
|
|
|
** Software, and to permit third-parties to whom the Software is furnished to
|
|
|
|
** do so, all subject to the following:
|
|
|
|
**
|
|
|
|
** The copyright notices in the Software and this entire statement, including
|
|
|
|
** the above license grant, this restriction and the following disclaimer,
|
|
|
|
** must be included in all copies of the Software, in whole or in part, and
|
|
|
|
** all derivative works of the Software, unless such copies or derivative
|
|
|
|
** works are solely in the form of machine-executable object code generated by
|
|
|
|
** a source language processor.
|
|
|
|
**
|
|
|
|
** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
** IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
** FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
|
|
|
|
** SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
|
|
|
|
** FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
|
|
|
|
** ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
|
|
** DEALINGS IN THE SOFTWARE.
|
|
|
|
** -LICENSE-END-
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef BMD_DECKLINKAPIMODES_H
|
|
|
|
#define BMD_DECKLINKAPIMODES_H
|
|
|
|
|
2014-12-03 13:42:43 +00:00
|
|
|
|
|
|
|
#ifndef BMD_CONST
|
|
|
|
#if defined(_MSC_VER)
|
|
|
|
#define BMD_CONST __declspec(selectany) static const
|
|
|
|
#else
|
|
|
|
#define BMD_CONST static const
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2020-02-27 11:32:17 +00:00
|
|
|
#ifndef BMD_PUBLIC
|
|
|
|
#define BMD_PUBLIC
|
|
|
|
#endif
|
|
|
|
|
2012-03-22 06:04:31 +00:00
|
|
|
// Type Declarations
|
|
|
|
|
|
|
|
|
|
|
|
// Interface ID Declarations
|
|
|
|
|
2014-12-03 13:42:43 +00:00
|
|
|
BMD_CONST REFIID IID_IDeckLinkDisplayModeIterator = /* 9C88499F-F601-4021-B80B-032E4EB41C35 */ {0x9C,0x88,0x49,0x9F,0xF6,0x01,0x40,0x21,0xB8,0x0B,0x03,0x2E,0x4E,0xB4,0x1C,0x35};
|
|
|
|
BMD_CONST REFIID IID_IDeckLinkDisplayMode = /* 3EB2C1AB-0A3D-4523-A3AD-F40D7FB14E78 */ {0x3E,0xB2,0xC1,0xAB,0x0A,0x3D,0x45,0x23,0xA3,0xAD,0xF4,0x0D,0x7F,0xB1,0x4E,0x78};
|
2012-03-22 06:04:31 +00:00
|
|
|
|
|
|
|
/* Enum BMDDisplayMode - Video display modes */
|
|
|
|
|
|
|
|
typedef uint32_t BMDDisplayMode;
|
|
|
|
enum _BMDDisplayMode {
|
|
|
|
|
|
|
|
/* SD Modes */
|
|
|
|
|
|
|
|
bmdModeNTSC = 'ntsc',
|
|
|
|
bmdModeNTSC2398 = 'nt23', // 3:2 pulldown
|
|
|
|
bmdModePAL = 'pal ',
|
|
|
|
bmdModeNTSCp = 'ntsp',
|
|
|
|
bmdModePALp = 'palp',
|
|
|
|
|
|
|
|
/* HD 1080 Modes */
|
|
|
|
|
|
|
|
bmdModeHD1080p2398 = '23ps',
|
|
|
|
bmdModeHD1080p24 = '24ps',
|
|
|
|
bmdModeHD1080p25 = 'Hp25',
|
|
|
|
bmdModeHD1080p2997 = 'Hp29',
|
|
|
|
bmdModeHD1080p30 = 'Hp30',
|
2020-10-07 16:33:35 +00:00
|
|
|
bmdModeHD1080p4795 = 'Hp47',
|
|
|
|
bmdModeHD1080p48 = 'Hp48',
|
2012-03-22 06:04:31 +00:00
|
|
|
bmdModeHD1080p50 = 'Hp50',
|
|
|
|
bmdModeHD1080p5994 = 'Hp59',
|
|
|
|
bmdModeHD1080p6000 = 'Hp60', // N.B. This _really_ is 60.00 Hz.
|
2020-10-07 16:33:35 +00:00
|
|
|
bmdModeHD1080p9590 = 'Hp95',
|
|
|
|
bmdModeHD1080p96 = 'Hp96',
|
|
|
|
bmdModeHD1080p100 = 'Hp10',
|
|
|
|
bmdModeHD1080p11988 = 'Hp11',
|
|
|
|
bmdModeHD1080p120 = 'Hp12',
|
2020-02-27 11:32:17 +00:00
|
|
|
bmdModeHD1080i50 = 'Hi50',
|
|
|
|
bmdModeHD1080i5994 = 'Hi59',
|
|
|
|
bmdModeHD1080i6000 = 'Hi60', // N.B. This _really_ is 60.00 Hz.
|
2012-03-22 06:04:31 +00:00
|
|
|
|
|
|
|
/* HD 720 Modes */
|
|
|
|
|
|
|
|
bmdModeHD720p50 = 'hp50',
|
|
|
|
bmdModeHD720p5994 = 'hp59',
|
|
|
|
bmdModeHD720p60 = 'hp60',
|
|
|
|
|
2020-02-27 11:32:17 +00:00
|
|
|
/* 2K Modes */
|
2012-03-22 06:04:31 +00:00
|
|
|
|
|
|
|
bmdMode2k2398 = '2k23',
|
|
|
|
bmdMode2k24 = '2k24',
|
|
|
|
bmdMode2k25 = '2k25',
|
|
|
|
|
2020-02-27 11:32:17 +00:00
|
|
|
/* 2K DCI Modes */
|
2014-12-03 13:42:43 +00:00
|
|
|
|
|
|
|
bmdMode2kDCI2398 = '2d23',
|
|
|
|
bmdMode2kDCI24 = '2d24',
|
|
|
|
bmdMode2kDCI25 = '2d25',
|
2020-02-27 11:32:17 +00:00
|
|
|
bmdMode2kDCI2997 = '2d29',
|
|
|
|
bmdMode2kDCI30 = '2d30',
|
2020-10-07 16:33:35 +00:00
|
|
|
bmdMode2kDCI4795 = '2d47',
|
|
|
|
bmdMode2kDCI48 = '2d48',
|
2020-02-27 11:32:17 +00:00
|
|
|
bmdMode2kDCI50 = '2d50',
|
|
|
|
bmdMode2kDCI5994 = '2d59',
|
|
|
|
bmdMode2kDCI60 = '2d60',
|
2020-10-07 16:33:35 +00:00
|
|
|
bmdMode2kDCI9590 = '2d95',
|
|
|
|
bmdMode2kDCI96 = '2d96',
|
|
|
|
bmdMode2kDCI100 = '2d10',
|
|
|
|
bmdMode2kDCI11988 = '2d11',
|
|
|
|
bmdMode2kDCI120 = '2d12',
|
2014-12-03 13:42:43 +00:00
|
|
|
|
2020-02-27 11:32:17 +00:00
|
|
|
/* 4K UHD Modes */
|
2014-12-03 13:42:43 +00:00
|
|
|
|
|
|
|
bmdMode4K2160p2398 = '4k23',
|
|
|
|
bmdMode4K2160p24 = '4k24',
|
|
|
|
bmdMode4K2160p25 = '4k25',
|
|
|
|
bmdMode4K2160p2997 = '4k29',
|
|
|
|
bmdMode4K2160p30 = '4k30',
|
2020-10-07 16:33:35 +00:00
|
|
|
bmdMode4K2160p4795 = '4k47',
|
|
|
|
bmdMode4K2160p48 = '4k48',
|
2014-12-03 13:42:43 +00:00
|
|
|
bmdMode4K2160p50 = '4k50',
|
|
|
|
bmdMode4K2160p5994 = '4k59',
|
|
|
|
bmdMode4K2160p60 = '4k60',
|
2020-10-07 16:33:35 +00:00
|
|
|
bmdMode4K2160p9590 = '4k95',
|
|
|
|
bmdMode4K2160p96 = '4k96',
|
|
|
|
bmdMode4K2160p100 = '4k10',
|
|
|
|
bmdMode4K2160p11988 = '4k11',
|
|
|
|
bmdMode4K2160p120 = '4k12',
|
2014-12-03 13:42:43 +00:00
|
|
|
|
2020-02-27 11:32:17 +00:00
|
|
|
/* 4K DCI Modes */
|
2014-12-03 13:42:43 +00:00
|
|
|
|
|
|
|
bmdMode4kDCI2398 = '4d23',
|
|
|
|
bmdMode4kDCI24 = '4d24',
|
|
|
|
bmdMode4kDCI25 = '4d25',
|
2020-02-27 11:32:17 +00:00
|
|
|
bmdMode4kDCI2997 = '4d29',
|
|
|
|
bmdMode4kDCI30 = '4d30',
|
2020-10-07 16:33:35 +00:00
|
|
|
bmdMode4kDCI4795 = '4d47',
|
|
|
|
bmdMode4kDCI48 = '4d48',
|
2020-02-27 11:32:17 +00:00
|
|
|
bmdMode4kDCI50 = '4d50',
|
|
|
|
bmdMode4kDCI5994 = '4d59',
|
|
|
|
bmdMode4kDCI60 = '4d60',
|
2020-10-07 16:33:35 +00:00
|
|
|
bmdMode4kDCI9590 = '4d95',
|
|
|
|
bmdMode4kDCI96 = '4d96',
|
|
|
|
bmdMode4kDCI100 = '4d10',
|
|
|
|
bmdMode4kDCI11988 = '4d11',
|
|
|
|
bmdMode4kDCI120 = '4d12',
|
2020-02-27 11:32:17 +00:00
|
|
|
|
|
|
|
/* 8K UHD Modes */
|
|
|
|
|
|
|
|
bmdMode8K4320p2398 = '8k23',
|
|
|
|
bmdMode8K4320p24 = '8k24',
|
|
|
|
bmdMode8K4320p25 = '8k25',
|
|
|
|
bmdMode8K4320p2997 = '8k29',
|
|
|
|
bmdMode8K4320p30 = '8k30',
|
2020-10-07 16:33:35 +00:00
|
|
|
bmdMode8K4320p4795 = '8k47',
|
|
|
|
bmdMode8K4320p48 = '8k48',
|
2020-02-27 11:32:17 +00:00
|
|
|
bmdMode8K4320p50 = '8k50',
|
|
|
|
bmdMode8K4320p5994 = '8k59',
|
|
|
|
bmdMode8K4320p60 = '8k60',
|
|
|
|
|
|
|
|
/* 8K DCI Modes */
|
|
|
|
|
|
|
|
bmdMode8kDCI2398 = '8d23',
|
|
|
|
bmdMode8kDCI24 = '8d24',
|
|
|
|
bmdMode8kDCI25 = '8d25',
|
|
|
|
bmdMode8kDCI2997 = '8d29',
|
|
|
|
bmdMode8kDCI30 = '8d30',
|
2020-10-07 16:33:35 +00:00
|
|
|
bmdMode8kDCI4795 = '8d47',
|
|
|
|
bmdMode8kDCI48 = '8d48',
|
2020-02-27 11:32:17 +00:00
|
|
|
bmdMode8kDCI50 = '8d50',
|
|
|
|
bmdMode8kDCI5994 = '8d59',
|
|
|
|
bmdMode8kDCI60 = '8d60',
|
|
|
|
|
2020-10-07 16:33:35 +00:00
|
|
|
/* PC Modes */
|
|
|
|
|
|
|
|
bmdMode640x480p60 = 'vga6',
|
|
|
|
bmdMode800x600p60 = 'svg6',
|
|
|
|
bmdMode1440x900p50 = 'wxg5',
|
|
|
|
bmdMode1440x900p60 = 'wxg6',
|
|
|
|
bmdMode1440x1080p50 = 'sxg5',
|
|
|
|
bmdMode1440x1080p60 = 'sxg6',
|
|
|
|
bmdMode1600x1200p50 = 'uxg5',
|
|
|
|
bmdMode1600x1200p60 = 'uxg6',
|
|
|
|
bmdMode1920x1200p50 = 'wux5',
|
|
|
|
bmdMode1920x1200p60 = 'wux6',
|
|
|
|
bmdMode1920x1440p50 = '1945',
|
|
|
|
bmdMode1920x1440p60 = '1946',
|
|
|
|
bmdMode2560x1440p50 = 'wqh5',
|
|
|
|
bmdMode2560x1440p60 = 'wqh6',
|
|
|
|
bmdMode2560x1600p50 = 'wqx5',
|
|
|
|
bmdMode2560x1600p60 = 'wqx6',
|
|
|
|
|
2020-02-27 11:32:17 +00:00
|
|
|
/* RAW Modes for Cintel (input only) */
|
|
|
|
|
|
|
|
bmdModeCintelRAW = 'rwci', // Frame size up to 4096x3072, variable frame rate
|
|
|
|
bmdModeCintelCompressedRAW = 'rwcc', // Frame size up to 4096x3072, variable frame rate
|
2014-12-03 13:42:43 +00:00
|
|
|
|
2012-03-22 06:04:31 +00:00
|
|
|
/* Special Modes */
|
|
|
|
|
|
|
|
bmdModeUnknown = 'iunk'
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Enum BMDFieldDominance - Video field dominance */
|
|
|
|
|
|
|
|
typedef uint32_t BMDFieldDominance;
|
|
|
|
enum _BMDFieldDominance {
|
|
|
|
bmdUnknownFieldDominance = 0,
|
|
|
|
bmdLowerFieldFirst = 'lowr',
|
|
|
|
bmdUpperFieldFirst = 'uppr',
|
|
|
|
bmdProgressiveFrame = 'prog',
|
|
|
|
bmdProgressiveSegmentedFrame = 'psf '
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Enum BMDPixelFormat - Video pixel formats supported for output/input */
|
|
|
|
|
|
|
|
typedef uint32_t BMDPixelFormat;
|
|
|
|
enum _BMDPixelFormat {
|
2020-10-07 16:33:35 +00:00
|
|
|
bmdFormatUnspecified = 0,
|
2012-03-22 06:04:31 +00:00
|
|
|
bmdFormat8BitYUV = '2vuy',
|
|
|
|
bmdFormat10BitYUV = 'v210',
|
|
|
|
bmdFormat8BitARGB = 32,
|
|
|
|
bmdFormat8BitBGRA = 'BGRA',
|
2014-12-03 13:42:43 +00:00
|
|
|
bmdFormat10BitRGB = 'r210', // Big-endian RGB 10-bit per component with SMPTE video levels (64-960). Packed as 2:10:10:10
|
|
|
|
bmdFormat12BitRGB = 'R12B', // Big-endian RGB 12-bit per component with full range (0-4095). Packed as 12-bit per component
|
|
|
|
bmdFormat12BitRGBLE = 'R12L', // Little-endian RGB 12-bit per component with full range (0-4095). Packed as 12-bit per component
|
|
|
|
bmdFormat10BitRGBXLE = 'R10l', // Little-endian 10-bit RGB with SMPTE video levels (64-940)
|
2016-09-26 13:38:04 +00:00
|
|
|
bmdFormat10BitRGBX = 'R10b', // Big-endian 10-bit RGB with SMPTE video levels (64-940)
|
|
|
|
bmdFormatH265 = 'hev1', // High Efficiency Video Coding (HEVC/h.265)
|
|
|
|
|
|
|
|
/* AVID DNxHR */
|
|
|
|
|
2020-02-27 11:32:17 +00:00
|
|
|
bmdFormatDNxHR = 'AVdh',
|
|
|
|
|
|
|
|
/* Cintel formats */
|
|
|
|
|
|
|
|
bmdFormat12BitRAWGRBG = 'r12p', // 12-bit RAW data for bayer pattern GRBG
|
|
|
|
bmdFormat12BitRAWJPEG = 'r16p' // 12-bit RAW data arranged in tiles and JPEG compressed
|
2012-03-22 06:04:31 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Enum BMDDisplayModeFlags - Flags to describe the characteristics of an IDeckLinkDisplayMode. */
|
|
|
|
|
|
|
|
typedef uint32_t BMDDisplayModeFlags;
|
|
|
|
enum _BMDDisplayModeFlags {
|
|
|
|
bmdDisplayModeSupports3D = 1 << 0,
|
|
|
|
bmdDisplayModeColorspaceRec601 = 1 << 1,
|
2020-02-27 11:32:17 +00:00
|
|
|
bmdDisplayModeColorspaceRec709 = 1 << 2,
|
|
|
|
bmdDisplayModeColorspaceRec2020 = 1 << 3
|
2012-03-22 06:04:31 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// Forward Declarations
|
|
|
|
|
|
|
|
class IDeckLinkDisplayModeIterator;
|
|
|
|
class IDeckLinkDisplayMode;
|
|
|
|
|
|
|
|
/* Interface IDeckLinkDisplayModeIterator - enumerates over supported input/output display modes. */
|
|
|
|
|
2020-02-27 11:32:17 +00:00
|
|
|
class BMD_PUBLIC IDeckLinkDisplayModeIterator : public IUnknown
|
2012-03-22 06:04:31 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual HRESULT Next (/* out */ IDeckLinkDisplayMode **deckLinkDisplayMode) = 0;
|
|
|
|
|
|
|
|
protected:
|
2014-12-03 13:42:43 +00:00
|
|
|
virtual ~IDeckLinkDisplayModeIterator () {} // call Release method to drop reference count
|
2012-03-22 06:04:31 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Interface IDeckLinkDisplayMode - represents a display mode */
|
|
|
|
|
2020-02-27 11:32:17 +00:00
|
|
|
class BMD_PUBLIC IDeckLinkDisplayMode : public IUnknown
|
2012-03-22 06:04:31 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual HRESULT GetName (/* out */ CFStringRef *name) = 0;
|
|
|
|
virtual BMDDisplayMode GetDisplayMode (void) = 0;
|
|
|
|
virtual long GetWidth (void) = 0;
|
|
|
|
virtual long GetHeight (void) = 0;
|
|
|
|
virtual HRESULT GetFrameRate (/* out */ BMDTimeValue *frameDuration, /* out */ BMDTimeScale *timeScale) = 0;
|
|
|
|
virtual BMDFieldDominance GetFieldDominance (void) = 0;
|
|
|
|
virtual BMDDisplayModeFlags GetFlags (void) = 0;
|
|
|
|
|
|
|
|
protected:
|
2014-12-03 13:42:43 +00:00
|
|
|
virtual ~IDeckLinkDisplayMode () {} // call Release method to drop reference count
|
2012-03-22 06:04:31 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Functions */
|
|
|
|
|
|
|
|
extern "C" {
|
|
|
|
|
|
|
|
|
2014-12-03 13:42:43 +00:00
|
|
|
}
|
2012-03-22 06:04:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
#endif /* defined(BMD_DECKLINKAPIMODES_H) */
|