Browse Source

Merge commit '8cd472d3f947a6233e7dc628f0dc71c74e62413a'

* commit '8cd472d3f947a6233e7dc628f0dc71c74e62413a':
  avconv: make output -ss insert trim/atrim filters.

Conflicts:
	Changelog
	ffmpeg.c

Merged-by: Michael Niedermayer <michaelni@gmx.at>
tags/n2.0
Michael Niedermayer 12 years ago
parent
commit
4818388e6c
3 changed files with 14 additions and 10 deletions
  1. +2
    -1
      Changelog
  2. +0
    -5
      ffmpeg.c
  3. +12
    -4
      ffmpeg_filter.c

+ 2
- 1
Changelog View File

@@ -35,7 +35,8 @@ version <next>:
the vid.stab library the vid.stab library
- astats filter - astats filter
- trim and atrim filters - trim and atrim filters
- ffmpeg -t option is now sample-accurate when transcoding audio
- ffmpeg -t and -ss (output-only) options are now sample-accurate when
transcoding audio




version 1.2: version 1.2:


+ 0
- 5
ffmpeg.c View File

@@ -1059,11 +1059,6 @@ static int reap_filters(void)
av_rescale_q(of->start_time, av_rescale_q(of->start_time,
AV_TIME_BASE_Q, AV_TIME_BASE_Q,
ost->st->codec->time_base); ost->st->codec->time_base);

if (of->start_time && filtered_frame->pts < 0) {
av_frame_unref(filtered_frame);
continue;
}
} }
//if (ost->source_index >= 0) //if (ost->source_index >= 0)
// *filtered_frame= *input_streams[ost->source_index]->decoded_frame; //for me_threshold // *filtered_frame= *input_streams[ost->source_index]->decoded_frame; //for me_threshold


+ 12
- 4
ffmpeg_filter.c View File

@@ -286,10 +286,12 @@ static int insert_trim(OutputStream *ost, AVFilterContext **last_filter, int *pa
char filter_name[128]; char filter_name[128];
int ret = 0; int ret = 0;


if (of->recording_time == INT64_MAX)
if (of->recording_time == INT64_MAX && !of->start_time)
return 0; return 0;


return 0;
// Use with duration and without output starttime is buggy with trim filters
if (!of->start_time)
return 0;


trim = avfilter_get_by_name(name); trim = avfilter_get_by_name(name);
if (!trim) { if (!trim) {
@@ -304,8 +306,14 @@ static int insert_trim(OutputStream *ost, AVFilterContext **last_filter, int *pa
if (!ctx) if (!ctx)
return AVERROR(ENOMEM); return AVERROR(ENOMEM);


ret = av_opt_set_double(ctx, "duration", (double)of->recording_time / 1e6,
AV_OPT_SEARCH_CHILDREN);
if (of->recording_time != INT64_MAX) {
ret = av_opt_set_double(ctx, "duration", (double)of->recording_time / 1e6,
AV_OPT_SEARCH_CHILDREN);
}
if (ret >= 0 && of->start_time) {
ret = av_opt_set_double(ctx, "start", (double)of->start_time / 1e6,
AV_OPT_SEARCH_CHILDREN);
}
if (ret < 0) { if (ret < 0) {
av_log(ctx, AV_LOG_ERROR, "Error configuring the %s filter", name); av_log(ctx, AV_LOG_ERROR, "Error configuring the %s filter", name);
return ret; return ret;


Loading…
Cancel
Save