mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 18:05:37 +00:00
mpegvideoparse: Use sequence_display_extension values to update the src caps
The caps should always represent what the user is supposed to see. So if there is a sequence_display_extension associated with the stream then use the display_horizontal_size/display_vertical_size to update the src caps (if they are less than the values provided by sequence header). https://bugzilla.gnome.org/show_bug.cgi?id=704009
This commit is contained in:
parent
1e7b3a8c9e
commit
654744a03c
1 changed files with 20 additions and 2 deletions
|
@ -737,8 +737,26 @@ gst_mpegv_parse_update_src_caps (GstMpegvParse * mpvparse)
|
||||||
"parsed", G_TYPE_BOOLEAN, TRUE, NULL);
|
"parsed", G_TYPE_BOOLEAN, TRUE, NULL);
|
||||||
|
|
||||||
if (mpvparse->sequencehdr.width > 0 && mpvparse->sequencehdr.height > 0) {
|
if (mpvparse->sequencehdr.width > 0 && mpvparse->sequencehdr.height > 0) {
|
||||||
gst_caps_set_simple (caps, "width", G_TYPE_INT, mpvparse->sequencehdr.width,
|
GstMpegVideoSequenceDisplayExt *seqdispext;
|
||||||
"height", G_TYPE_INT, mpvparse->sequencehdr.height, NULL);
|
gint width, height;
|
||||||
|
|
||||||
|
width = mpvparse->sequencehdr.width;
|
||||||
|
height = mpvparse->sequencehdr.height;
|
||||||
|
|
||||||
|
if (mpvparse->config_flags & FLAG_SEQUENCE_DISPLAY_EXT) {
|
||||||
|
seqdispext = &mpvparse->sequencedispext;
|
||||||
|
|
||||||
|
if (seqdispext->display_horizontal_size <= width
|
||||||
|
&& seqdispext->display_vertical_size <= height) {
|
||||||
|
width = seqdispext->display_horizontal_size;
|
||||||
|
height = seqdispext->display_vertical_size;
|
||||||
|
GST_INFO_OBJECT (mpvparse,
|
||||||
|
"stream has display extension: display_width=%d display_height=%d",
|
||||||
|
width, height);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
gst_caps_set_simple (caps, "width", G_TYPE_INT, width,
|
||||||
|
"height", G_TYPE_INT, height, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* perhaps we have a framerate */
|
/* perhaps we have a framerate */
|
||||||
|
|
Loading…
Reference in a new issue