Commit 176ac987 authored by Paul B Mahol's avatar Paul B Mahol

avfilter/f_graphmonitor: output frames in pts gaps

parent a1f8b36c
...@@ -42,6 +42,7 @@ typedef struct GraphMonitorContext { ...@@ -42,6 +42,7 @@ typedef struct GraphMonitorContext {
AVRational frame_rate; AVRational frame_rate;
int64_t pts; int64_t pts;
int64_t next_pts;
uint8_t white[4]; uint8_t white[4];
uint8_t yellow[4]; uint8_t yellow[4];
uint8_t red[4]; uint8_t red[4];
...@@ -300,7 +301,7 @@ static int create_frame(AVFilterContext *ctx, int64_t pts) ...@@ -300,7 +301,7 @@ static int create_frame(AVFilterContext *ctx, int64_t pts)
} }
out->pts = pts; out->pts = pts;
s->pts = pts; s->pts = pts + 1;
return ff_filter_frame(outlink, out); return ff_filter_frame(outlink, out);
} }
...@@ -328,10 +329,14 @@ static int activate(AVFilterContext *ctx) ...@@ -328,10 +329,14 @@ static int activate(AVFilterContext *ctx)
if (pts != AV_NOPTS_VALUE) { if (pts != AV_NOPTS_VALUE) {
pts = av_rescale_q(pts, inlink->time_base, outlink->time_base); pts = av_rescale_q(pts, inlink->time_base, outlink->time_base);
if (s->pts < pts && ff_outlink_frame_wanted(outlink)) if (s->pts == AV_NOPTS_VALUE)
return create_frame(ctx, pts); s->pts = pts;
s->next_pts = pts;
} }
if (s->pts < s->next_pts && ff_outlink_frame_wanted(outlink))
return create_frame(ctx, s->pts);
FF_FILTER_FORWARD_STATUS(inlink, outlink); FF_FILTER_FORWARD_STATUS(inlink, outlink);
FF_FILTER_FORWARD_WANTED(outlink, inlink); FF_FILTER_FORWARD_WANTED(outlink, inlink);
...@@ -347,6 +352,8 @@ static int config_output(AVFilterLink *outlink) ...@@ -347,6 +352,8 @@ static int config_output(AVFilterLink *outlink)
s->yellow[0] = s->yellow[1] = 255; s->yellow[0] = s->yellow[1] = 255;
s->red[0] = 255; s->red[0] = 255;
s->green[1] = 255; s->green[1] = 255;
s->pts = AV_NOPTS_VALUE;
s->next_pts = AV_NOPTS_VALUE;
outlink->w = s->w; outlink->w = s->w;
outlink->h = s->h; outlink->h = s->h;
outlink->sample_aspect_ratio = (AVRational){1,1}; outlink->sample_aspect_ratio = (AVRational){1,1};
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment