mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-01-26 01:03:07 +00:00
ffmpeg: deprecate passing numbers to -vsync
There is never a reason to do this, using symbolic names is always preferred.
This commit is contained in:
parent
e3833e8a24
commit
6ce9546428
@ -1620,23 +1620,25 @@ It is useful for when flow speed of output packets is important, such as live st
|
|||||||
Read input at native frame rate. This is equivalent to setting @code{-readrate 1}.
|
Read input at native frame rate. This is equivalent to setting @code{-readrate 1}.
|
||||||
@item -vsync @var{parameter}
|
@item -vsync @var{parameter}
|
||||||
Video sync method.
|
Video sync method.
|
||||||
For compatibility reasons old values can be specified as numbers.
|
|
||||||
Newly added values will have to be specified as strings always.
|
For compatibility reasons some of the values can be specified as numbers (shown
|
||||||
|
in parentheses in the following table). This is deprecated and will stop working
|
||||||
|
in the future.
|
||||||
|
|
||||||
@table @option
|
@table @option
|
||||||
@item 0, passthrough
|
@item passthrough (0)
|
||||||
Each frame is passed with its timestamp from the demuxer to the muxer.
|
Each frame is passed with its timestamp from the demuxer to the muxer.
|
||||||
@item 1, cfr
|
@item cfr (1)
|
||||||
Frames will be duplicated and dropped to achieve exactly the requested
|
Frames will be duplicated and dropped to achieve exactly the requested
|
||||||
constant frame rate.
|
constant frame rate.
|
||||||
@item 2, vfr
|
@item vfr (2)
|
||||||
Frames are passed through with their timestamp or dropped so as to
|
Frames are passed through with their timestamp or dropped so as to
|
||||||
prevent 2 frames from having the same timestamp.
|
prevent 2 frames from having the same timestamp.
|
||||||
@item drop
|
@item drop
|
||||||
As passthrough but destroys all timestamps, making the muxer generate
|
As passthrough but destroys all timestamps, making the muxer generate
|
||||||
fresh timestamps based on frame-rate.
|
fresh timestamps based on frame-rate.
|
||||||
@item -1, auto
|
@item auto (-1)
|
||||||
Chooses between 1 and 2 depending on muxer capabilities. This is the
|
Chooses between cfr and vfr depending on muxer capabilities. This is the
|
||||||
default method.
|
default method.
|
||||||
@end table
|
@end table
|
||||||
|
|
||||||
|
@ -1731,7 +1731,7 @@ static OutputStream *new_video_stream(OptionsContext *o, AVFormatContext *oc, in
|
|||||||
|
|
||||||
if ((frame_rate || max_frame_rate) &&
|
if ((frame_rate || max_frame_rate) &&
|
||||||
video_sync_method == VSYNC_PASSTHROUGH)
|
video_sync_method == VSYNC_PASSTHROUGH)
|
||||||
av_log(NULL, AV_LOG_ERROR, "Using -vsync 0 and -r/-fpsmax can produce invalid output files\n");
|
av_log(NULL, AV_LOG_ERROR, "Using -vsync passthrough and -r/-fpsmax can produce invalid output files\n");
|
||||||
|
|
||||||
MATCH_PER_STREAM_OPT(frame_aspect_ratios, str, frame_aspect_ratio, oc, st);
|
MATCH_PER_STREAM_OPT(frame_aspect_ratios, str, frame_aspect_ratio, oc, st);
|
||||||
if (frame_aspect_ratio) {
|
if (frame_aspect_ratio) {
|
||||||
@ -3191,8 +3191,11 @@ static int opt_vsync(void *optctx, const char *opt, const char *arg)
|
|||||||
else if (!av_strcasecmp(arg, "passthrough")) video_sync_method = VSYNC_PASSTHROUGH;
|
else if (!av_strcasecmp(arg, "passthrough")) video_sync_method = VSYNC_PASSTHROUGH;
|
||||||
else if (!av_strcasecmp(arg, "drop")) video_sync_method = VSYNC_DROP;
|
else if (!av_strcasecmp(arg, "drop")) video_sync_method = VSYNC_DROP;
|
||||||
|
|
||||||
if (video_sync_method == VSYNC_AUTO)
|
if (video_sync_method == VSYNC_AUTO) {
|
||||||
video_sync_method = parse_number_or_die("vsync", arg, OPT_INT, VSYNC_AUTO, VSYNC_VFR);
|
video_sync_method = parse_number_or_die("vsync", arg, OPT_INT, VSYNC_AUTO, VSYNC_VFR);
|
||||||
|
av_log(NULL, AV_LOG_WARNING, "Passing a number to -vsync is deprecated,"
|
||||||
|
" use a string argument as described in the manual.\n");
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user