mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 09:55:36 +00:00
x265enc: Add support for 10bit 4:2:0 and 4:4:4 formats
This commit is contained in:
parent
037928dcf6
commit
767fefafb3
1 changed files with 41 additions and 12 deletions
|
@ -65,9 +65,9 @@ static GString *x265enc_defaults;
|
||||||
#define PROP_TUNE_DEFAULT 2 // SSIM
|
#define PROP_TUNE_DEFAULT 2 // SSIM
|
||||||
|
|
||||||
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
|
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
|
||||||
#define FORMATS "I420, Y444"
|
#define FORMATS "I420, Y444, I420_10LE, Y444_10LE"
|
||||||
#else
|
#else
|
||||||
#define FORMATS "I420, Y444"
|
#define FORMATS "I420, Y444, I420_10BE, Y444_10BE"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define GST_X265_ENC_LOG_LEVEL_TYPE (gst_x265_enc_log_level_get_type())
|
#define GST_X265_ENC_LOG_LEVEL_TYPE (gst_x265_enc_log_level_get_type())
|
||||||
|
@ -239,6 +239,30 @@ gst_x265_enc_add_x265_chroma_format (GstStructure * s,
|
||||||
{
|
{
|
||||||
GValue fmt = G_VALUE_INIT;
|
GValue fmt = G_VALUE_INIT;
|
||||||
|
|
||||||
|
if (x265_max_bit_depth >= 10) {
|
||||||
|
GST_INFO ("This x265 build supports %d-bit depth", x265_max_bit_depth);
|
||||||
|
if (x265_chroma_format_local == 0) {
|
||||||
|
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
|
||||||
|
set_value (&fmt, 4, "I420", "Y444", "I420_10LE", "Y444_10LE");
|
||||||
|
#else
|
||||||
|
set_value (&fmt, 4, "I420", "Y444", "I420_10BE", "Y444_10BE");
|
||||||
|
#endif
|
||||||
|
} else if (x265_chroma_format_local == X265_CSP_I444) {
|
||||||
|
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
|
||||||
|
set_value (&fmt, 2, "Y444", "Y444_10LE");
|
||||||
|
#else
|
||||||
|
set_value (&fmt, 2, "Y444", "Y444_10BE");
|
||||||
|
#endif
|
||||||
|
} else if (x265_chroma_format_local == X265_CSP_I420) {
|
||||||
|
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
|
||||||
|
set_value (&fmt, 2, "I420", "I420_10LE");
|
||||||
|
#else
|
||||||
|
set_value (&fmt, 2, "I420", "I420_10BE");
|
||||||
|
#endif
|
||||||
|
} else {
|
||||||
|
GST_ERROR ("Unsupported chroma format %d", x265_chroma_format_local);
|
||||||
|
}
|
||||||
|
} else if (x265_max_bit_depth == 8) {
|
||||||
GST_INFO ("This x265 build supports 8-bit depth");
|
GST_INFO ("This x265 build supports 8-bit depth");
|
||||||
if (x265_chroma_format_local == 0) {
|
if (x265_chroma_format_local == 0) {
|
||||||
set_value (&fmt, 2, "I420", "Y444");
|
set_value (&fmt, 2, "I420", "Y444");
|
||||||
|
@ -249,6 +273,7 @@ gst_x265_enc_add_x265_chroma_format (GstStructure * s,
|
||||||
} else {
|
} else {
|
||||||
GST_ERROR ("Unsupported chroma format %d", x265_chroma_format_local);
|
GST_ERROR ("Unsupported chroma format %d", x265_chroma_format_local);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (G_VALUE_TYPE (&fmt) != G_TYPE_INVALID)
|
if (G_VALUE_TYPE (&fmt) != G_TYPE_INVALID)
|
||||||
gst_structure_take_value (s, "format", &fmt);
|
gst_structure_take_value (s, "format", &fmt);
|
||||||
|
@ -501,10 +526,14 @@ gst_x265_enc_gst_to_x265_video_format (GstVideoFormat format, gint * nplanes)
|
||||||
switch (format) {
|
switch (format) {
|
||||||
case GST_VIDEO_FORMAT_I420:
|
case GST_VIDEO_FORMAT_I420:
|
||||||
case GST_VIDEO_FORMAT_YV12:
|
case GST_VIDEO_FORMAT_YV12:
|
||||||
|
case GST_VIDEO_FORMAT_I420_10LE:
|
||||||
|
case GST_VIDEO_FORMAT_I420_10BE:
|
||||||
if (nplanes)
|
if (nplanes)
|
||||||
*nplanes = 3;
|
*nplanes = 3;
|
||||||
return X265_CSP_I420;
|
return X265_CSP_I420;
|
||||||
case GST_VIDEO_FORMAT_Y444:
|
case GST_VIDEO_FORMAT_Y444:
|
||||||
|
case GST_VIDEO_FORMAT_Y444_10LE:
|
||||||
|
case GST_VIDEO_FORMAT_Y444_10BE:
|
||||||
if (nplanes)
|
if (nplanes)
|
||||||
*nplanes = 3;
|
*nplanes = 3;
|
||||||
return X265_CSP_I444;
|
return X265_CSP_I444;
|
||||||
|
@ -952,7 +981,7 @@ gst_x265_enc_handle_frame (GstVideoEncoder * video_enc,
|
||||||
pic_in.sliceType = X265_TYPE_AUTO;
|
pic_in.sliceType = X265_TYPE_AUTO;
|
||||||
pic_in.pts = frame->pts;
|
pic_in.pts = frame->pts;
|
||||||
pic_in.dts = frame->dts;
|
pic_in.dts = frame->dts;
|
||||||
pic_in.bitDepth = 8;
|
pic_in.bitDepth = info->finfo->depth[0];
|
||||||
pic_in.userData = GINT_TO_POINTER (frame->system_frame_number);
|
pic_in.userData = GINT_TO_POINTER (frame->system_frame_number);
|
||||||
|
|
||||||
ret = gst_x265_enc_encode_frame (encoder, &pic_in, frame, &i_nal, TRUE);
|
ret = gst_x265_enc_encode_frame (encoder, &pic_in, frame, &i_nal, TRUE);
|
||||||
|
|
Loading…
Reference in a new issue