video-io.h 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. /******************************************************************************
  2. Copyright (C) 2013 by Hugh Bailey <[email protected]>
  3. This program is free software: you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation, either version 2 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program. If not, see <http://www.gnu.org/licenses/>.
  13. ******************************************************************************/
  14. #pragma once
  15. #include "media-io-defs.h"
  16. #ifdef __cplusplus
  17. extern "C" {
  18. #endif
  19. struct video_frame;
  20. /* Base video output component. Use this to create a video output track. */
  21. struct video_output;
  22. typedef struct video_output video_t;
  23. enum video_format {
  24. VIDEO_FORMAT_NONE,
  25. /* planar 420 format */
  26. VIDEO_FORMAT_I420, /* three-plane */
  27. VIDEO_FORMAT_NV12, /* two-plane, luma and packed chroma */
  28. /* packed 422 formats */
  29. VIDEO_FORMAT_YVYU,
  30. VIDEO_FORMAT_YUY2, /* YUYV */
  31. VIDEO_FORMAT_UYVY,
  32. /* packed uncompressed formats */
  33. VIDEO_FORMAT_RGBA,
  34. VIDEO_FORMAT_BGRA,
  35. VIDEO_FORMAT_BGRX,
  36. VIDEO_FORMAT_Y800, /* grayscale */
  37. /* planar 4:4:4 */
  38. VIDEO_FORMAT_I444,
  39. /* more packed uncompressed formats */
  40. VIDEO_FORMAT_BGR3,
  41. };
  42. enum video_colorspace {
  43. VIDEO_CS_DEFAULT,
  44. VIDEO_CS_601,
  45. VIDEO_CS_709,
  46. };
  47. enum video_range_type {
  48. VIDEO_RANGE_DEFAULT,
  49. VIDEO_RANGE_PARTIAL,
  50. VIDEO_RANGE_FULL
  51. };
  52. struct video_data {
  53. uint8_t *data[MAX_AV_PLANES];
  54. uint32_t linesize[MAX_AV_PLANES];
  55. uint64_t timestamp;
  56. };
  57. struct video_output_info {
  58. const char *name;
  59. enum video_format format;
  60. uint32_t fps_num;
  61. uint32_t fps_den;
  62. uint32_t width;
  63. uint32_t height;
  64. size_t cache_size;
  65. enum video_colorspace colorspace;
  66. enum video_range_type range;
  67. };
  68. static inline bool format_is_yuv(enum video_format format)
  69. {
  70. switch (format) {
  71. case VIDEO_FORMAT_I420:
  72. case VIDEO_FORMAT_NV12:
  73. case VIDEO_FORMAT_YVYU:
  74. case VIDEO_FORMAT_YUY2:
  75. case VIDEO_FORMAT_UYVY:
  76. case VIDEO_FORMAT_I444:
  77. return true;
  78. case VIDEO_FORMAT_NONE:
  79. case VIDEO_FORMAT_RGBA:
  80. case VIDEO_FORMAT_BGRA:
  81. case VIDEO_FORMAT_BGRX:
  82. case VIDEO_FORMAT_Y800:
  83. case VIDEO_FORMAT_BGR3:
  84. return false;
  85. }
  86. return false;
  87. }
  88. static inline const char *get_video_format_name(enum video_format format)
  89. {
  90. switch (format) {
  91. case VIDEO_FORMAT_I420:
  92. return "I420";
  93. case VIDEO_FORMAT_NV12:
  94. return "NV12";
  95. case VIDEO_FORMAT_YVYU:
  96. return "YVYU";
  97. case VIDEO_FORMAT_YUY2:
  98. return "YUY2";
  99. case VIDEO_FORMAT_UYVY:
  100. return "UYVY";
  101. case VIDEO_FORMAT_RGBA:
  102. return "RGBA";
  103. case VIDEO_FORMAT_BGRA:
  104. return "BGRA";
  105. case VIDEO_FORMAT_BGRX:
  106. return "BGRX";
  107. case VIDEO_FORMAT_I444:
  108. return "I444";
  109. case VIDEO_FORMAT_Y800:
  110. return "Y800";
  111. case VIDEO_FORMAT_BGR3:
  112. return "BGR3";
  113. case VIDEO_FORMAT_NONE:;
  114. }
  115. return "None";
  116. }
  117. static inline const char *get_video_colorspace_name(enum video_colorspace cs)
  118. {
  119. switch (cs) {
  120. case VIDEO_CS_709:
  121. return "709";
  122. case VIDEO_CS_601:
  123. case VIDEO_CS_DEFAULT:;
  124. }
  125. return "601";
  126. }
  127. static inline enum video_range_type
  128. resolve_video_range(enum video_format format, enum video_range_type range)
  129. {
  130. if (range == VIDEO_RANGE_DEFAULT) {
  131. range = format_is_yuv(format) ? VIDEO_RANGE_PARTIAL
  132. : VIDEO_RANGE_FULL;
  133. }
  134. return range;
  135. }
  136. static inline const char *get_video_range_name(enum video_format format,
  137. enum video_range_type range)
  138. {
  139. range = resolve_video_range(format, range);
  140. return range == VIDEO_RANGE_FULL ? "Full" : "Partial";
  141. }
  142. enum video_scale_type {
  143. VIDEO_SCALE_DEFAULT,
  144. VIDEO_SCALE_POINT,
  145. VIDEO_SCALE_FAST_BILINEAR,
  146. VIDEO_SCALE_BILINEAR,
  147. VIDEO_SCALE_BICUBIC,
  148. };
  149. struct video_scale_info {
  150. enum video_format format;
  151. uint32_t width;
  152. uint32_t height;
  153. enum video_range_type range;
  154. enum video_colorspace colorspace;
  155. };
  156. EXPORT enum video_format video_format_from_fourcc(uint32_t fourcc);
  157. EXPORT bool video_format_get_parameters(enum video_colorspace color_space,
  158. enum video_range_type range,
  159. float matrix[16], float min_range[3],
  160. float max_range[3]);
  161. #define VIDEO_OUTPUT_SUCCESS 0
  162. #define VIDEO_OUTPUT_INVALIDPARAM -1
  163. #define VIDEO_OUTPUT_FAIL -2
  164. EXPORT int video_output_open(video_t **video, struct video_output_info *info);
  165. EXPORT void video_output_close(video_t *video);
  166. EXPORT bool
  167. video_output_connect(video_t *video, const struct video_scale_info *conversion,
  168. void (*callback)(void *param, struct video_data *frame),
  169. void *param);
  170. EXPORT void video_output_disconnect(video_t *video,
  171. void (*callback)(void *param,
  172. struct video_data *frame),
  173. void *param);
  174. EXPORT bool video_output_active(const video_t *video);
  175. EXPORT const struct video_output_info *
  176. video_output_get_info(const video_t *video);
  177. EXPORT bool video_output_lock_frame(video_t *video, struct video_frame *frame,
  178. int count, uint64_t timestamp);
  179. EXPORT void video_output_unlock_frame(video_t *video);
  180. EXPORT uint64_t video_output_get_frame_time(const video_t *video);
  181. EXPORT void video_output_stop(video_t *video);
  182. EXPORT bool video_output_stopped(video_t *video);
  183. EXPORT enum video_format video_output_get_format(const video_t *video);
  184. EXPORT uint32_t video_output_get_width(const video_t *video);
  185. EXPORT uint32_t video_output_get_height(const video_t *video);
  186. EXPORT double video_output_get_frame_rate(const video_t *video);
  187. EXPORT uint32_t video_output_get_skipped_frames(const video_t *video);
  188. EXPORT uint32_t video_output_get_total_frames(const video_t *video);
  189. extern void video_output_inc_texture_encoders(video_t *video);
  190. extern void video_output_dec_texture_encoders(video_t *video);
  191. extern void video_output_inc_texture_frames(video_t *video);
  192. extern void video_output_inc_texture_skipped_frames(video_t *video);
  193. #ifdef __cplusplus
  194. }
  195. #endif