DeckLinkAPIModes.idl 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. /* -LICENSE-START-
  2. ** Copyright (c) 2021 Blackmagic Design
  3. **
  4. ** Permission is hereby granted, free of charge, to any person or organization
  5. ** obtaining a copy of the software and accompanying documentation covered by
  6. ** this license (the "Software") to use, reproduce, display, distribute,
  7. ** execute, and transmit the Software, and to prepare derivative works of the
  8. ** Software, and to permit third-parties to whom the Software is furnished to
  9. ** do so, all subject to the following:
  10. **
  11. ** The copyright notices in the Software and this entire statement, including
  12. ** the above license grant, this restriction and the following disclaimer,
  13. ** must be included in all copies of the Software, in whole or in part, and
  14. ** all derivative works of the Software, unless such copies or derivative
  15. ** works are solely in the form of machine-executable object code generated by
  16. ** a source language processor.
  17. **
  18. ** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  19. ** IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  20. ** FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
  21. ** SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
  22. ** FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
  23. ** ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  24. ** DEALINGS IN THE SOFTWARE.
  25. ** -LICENSE-END-
  26. */
  27. #ifndef BMD_CONST
  28. #if defined(_MSC_VER)
  29. #define BMD_CONST __declspec(selectany) static const
  30. #else
  31. #define BMD_CONST static const
  32. #endif
  33. #endif
  34. // Type Declarations
  35. // Enumeration Mapping
  36. cpp_quote("typedef unsigned int BMDDisplayModeFlags;")
  37. cpp_quote("#if 0")
  38. typedef enum _BMDDisplayModeFlags BMDDisplayModeFlags;
  39. cpp_quote("#endif")
  40. /* Enum BMDDisplayMode - BMDDisplayMode enumerates the video modes supported. */
  41. typedef [v1_enum] enum _BMDDisplayMode {
  42. /* SD Modes */
  43. bmdModeNTSC = /* 'ntsc' */ 0x6E747363,
  44. bmdModeNTSC2398 = /* 'nt23' */ 0x6E743233, // 3:2 pulldown
  45. bmdModePAL = /* 'pal ' */ 0x70616C20,
  46. bmdModeNTSCp = /* 'ntsp' */ 0x6E747370,
  47. bmdModePALp = /* 'palp' */ 0x70616C70,
  48. /* HD 1080 Modes */
  49. bmdModeHD1080p2398 = /* '23ps' */ 0x32337073,
  50. bmdModeHD1080p24 = /* '24ps' */ 0x32347073,
  51. bmdModeHD1080p25 = /* 'Hp25' */ 0x48703235,
  52. bmdModeHD1080p2997 = /* 'Hp29' */ 0x48703239,
  53. bmdModeHD1080p30 = /* 'Hp30' */ 0x48703330,
  54. bmdModeHD1080p4795 = /* 'Hp47' */ 0x48703437,
  55. bmdModeHD1080p48 = /* 'Hp48' */ 0x48703438,
  56. bmdModeHD1080p50 = /* 'Hp50' */ 0x48703530,
  57. bmdModeHD1080p5994 = /* 'Hp59' */ 0x48703539,
  58. bmdModeHD1080p6000 = /* 'Hp60' */ 0x48703630, // N.B. This _really_ is 60.00 Hz.
  59. bmdModeHD1080p9590 = /* 'Hp95' */ 0x48703935,
  60. bmdModeHD1080p96 = /* 'Hp96' */ 0x48703936,
  61. bmdModeHD1080p100 = /* 'Hp10' */ 0x48703130,
  62. bmdModeHD1080p11988 = /* 'Hp11' */ 0x48703131,
  63. bmdModeHD1080p120 = /* 'Hp12' */ 0x48703132,
  64. bmdModeHD1080i50 = /* 'Hi50' */ 0x48693530,
  65. bmdModeHD1080i5994 = /* 'Hi59' */ 0x48693539,
  66. bmdModeHD1080i6000 = /* 'Hi60' */ 0x48693630, // N.B. This _really_ is 60.00 Hz.
  67. /* HD 720 Modes */
  68. bmdModeHD720p50 = /* 'hp50' */ 0x68703530,
  69. bmdModeHD720p5994 = /* 'hp59' */ 0x68703539,
  70. bmdModeHD720p60 = /* 'hp60' */ 0x68703630,
  71. /* 2K Modes */
  72. bmdMode2k2398 = /* '2k23' */ 0x326B3233,
  73. bmdMode2k24 = /* '2k24' */ 0x326B3234,
  74. bmdMode2k25 = /* '2k25' */ 0x326B3235,
  75. /* 2K DCI Modes */
  76. bmdMode2kDCI2398 = /* '2d23' */ 0x32643233,
  77. bmdMode2kDCI24 = /* '2d24' */ 0x32643234,
  78. bmdMode2kDCI25 = /* '2d25' */ 0x32643235,
  79. bmdMode2kDCI2997 = /* '2d29' */ 0x32643239,
  80. bmdMode2kDCI30 = /* '2d30' */ 0x32643330,
  81. bmdMode2kDCI4795 = /* '2d47' */ 0x32643437,
  82. bmdMode2kDCI48 = /* '2d48' */ 0x32643438,
  83. bmdMode2kDCI50 = /* '2d50' */ 0x32643530,
  84. bmdMode2kDCI5994 = /* '2d59' */ 0x32643539,
  85. bmdMode2kDCI60 = /* '2d60' */ 0x32643630,
  86. bmdMode2kDCI9590 = /* '2d95' */ 0x32643935,
  87. bmdMode2kDCI96 = /* '2d96' */ 0x32643936,
  88. bmdMode2kDCI100 = /* '2d10' */ 0x32643130,
  89. bmdMode2kDCI11988 = /* '2d11' */ 0x32643131,
  90. bmdMode2kDCI120 = /* '2d12' */ 0x32643132,
  91. /* 4K UHD Modes */
  92. bmdMode4K2160p2398 = /* '4k23' */ 0x346B3233,
  93. bmdMode4K2160p24 = /* '4k24' */ 0x346B3234,
  94. bmdMode4K2160p25 = /* '4k25' */ 0x346B3235,
  95. bmdMode4K2160p2997 = /* '4k29' */ 0x346B3239,
  96. bmdMode4K2160p30 = /* '4k30' */ 0x346B3330,
  97. bmdMode4K2160p4795 = /* '4k47' */ 0x346B3437,
  98. bmdMode4K2160p48 = /* '4k48' */ 0x346B3438,
  99. bmdMode4K2160p50 = /* '4k50' */ 0x346B3530,
  100. bmdMode4K2160p5994 = /* '4k59' */ 0x346B3539,
  101. bmdMode4K2160p60 = /* '4k60' */ 0x346B3630,
  102. bmdMode4K2160p9590 = /* '4k95' */ 0x346B3935,
  103. bmdMode4K2160p96 = /* '4k96' */ 0x346B3936,
  104. bmdMode4K2160p100 = /* '4k10' */ 0x346B3130,
  105. bmdMode4K2160p11988 = /* '4k11' */ 0x346B3131,
  106. bmdMode4K2160p120 = /* '4k12' */ 0x346B3132,
  107. /* 4K DCI Modes */
  108. bmdMode4kDCI2398 = /* '4d23' */ 0x34643233,
  109. bmdMode4kDCI24 = /* '4d24' */ 0x34643234,
  110. bmdMode4kDCI25 = /* '4d25' */ 0x34643235,
  111. bmdMode4kDCI2997 = /* '4d29' */ 0x34643239,
  112. bmdMode4kDCI30 = /* '4d30' */ 0x34643330,
  113. bmdMode4kDCI4795 = /* '4d47' */ 0x34643437,
  114. bmdMode4kDCI48 = /* '4d48' */ 0x34643438,
  115. bmdMode4kDCI50 = /* '4d50' */ 0x34643530,
  116. bmdMode4kDCI5994 = /* '4d59' */ 0x34643539,
  117. bmdMode4kDCI60 = /* '4d60' */ 0x34643630,
  118. bmdMode4kDCI9590 = /* '4d95' */ 0x34643935,
  119. bmdMode4kDCI96 = /* '4d96' */ 0x34643936,
  120. bmdMode4kDCI100 = /* '4d10' */ 0x34643130,
  121. bmdMode4kDCI11988 = /* '4d11' */ 0x34643131,
  122. bmdMode4kDCI120 = /* '4d12' */ 0x34643132,
  123. /* 8K UHD Modes */
  124. bmdMode8K4320p2398 = /* '8k23' */ 0x386B3233,
  125. bmdMode8K4320p24 = /* '8k24' */ 0x386B3234,
  126. bmdMode8K4320p25 = /* '8k25' */ 0x386B3235,
  127. bmdMode8K4320p2997 = /* '8k29' */ 0x386B3239,
  128. bmdMode8K4320p30 = /* '8k30' */ 0x386B3330,
  129. bmdMode8K4320p4795 = /* '8k47' */ 0x386B3437,
  130. bmdMode8K4320p48 = /* '8k48' */ 0x386B3438,
  131. bmdMode8K4320p50 = /* '8k50' */ 0x386B3530,
  132. bmdMode8K4320p5994 = /* '8k59' */ 0x386B3539,
  133. bmdMode8K4320p60 = /* '8k60' */ 0x386B3630,
  134. /* 8K DCI Modes */
  135. bmdMode8kDCI2398 = /* '8d23' */ 0x38643233,
  136. bmdMode8kDCI24 = /* '8d24' */ 0x38643234,
  137. bmdMode8kDCI25 = /* '8d25' */ 0x38643235,
  138. bmdMode8kDCI2997 = /* '8d29' */ 0x38643239,
  139. bmdMode8kDCI30 = /* '8d30' */ 0x38643330,
  140. bmdMode8kDCI4795 = /* '8d47' */ 0x38643437,
  141. bmdMode8kDCI48 = /* '8d48' */ 0x38643438,
  142. bmdMode8kDCI50 = /* '8d50' */ 0x38643530,
  143. bmdMode8kDCI5994 = /* '8d59' */ 0x38643539,
  144. bmdMode8kDCI60 = /* '8d60' */ 0x38643630,
  145. /* PC Modes */
  146. bmdMode640x480p60 = /* 'vga6' */ 0x76676136,
  147. bmdMode800x600p60 = /* 'svg6' */ 0x73766736,
  148. bmdMode1440x900p50 = /* 'wxg5' */ 0x77786735,
  149. bmdMode1440x900p60 = /* 'wxg6' */ 0x77786736,
  150. bmdMode1440x1080p50 = /* 'sxg5' */ 0x73786735,
  151. bmdMode1440x1080p60 = /* 'sxg6' */ 0x73786736,
  152. bmdMode1600x1200p50 = /* 'uxg5' */ 0x75786735,
  153. bmdMode1600x1200p60 = /* 'uxg6' */ 0x75786736,
  154. bmdMode1920x1200p50 = /* 'wux5' */ 0x77757835,
  155. bmdMode1920x1200p60 = /* 'wux6' */ 0x77757836,
  156. bmdMode1920x1440p50 = /* '1945' */ 0x31393435,
  157. bmdMode1920x1440p60 = /* '1946' */ 0x31393436,
  158. bmdMode2560x1440p50 = /* 'wqh5' */ 0x77716835,
  159. bmdMode2560x1440p60 = /* 'wqh6' */ 0x77716836,
  160. bmdMode2560x1600p50 = /* 'wqx5' */ 0x77717835,
  161. bmdMode2560x1600p60 = /* 'wqx6' */ 0x77717836,
  162. /* Special Modes */
  163. bmdModeUnknown = /* 'iunk' */ 0x69756E6B
  164. } BMDDisplayMode;
  165. /* Enum BMDFieldDominance - BMDFieldDominance enumerates settings applicable to video fields. */
  166. typedef [v1_enum] enum _BMDFieldDominance {
  167. bmdUnknownFieldDominance = 0,
  168. bmdLowerFieldFirst = /* 'lowr' */ 0x6C6F7772,
  169. bmdUpperFieldFirst = /* 'uppr' */ 0x75707072,
  170. bmdProgressiveFrame = /* 'prog' */ 0x70726F67,
  171. bmdProgressiveSegmentedFrame = /* 'psf ' */ 0x70736620
  172. } BMDFieldDominance;
  173. /* Enum BMDPixelFormat - Video pixel formats supported for output/input */
  174. typedef [v1_enum] enum _BMDPixelFormat {
  175. bmdFormatUnspecified = 0,
  176. bmdFormat8BitYUV = /* '2vuy' */ 0x32767579,
  177. bmdFormat10BitYUV = /* 'v210' */ 0x76323130,
  178. bmdFormat8BitARGB = 32,
  179. bmdFormat8BitBGRA = /* 'BGRA' */ 0x42475241,
  180. bmdFormat10BitRGB = /* 'r210' */ 0x72323130, // Big-endian RGB 10-bit per component with SMPTE video levels (64-960). Packed as 2:10:10:10
  181. bmdFormat12BitRGB = /* 'R12B' */ 0x52313242, // Big-endian RGB 12-bit per component with full range (0-4095). Packed as 12-bit per component
  182. bmdFormat12BitRGBLE = /* 'R12L' */ 0x5231324C, // Little-endian RGB 12-bit per component with full range (0-4095). Packed as 12-bit per component
  183. bmdFormat10BitRGBXLE = /* 'R10l' */ 0x5231306C, // Little-endian 10-bit RGB with SMPTE video levels (64-940)
  184. bmdFormat10BitRGBX = /* 'R10b' */ 0x52313062, // Big-endian 10-bit RGB with SMPTE video levels (64-940)
  185. bmdFormatH265 = /* 'hev1' */ 0x68657631, // High Efficiency Video Coding (HEVC/h.265)
  186. /* AVID DNxHR */
  187. bmdFormatDNxHR = /* 'AVdh' */ 0x41566468
  188. } BMDPixelFormat;
  189. /* Enum BMDDisplayModeFlags - Flags to describe the characteristics of an IDeckLinkDisplayMode. */
  190. [v1_enum] enum _BMDDisplayModeFlags {
  191. bmdDisplayModeSupports3D = 1 << 0,
  192. bmdDisplayModeColorspaceRec601 = 1 << 1,
  193. bmdDisplayModeColorspaceRec709 = 1 << 2,
  194. bmdDisplayModeColorspaceRec2020 = 1 << 3
  195. };
  196. // Forward Declarations
  197. interface IDeckLinkDisplayModeIterator;
  198. interface IDeckLinkDisplayMode;
  199. /* Interface IDeckLinkDisplayModeIterator - Enumerates over supported input/output display modes. */
  200. [
  201. object,
  202. uuid(9C88499F-F601-4021-B80B-032E4EB41C35),
  203. helpstring("Enumerates over supported input/output display modes.")
  204. ] interface IDeckLinkDisplayModeIterator : IUnknown
  205. {
  206. HRESULT Next ([out] IDeckLinkDisplayMode** deckLinkDisplayMode);
  207. };
  208. /* Interface IDeckLinkDisplayMode - Represents a display mode */
  209. [
  210. object,
  211. uuid(3EB2C1AB-0A3D-4523-A3AD-F40D7FB14E78),
  212. helpstring("Represents a display mode")
  213. ] interface IDeckLinkDisplayMode : IUnknown
  214. {
  215. HRESULT GetName ([out] BSTR* name);
  216. BMDDisplayMode GetDisplayMode (void);
  217. long GetWidth (void);
  218. long GetHeight (void);
  219. HRESULT GetFrameRate ([out] BMDTimeValue* frameDuration, [out] BMDTimeScale* timeScale);
  220. BMDFieldDominance GetFieldDominance (void);
  221. BMDDisplayModeFlags GetFlags (void);
  222. };
  223. /* Coclasses */
  224. importlib("stdole2.tlb");