Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
545a0b80
Commit
545a0b80
authored
Aug 15, 2013
by
Justin Ruggles
Committed by
Justin Ruggles
Aug 20, 2013
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
vf_fps: add 'start_time' option
This allows for dropping or duplication to match a particular start time.
parent
2a615925
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
23 additions
and
1 deletion
+23
-1
filters.texi
doc/filters.texi
+8
-0
vf_fps.c
libavfilter/vf_fps.c
+15
-1
No files found.
doc/filters.texi
View file @
545a0b80
...
@@ -1241,6 +1241,14 @@ This filter accepts the following named parameters:
...
@@ -1241,6 +1241,14 @@ This filter accepts the following named parameters:
@item fps
@item fps
Desired output framerate.
Desired output framerate.
@item start_time
Assume the first PTS should be the given value, in seconds. This allows for
padding/trimming at the start of stream. By default, no assumption is made
about the first frame's expected PTS, so no padding or trimming is done.
For example, this could be set to 0 to pad the beginning with duplicates of
the first frame if a video stream starts after the audio stream or to trim any
frames with a negative PTS.
@end table
@end table
@anchor{frei0r}
@anchor{frei0r}
...
...
libavfilter/vf_fps.c
View file @
545a0b80
...
@@ -40,6 +40,8 @@ typedef struct FPSContext {
...
@@ -40,6 +40,8 @@ typedef struct FPSContext {
int64_t
first_pts
;
///< pts of the first frame that arrived on this filter
int64_t
first_pts
;
///< pts of the first frame that arrived on this filter
int64_t
pts
;
///< pts of the first frame currently in the fifo
int64_t
pts
;
///< pts of the first frame currently in the fifo
double
start_time
;
///< pts, in seconds, of the expected first frame
AVRational
framerate
;
///< target framerate
AVRational
framerate
;
///< target framerate
char
*
fps
;
///< a string describing target framerate
char
*
fps
;
///< a string describing target framerate
...
@@ -54,6 +56,7 @@ typedef struct FPSContext {
...
@@ -54,6 +56,7 @@ typedef struct FPSContext {
#define V AV_OPT_FLAG_VIDEO_PARAM
#define V AV_OPT_FLAG_VIDEO_PARAM
static
const
AVOption
options
[]
=
{
static
const
AVOption
options
[]
=
{
{
"fps"
,
"A string describing desired output framerate"
,
OFFSET
(
fps
),
AV_OPT_TYPE_STRING
,
{
.
str
=
"25"
},
.
flags
=
V
},
{
"fps"
,
"A string describing desired output framerate"
,
OFFSET
(
fps
),
AV_OPT_TYPE_STRING
,
{
.
str
=
"25"
},
.
flags
=
V
},
{
"start_time"
,
"Assume the first PTS should be this value."
,
OFFSET
(
start_time
),
AV_OPT_TYPE_DOUBLE
,
{
.
dbl
=
AV_NOPTS_VALUE
},
INT64_MIN
,
INT64_MAX
,
V
},
{
NULL
},
{
NULL
},
};
};
...
@@ -78,6 +81,7 @@ static av_cold int init(AVFilterContext *ctx)
...
@@ -78,6 +81,7 @@ static av_cold int init(AVFilterContext *ctx)
return
AVERROR
(
ENOMEM
);
return
AVERROR
(
ENOMEM
);
s
->
pts
=
AV_NOPTS_VALUE
;
s
->
pts
=
AV_NOPTS_VALUE
;
s
->
first_pts
=
AV_NOPTS_VALUE
;
av_log
(
ctx
,
AV_LOG_VERBOSE
,
"fps=%d/%d
\n
"
,
s
->
framerate
.
num
,
s
->
framerate
.
den
);
av_log
(
ctx
,
AV_LOG_VERBOSE
,
"fps=%d/%d
\n
"
,
s
->
framerate
.
num
,
s
->
framerate
.
den
);
return
0
;
return
0
;
...
@@ -177,7 +181,17 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *buf)
...
@@ -177,7 +181,17 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *buf)
if
(
ret
<
0
)
if
(
ret
<
0
)
return
ret
;
return
ret
;
s
->
first_pts
=
s
->
pts
=
buf
->
pts
;
if
(
s
->
start_time
!=
AV_NOPTS_VALUE
)
{
double
first_pts
=
s
->
start_time
*
AV_TIME_BASE
;
first_pts
=
FFMIN
(
FFMAX
(
first_pts
,
INT64_MIN
),
INT64_MAX
);
s
->
first_pts
=
s
->
pts
=
av_rescale_q
(
first_pts
,
AV_TIME_BASE_Q
,
inlink
->
time_base
);
av_log
(
ctx
,
AV_LOG_VERBOSE
,
"Set first pts to (in:%"
PRId64
" out:%"
PRId64
")
\n
"
,
s
->
first_pts
,
av_rescale_q
(
first_pts
,
AV_TIME_BASE_Q
,
outlink
->
time_base
));
}
else
{
s
->
first_pts
=
s
->
pts
=
buf
->
pts
;
}
}
else
{
}
else
{
av_log
(
ctx
,
AV_LOG_WARNING
,
"Discarding initial frame(s) with no "
av_log
(
ctx
,
AV_LOG_WARNING
,
"Discarding initial frame(s) with no "
"timestamp.
\n
"
);
"timestamp.
\n
"
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment