mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-03-01 18:21:04 +00:00
Merge commit 'e3453fd44480d903338c663238bf280215dd9a07'
* commit 'e3453fd44480d903338c663238bf280215dd9a07': matroska: Write the field order information Merged-by: Derek Buitenhuis <derek.buitenhuis@gmail.com>
This commit is contained in:
commit
ee865e9780
@ -789,6 +789,44 @@ static int mkv_write_video_color(AVIOContext *pb, AVCodecParameters *par, AVStre
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void mkv_write_field_order(AVIOContext *pb,
|
||||||
|
enum AVFieldOrder field_order)
|
||||||
|
{
|
||||||
|
switch (field_order) {
|
||||||
|
case AV_FIELD_UNKNOWN:
|
||||||
|
put_ebml_uint(pb, MATROSKA_ID_VIDEOFLAGINTERLACED,
|
||||||
|
MATROSKA_VIDEO_INTERLACE_FLAG_UNDETERMINED);
|
||||||
|
break;
|
||||||
|
case AV_FIELD_PROGRESSIVE:
|
||||||
|
put_ebml_uint(pb, MATROSKA_ID_VIDEOFLAGINTERLACED,
|
||||||
|
MATROSKA_VIDEO_INTERLACE_FLAG_PROGRESSIVE);
|
||||||
|
break;
|
||||||
|
case AV_FIELD_TT:
|
||||||
|
case AV_FIELD_BB:
|
||||||
|
case AV_FIELD_TB:
|
||||||
|
case AV_FIELD_BT:
|
||||||
|
put_ebml_uint(pb, MATROSKA_ID_VIDEOFLAGINTERLACED,
|
||||||
|
MATROSKA_VIDEO_INTERLACE_FLAG_INTERLACED);
|
||||||
|
switch (field_order) {
|
||||||
|
case AV_FIELD_TT:
|
||||||
|
put_ebml_uint(pb, MATROSKA_ID_VIDEOFIELDORDER,
|
||||||
|
MATROSKA_VIDEO_FIELDORDER_TT);
|
||||||
|
break;
|
||||||
|
case AV_FIELD_BB:
|
||||||
|
put_ebml_uint(pb, MATROSKA_ID_VIDEOFIELDORDER,
|
||||||
|
MATROSKA_VIDEO_FIELDORDER_BB);
|
||||||
|
break;
|
||||||
|
case AV_FIELD_TB:
|
||||||
|
put_ebml_uint(pb, MATROSKA_ID_VIDEOFIELDORDER,
|
||||||
|
MATROSKA_VIDEO_FIELDORDER_TB);
|
||||||
|
break;
|
||||||
|
case AV_FIELD_BT:
|
||||||
|
put_ebml_uint(pb, MATROSKA_ID_VIDEOFIELDORDER,
|
||||||
|
MATROSKA_VIDEO_FIELDORDER_BT);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static int mkv_write_stereo_mode(AVFormatContext *s, AVIOContext *pb,
|
static int mkv_write_stereo_mode(AVFormatContext *s, AVIOContext *pb,
|
||||||
AVStream *st, int mode, int *h_width, int *h_height)
|
AVStream *st, int mode, int *h_width, int *h_height)
|
||||||
@ -1041,10 +1079,13 @@ static int mkv_write_track(AVFormatContext *s, MatroskaMuxContext *mkv,
|
|||||||
}
|
}
|
||||||
|
|
||||||
subinfo = start_ebml_master(pb, MATROSKA_ID_TRACKVIDEO, 0);
|
subinfo = start_ebml_master(pb, MATROSKA_ID_TRACKVIDEO, 0);
|
||||||
// XXX: interlace flag?
|
|
||||||
put_ebml_uint (pb, MATROSKA_ID_VIDEOPIXELWIDTH , par->width);
|
put_ebml_uint (pb, MATROSKA_ID_VIDEOPIXELWIDTH , par->width);
|
||||||
put_ebml_uint (pb, MATROSKA_ID_VIDEOPIXELHEIGHT, par->height);
|
put_ebml_uint (pb, MATROSKA_ID_VIDEOPIXELHEIGHT, par->height);
|
||||||
|
|
||||||
|
if (mkv->mode != MODE_WEBM)
|
||||||
|
mkv_write_field_order(pb, par->field_order);
|
||||||
|
|
||||||
// check both side data and metadata for stereo information,
|
// check both side data and metadata for stereo information,
|
||||||
// write the result to the bitstream if any is found
|
// write the result to the bitstream if any is found
|
||||||
ret = mkv_write_stereo_mode(s, pb, st, mkv->mode,
|
ret = mkv_write_stereo_mode(s, pb, st, mkv->mode,
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
7c6509f597fb57bab002cbceec960011 *./tests/data/lavf/lavf.mkv
|
c081514c38735524ab09dbd2a498b7b3 *./tests/data/lavf/lavf.mkv
|
||||||
472872 ./tests/data/lavf/lavf.mkv
|
472875 ./tests/data/lavf/lavf.mkv
|
||||||
./tests/data/lavf/lavf.mkv CRC=0xec6c3c68
|
./tests/data/lavf/lavf.mkv CRC=0xec6c3c68
|
||||||
5f8cb4b7e98610347dd8d0d58a828a0f *./tests/data/lavf/lavf.mkv
|
d1fc3a31150d00aebbd674862640f701 *./tests/data/lavf/lavf.mkv
|
||||||
320548 ./tests/data/lavf/lavf.mkv
|
320551 ./tests/data/lavf/lavf.mkv
|
||||||
./tests/data/lavf/lavf.mkv CRC=0xec6c3c68
|
./tests/data/lavf/lavf.mkv CRC=0xec6c3c68
|
||||||
|
@ -1,48 +1,48 @@
|
|||||||
ret: 0 st: 1 flags:1 dts: 0.000000 pts: 0.000000 pos: 797 size: 208
|
ret: 0 st: 1 flags:1 dts: 0.000000 pts: 0.000000 pos: 800 size: 208
|
||||||
ret: 0 st:-1 flags:0 ts:-1.000000
|
ret: 0 st:-1 flags:0 ts:-1.000000
|
||||||
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1013 size: 27837
|
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1016 size: 27837
|
||||||
ret: 0 st:-1 flags:1 ts: 1.894167
|
ret: 0 st:-1 flags:1 ts: 1.894167
|
||||||
ret: 0 st: 0 flags:1 dts: 0.971000 pts: 0.971000 pos: 292427 size: 27834
|
ret: 0 st: 0 flags:1 dts: 0.971000 pts: 0.971000 pos: 292430 size: 27834
|
||||||
ret: 0 st: 0 flags:0 ts: 0.788000
|
ret: 0 st: 0 flags:0 ts: 0.788000
|
||||||
ret: 0 st: 0 flags:1 dts: 0.971000 pts: 0.971000 pos: 292427 size: 27834
|
ret: 0 st: 0 flags:1 dts: 0.971000 pts: 0.971000 pos: 292430 size: 27834
|
||||||
ret: 0 st: 0 flags:1 ts:-0.317000
|
ret: 0 st: 0 flags:1 ts:-0.317000
|
||||||
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1013 size: 27837
|
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1016 size: 27837
|
||||||
ret:-1 st: 1 flags:0 ts: 2.577000
|
ret:-1 st: 1 flags:0 ts: 2.577000
|
||||||
ret: 0 st: 1 flags:1 ts: 1.471000
|
ret: 0 st: 1 flags:1 ts: 1.471000
|
||||||
ret: 0 st: 1 flags:1 dts: 0.993000 pts: 0.993000 pos: 320268 size: 209
|
ret: 0 st: 1 flags:1 dts: 0.993000 pts: 0.993000 pos: 320271 size: 209
|
||||||
ret: 0 st:-1 flags:0 ts: 0.365002
|
ret: 0 st:-1 flags:0 ts: 0.365002
|
||||||
ret: 0 st: 0 flags:1 dts: 0.491000 pts: 0.491000 pos: 146980 size: 27925
|
ret: 0 st: 0 flags:1 dts: 0.491000 pts: 0.491000 pos: 146983 size: 27925
|
||||||
ret: 0 st:-1 flags:1 ts:-0.740831
|
ret: 0 st:-1 flags:1 ts:-0.740831
|
||||||
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1013 size: 27837
|
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1016 size: 27837
|
||||||
ret:-1 st: 0 flags:0 ts: 2.153000
|
ret:-1 st: 0 flags:0 ts: 2.153000
|
||||||
ret: 0 st: 0 flags:1 ts: 1.048000
|
ret: 0 st: 0 flags:1 ts: 1.048000
|
||||||
ret: 0 st: 0 flags:1 dts: 0.971000 pts: 0.971000 pos: 292427 size: 27834
|
ret: 0 st: 0 flags:1 dts: 0.971000 pts: 0.971000 pos: 292430 size: 27834
|
||||||
ret: 0 st: 1 flags:0 ts:-0.058000
|
ret: 0 st: 1 flags:0 ts:-0.058000
|
||||||
ret: 0 st: 1 flags:1 dts: 0.000000 pts: 0.000000 pos: 797 size: 208
|
ret: 0 st: 1 flags:1 dts: 0.000000 pts: 0.000000 pos: 800 size: 208
|
||||||
ret: 0 st: 1 flags:1 ts: 2.836000
|
ret: 0 st: 1 flags:1 ts: 2.836000
|
||||||
ret: 0 st: 1 flags:1 dts: 0.993000 pts: 0.993000 pos: 320268 size: 209
|
ret: 0 st: 1 flags:1 dts: 0.993000 pts: 0.993000 pos: 320271 size: 209
|
||||||
ret:-1 st:-1 flags:0 ts: 1.730004
|
ret:-1 st:-1 flags:0 ts: 1.730004
|
||||||
ret: 0 st:-1 flags:1 ts: 0.624171
|
ret: 0 st:-1 flags:1 ts: 0.624171
|
||||||
ret: 0 st: 0 flags:1 dts: 0.491000 pts: 0.491000 pos: 146980 size: 27925
|
ret: 0 st: 0 flags:1 dts: 0.491000 pts: 0.491000 pos: 146983 size: 27925
|
||||||
ret: 0 st: 0 flags:0 ts:-0.482000
|
ret: 0 st: 0 flags:0 ts:-0.482000
|
||||||
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1013 size: 27837
|
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1016 size: 27837
|
||||||
ret: 0 st: 0 flags:1 ts: 2.413000
|
ret: 0 st: 0 flags:1 ts: 2.413000
|
||||||
ret: 0 st: 0 flags:1 dts: 0.971000 pts: 0.971000 pos: 292427 size: 27834
|
ret: 0 st: 0 flags:1 dts: 0.971000 pts: 0.971000 pos: 292430 size: 27834
|
||||||
ret:-1 st: 1 flags:0 ts: 1.307000
|
ret:-1 st: 1 flags:0 ts: 1.307000
|
||||||
ret: 0 st: 1 flags:1 ts: 0.201000
|
ret: 0 st: 1 flags:1 ts: 0.201000
|
||||||
ret: 0 st: 1 flags:1 dts: 0.000000 pts: 0.000000 pos: 797 size: 208
|
ret: 0 st: 1 flags:1 dts: 0.000000 pts: 0.000000 pos: 800 size: 208
|
||||||
ret: 0 st:-1 flags:0 ts:-0.904994
|
ret: 0 st:-1 flags:0 ts:-0.904994
|
||||||
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1013 size: 27837
|
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1016 size: 27837
|
||||||
ret: 0 st:-1 flags:1 ts: 1.989173
|
ret: 0 st:-1 flags:1 ts: 1.989173
|
||||||
ret: 0 st: 0 flags:1 dts: 0.971000 pts: 0.971000 pos: 292427 size: 27834
|
ret: 0 st: 0 flags:1 dts: 0.971000 pts: 0.971000 pos: 292430 size: 27834
|
||||||
ret: 0 st: 0 flags:0 ts: 0.883000
|
ret: 0 st: 0 flags:0 ts: 0.883000
|
||||||
ret: 0 st: 0 flags:1 dts: 0.971000 pts: 0.971000 pos: 292427 size: 27834
|
ret: 0 st: 0 flags:1 dts: 0.971000 pts: 0.971000 pos: 292430 size: 27834
|
||||||
ret: 0 st: 0 flags:1 ts:-0.222000
|
ret: 0 st: 0 flags:1 ts:-0.222000
|
||||||
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1013 size: 27837
|
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1016 size: 27837
|
||||||
ret:-1 st: 1 flags:0 ts: 2.672000
|
ret:-1 st: 1 flags:0 ts: 2.672000
|
||||||
ret: 0 st: 1 flags:1 ts: 1.566000
|
ret: 0 st: 1 flags:1 ts: 1.566000
|
||||||
ret: 0 st: 1 flags:1 dts: 0.993000 pts: 0.993000 pos: 320268 size: 209
|
ret: 0 st: 1 flags:1 dts: 0.993000 pts: 0.993000 pos: 320271 size: 209
|
||||||
ret: 0 st:-1 flags:0 ts: 0.460008
|
ret: 0 st:-1 flags:0 ts: 0.460008
|
||||||
ret: 0 st: 0 flags:1 dts: 0.491000 pts: 0.491000 pos: 146980 size: 27925
|
ret: 0 st: 0 flags:1 dts: 0.491000 pts: 0.491000 pos: 146983 size: 27925
|
||||||
ret: 0 st:-1 flags:1 ts:-0.645825
|
ret: 0 st:-1 flags:1 ts:-0.645825
|
||||||
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1013 size: 27837
|
ret: 0 st: 0 flags:1 dts: 0.011000 pts: 0.011000 pos: 1016 size: 27837
|
||||||
|
Loading…
Reference in New Issue
Block a user