x265enc: Update for video-hdr struct change

See the change of -base https://gitlab.freedesktop.org/gstreamer/gst-plugins-base/-/merge_requests/594
This commit is contained in:
Seungha Yang 2020-03-13 16:34:01 +09:00
parent f05effe024
commit 770a851e03

View file

@ -942,70 +942,28 @@ gst_x265_enc_init_encoder (GstX265Enc * encoder)
if (gst_video_mastering_display_info_from_caps (&minfo, if (gst_video_mastering_display_info_from_caps (&minfo,
encoder->input_state->caps)) { encoder->input_state->caps)) {
guint16 displayPrimaryX[3];
guint16 displayPrimaryY[3];
guint16 whitePointX, whitePointY;
guint32 maxDisplayMasteringLuminance;
guint32 minDisplayMasteringLuminance;
const guint chroma_scale = 50000;
const guint luma_scale = 10000;
GST_DEBUG_OBJECT (encoder, "Apply mastering display info"); GST_DEBUG_OBJECT (encoder, "Apply mastering display info");
displayPrimaryX[0] = /* GstVideoMasteringDisplayInfo::display_primaries is rgb order but
(guint16) gst_util_uint64_scale_round (minfo.Gx_n, chroma_scale, * HEVC uses gbr order
minfo.Gx_d); * See spec D.3.28 display_primaries_x and display_primaries_y
displayPrimaryX[1] = */
(guint16) gst_util_uint64_scale_round (minfo.Bx_n, chroma_scale,
minfo.Bx_d);
displayPrimaryX[2] =
(guint16) gst_util_uint64_scale_round (minfo.Rx_n, chroma_scale,
minfo.Rx_d);
displayPrimaryY[0] =
(guint16) gst_util_uint64_scale_round (minfo.Gy_n, chroma_scale,
minfo.Gy_d);
displayPrimaryY[1] =
(guint16) gst_util_uint64_scale_round (minfo.By_n, chroma_scale,
minfo.By_d);
displayPrimaryY[2] =
(guint16) gst_util_uint64_scale_round (minfo.Ry_n, chroma_scale,
minfo.Ry_d);
whitePointX =
(guint16) gst_util_uint64_scale_round (minfo.Wx_n, chroma_scale,
minfo.Wx_d);
whitePointY =
(guint16) gst_util_uint64_scale_round (minfo.Wy_n, chroma_scale,
minfo.Wy_d);
maxDisplayMasteringLuminance =
(guint32) gst_util_uint64_scale_round (minfo.max_luma_n, luma_scale,
minfo.max_luma_d);
minDisplayMasteringLuminance =
(guint32) gst_util_uint64_scale_round (minfo.min_luma_n, luma_scale,
minfo.min_luma_d);
encoder->x265param.masteringDisplayColorVolume = encoder->x265param.masteringDisplayColorVolume =
g_strdup_printf ("G(%hu,%hu)B(%hu,%hu)R(%hu,%hu)WP(%hu,%hu)L(%u,%u)", g_strdup_printf ("G(%hu,%hu)B(%hu,%hu)R(%hu,%hu)WP(%hu,%hu)L(%u,%u)",
displayPrimaryX[0], displayPrimaryY[0], minfo.display_primaries[1].x, minfo.display_primaries[1].y,
displayPrimaryX[1], displayPrimaryY[1], minfo.display_primaries[2].x, minfo.display_primaries[2].y,
displayPrimaryX[2], displayPrimaryY[2], minfo.display_primaries[0].x, minfo.display_primaries[0].y,
whitePointX, whitePointY, minfo.white_point.x, minfo.white_point.y,
maxDisplayMasteringLuminance, minDisplayMasteringLuminance); minfo.max_display_mastering_luminance,
minfo.min_display_mastering_luminance);
} }
if (gst_video_content_light_level_from_caps (&cll, if (gst_video_content_light_level_from_caps (&cll,
encoder->input_state->caps)) { encoder->input_state->caps)) {
gdouble val;
GST_DEBUG_OBJECT (encoder, "Apply content light level"); GST_DEBUG_OBJECT (encoder, "Apply content light level");
gst_util_fraction_to_double (cll.maxCLL_n, cll.maxCLL_d, &val); encoder->x265param.maxCLL = cll.max_content_light_level;
encoder->x265param.maxCLL = (guint16) val; encoder->x265param.maxFALL = cll.max_frame_average_light_level;
gst_util_fraction_to_double (cll.maxFALL_n, cll.maxFALL_d, &val);
encoder->x265param.maxFALL = (guint16) val;
} }
} }
#endif #endif