mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
avcodec/setts_bsf: don't repeatedly set start pts and dts
Signed-off-by: James Almer <jamrial@gmail.com>
This commit is contained in:
parent
c5628ae347
commit
85b7be53e1
@ -91,9 +91,6 @@ typedef struct SetTSContext {
|
||||
|
||||
int64_t frame_number;
|
||||
|
||||
int64_t start_pts;
|
||||
int64_t start_dts;
|
||||
|
||||
double var_values[VAR_VARS_NB];
|
||||
|
||||
AVExpr *ts_expr;
|
||||
@ -149,8 +146,8 @@ static int setts_init(AVBSFContext *ctx)
|
||||
ctx->time_base_out = s->time_base;
|
||||
|
||||
s->frame_number= 0;
|
||||
s->start_pts = AV_NOPTS_VALUE;
|
||||
s->start_dts = AV_NOPTS_VALUE;
|
||||
s->var_values[VAR_STARTPTS] = AV_NOPTS_VALUE;
|
||||
s->var_values[VAR_STARTDTS] = AV_NOPTS_VALUE;
|
||||
s->var_values[VAR_NOPTS] = AV_NOPTS_VALUE;
|
||||
s->var_values[VAR_TB] = ctx->time_base_in.den ? av_q2d(ctx->time_base_in) : 0;
|
||||
s->var_values[VAR_TB_OUT]= ctx->time_base_out.den ? av_q2d(ctx->time_base_out) : 0;
|
||||
@ -174,11 +171,11 @@ static int setts_filter(AVBSFContext *ctx, AVPacket *pkt)
|
||||
return AVERROR(EAGAIN);
|
||||
}
|
||||
|
||||
if (s->start_pts == AV_NOPTS_VALUE)
|
||||
s->start_pts = s->cur_pkt->pts;
|
||||
if (s->var_values[VAR_STARTPTS] == AV_NOPTS_VALUE)
|
||||
s->var_values[VAR_STARTPTS] = s->cur_pkt->pts;
|
||||
|
||||
if (s->start_dts == AV_NOPTS_VALUE)
|
||||
s->start_dts = s->cur_pkt->dts;
|
||||
if (s->var_values[VAR_STARTDTS] == AV_NOPTS_VALUE)
|
||||
s->var_values[VAR_STARTDTS] = s->cur_pkt->dts;
|
||||
|
||||
s->var_values[VAR_N] = s->frame_number++;
|
||||
s->var_values[VAR_TS] = s->cur_pkt->dts;
|
||||
@ -195,8 +192,6 @@ static int setts_filter(AVBSFContext *ctx, AVPacket *pkt)
|
||||
s->var_values[VAR_NEXT_PTS] = pkt->pts;
|
||||
s->var_values[VAR_NEXT_DTS] = pkt->dts;
|
||||
s->var_values[VAR_NEXT_DUR] = pkt->duration;
|
||||
s->var_values[VAR_STARTPTS] = s->start_pts;
|
||||
s->var_values[VAR_STARTDTS] = s->start_dts;
|
||||
|
||||
new_ts = llrint(av_expr_eval(s->ts_expr, s->var_values, NULL));
|
||||
new_duration = llrint(av_expr_eval(s->duration_expr, s->var_values, NULL));
|
||||
|
Loading…
Reference in New Issue
Block a user