]> git.sesse.net Git - casparcg/blob - modules/ffmpeg/producer/util.h
2.0. Updated namespaces.
[casparcg] / modules / ffmpeg / producer / util.h
1 #pragma once\r
2 \r
3 #include <common/memory/safe_ptr.h>\r
4 \r
5 #include <core/video_format.h>\r
6 #include <core/producer/frame/pixel_format.h>\r
7 \r
8 extern "C"\r
9 {\r
10         #include <libavutil/pixfmt.h>\r
11 }\r
12 \r
13 struct AVFrame;\r
14 struct AVFormatContext;\r
15 \r
16 namespace caspar {\r
17 \r
18 namespace core {\r
19 \r
20 struct pixel_format_desc;\r
21 class write_frame;\r
22 struct frame_factory;\r
23 \r
24 }\r
25 \r
26 namespace ffmpeg {\r
27 \r
28 static const PixelFormat        CASPAR_PIX_FMT_LUMA = PIX_FMT_MONOBLACK; // Just hijack some unual pixel format.\r
29 \r
30 core::field_mode::type          get_mode(AVFrame& frame);\r
31 core::pixel_format::type        get_pixel_format(PixelFormat pix_fmt);\r
32 core::pixel_format_desc         get_pixel_format_desc(PixelFormat pix_fmt, size_t width, size_t height);\r
33 int                                                     make_alpha_format(int format); // NOTE: Be careful about CASPAR_PIX_FMT_LUMA, change it to PIX_FMT_GRAY8 if you want to use the frame inside some ffmpeg function.\r
34 safe_ptr<core::write_frame> make_write_frame(const void* tag, const safe_ptr<AVFrame>& decoded_frame, const safe_ptr<core::frame_factory>& frame_factory, int hints);\r
35 \r
36 void fix_meta_data(AVFormatContext& context);\r
37 \r
38 }}