| 1 | /* GStreamer |
| 2 | * Copyright (C) <2018-2019> Seungha Yang <seungha.yang@navercorp.com> |
| 3 | * |
| 4 | * This library is free software; you can redistribute it and/or |
| 5 | * modify it under the terms of the GNU Library General Public |
| 6 | * License as published by the Free Software Foundation; either |
| 7 | * version 2 of the License, or (at your option) any later version. |
| 8 | * |
| 9 | * This library is distributed in the hope that it will be useful, |
| 10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| 12 | * Library General Public License for more details. |
| 13 | * |
| 14 | * You should have received a copy of the GNU Library General Public |
| 15 | * License along with this library; if not, write to the |
| 16 | * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, |
| 17 | * Boston, MA 02110-1301, USA. |
| 18 | */ |
| 19 | |
| 20 | #ifndef __GST_VIDEO_HDR_H__ |
| 21 | #define __GST_VIDEO_HDR_H__ |
| 22 | |
| 23 | #include <gst/gst.h> |
| 24 | #include <gst/video/video-prelude.h> |
| 25 | |
| 26 | G_BEGIN_DECLS |
| 27 | |
| 28 | typedef struct _GstVideoMasteringDisplayInfoCoordinates GstVideoMasteringDisplayInfoCoordinates; |
| 29 | typedef struct _GstVideoMasteringDisplayInfo GstVideoMasteringDisplayInfo; |
| 30 | typedef struct _GstVideoContentLightLevel GstVideoContentLightLevel; |
| 31 | |
| 32 | /** |
| 33 | * GstVideoMasteringDisplayInfoCoordinates: |
| 34 | * @x: the x coordinate of CIE 1931 color space in unit of 0.00002. |
| 35 | * @y: the y coordinate of CIE 1931 color space in unit of 0.00002. |
| 36 | * |
| 37 | * Used to represent display_primaries and white_point of |
| 38 | * #GstVideoMasteringDisplayInfo struct. See #GstVideoMasteringDisplayInfo |
| 39 | * |
| 40 | * Since: 1.18 |
| 41 | */ |
| 42 | struct _GstVideoMasteringDisplayInfoCoordinates |
| 43 | { |
| 44 | guint16 x; |
| 45 | guint16 y; |
| 46 | }; |
| 47 | |
| 48 | /** |
| 49 | * GstVideoMasteringDisplayInfo: |
| 50 | * @display_primaries: the xy coordinates of primaries in the CIE 1931 color space. |
| 51 | * the index 0 contains red, 1 is for green and 2 is for blue. |
| 52 | * each value is normalized to 50000 (meaning that in unit of 0.00002) |
| 53 | * @white_point: the xy coordinates of white point in the CIE 1931 color space. |
| 54 | * each value is normalized to 50000 (meaning that in unit of 0.00002) |
| 55 | * @max_display_mastering_luminance: the maximum value of display luminance |
| 56 | * in unit of 0.0001 candelas per square metre (cd/m^2 and nit) |
| 57 | * @min_display_mastering_luminance: the minimum value of display luminance |
| 58 | * in unit of 0.0001 candelas per square metre (cd/m^2 and nit) |
| 59 | * |
| 60 | * Mastering display color volume information defined by SMPTE ST 2086 |
| 61 | * (a.k.a static HDR metadata). |
| 62 | * |
| 63 | * Since: 1.18 |
| 64 | */ |
| 65 | struct _GstVideoMasteringDisplayInfo |
| 66 | { |
| 67 | GstVideoMasteringDisplayInfoCoordinates display_primaries[3]; |
| 68 | GstVideoMasteringDisplayInfoCoordinates white_point; |
| 69 | guint32 max_display_mastering_luminance; |
| 70 | guint32 min_display_mastering_luminance; |
| 71 | |
| 72 | /*< private >*/ |
| 73 | gpointer _gst_reserved[GST_PADDING]; |
| 74 | }; |
| 75 | |
| 76 | GST_VIDEO_API |
| 77 | void gst_video_mastering_display_info_init (GstVideoMasteringDisplayInfo * minfo); |
| 78 | |
| 79 | GST_VIDEO_API |
| 80 | gboolean gst_video_mastering_display_info_from_string (GstVideoMasteringDisplayInfo * minfo, |
| 81 | const gchar * mastering); |
| 82 | |
| 83 | GST_VIDEO_API |
| 84 | gchar * gst_video_mastering_display_info_to_string (const GstVideoMasteringDisplayInfo * minfo); |
| 85 | |
| 86 | GST_VIDEO_API |
| 87 | gboolean gst_video_mastering_display_info_is_equal (const GstVideoMasteringDisplayInfo * minfo, |
| 88 | const GstVideoMasteringDisplayInfo * other); |
| 89 | |
| 90 | GST_VIDEO_API |
| 91 | gboolean gst_video_mastering_display_info_from_caps (GstVideoMasteringDisplayInfo * minfo, |
| 92 | const GstCaps * caps); |
| 93 | |
| 94 | GST_VIDEO_API |
| 95 | gboolean gst_video_mastering_display_info_add_to_caps (const GstVideoMasteringDisplayInfo * minfo, |
| 96 | GstCaps * caps); |
| 97 | |
| 98 | /** |
| 99 | * GstVideoContentLightLevel: |
| 100 | * @max_content_light_level: the maximum content light level |
| 101 | * (abbreviated to MaxCLL) in candelas per square meter (cd/m^2 and nit) |
| 102 | * @max_frame_average_light_level: the maximum frame average light level |
| 103 | * (abbreviated to MaxFLL) in candelas per square meter (cd/m^2 and nit) |
| 104 | * |
| 105 | * Content light level information specified in CEA-861.3, Appendix A. |
| 106 | * |
| 107 | * Since: 1.18 |
| 108 | */ |
| 109 | struct _GstVideoContentLightLevel |
| 110 | { |
| 111 | guint16 max_content_light_level; |
| 112 | guint16 max_frame_average_light_level; |
| 113 | |
| 114 | /*< private >*/ |
| 115 | gpointer _gst_reserved[GST_PADDING]; |
| 116 | }; |
| 117 | |
| 118 | GST_VIDEO_API |
| 119 | void gst_video_content_light_level_init (GstVideoContentLightLevel * linfo); |
| 120 | |
| 121 | GST_VIDEO_API |
| 122 | gboolean gst_video_content_light_level_from_string (GstVideoContentLightLevel * linfo, |
| 123 | const gchar * level); |
| 124 | |
| 125 | GST_VIDEO_API |
| 126 | gchar * gst_video_content_light_level_to_string (const GstVideoContentLightLevel * linfo); |
| 127 | |
| 128 | GST_VIDEO_API |
| 129 | gboolean gst_video_content_light_level_is_equal (const GstVideoContentLightLevel * linfo, |
| 130 | const GstVideoContentLightLevel * other); |
| 131 | |
| 132 | GST_VIDEO_API |
| 133 | gboolean gst_video_content_light_level_from_caps (GstVideoContentLightLevel * linfo, |
| 134 | const GstCaps * caps); |
| 135 | |
| 136 | GST_VIDEO_API |
| 137 | gboolean gst_video_content_light_level_add_to_caps (const GstVideoContentLightLevel * linfo, |
| 138 | GstCaps * caps); |
| 139 | |
| 140 | |
| 141 | G_END_DECLS |
| 142 | |
| 143 | #endif /* __GST_VIDEO_HDR_H__ */ |
| 144 | |