use base class' newsegment to properly timestamp

Original commit message from CVS:

use base class' newsegment to properly timestamp
This commit is contained in:
Thomas Vander Stichele 2005-08-26 17:35:28 +00:00
parent 282065617d
commit fb39749b0f

View file

@ -295,9 +295,12 @@ gboolean
} else { } else {
/* take a best guess, this is called cheating */ /* take a best guess, this is called cheating */
*othersize = floor (size * state->i_rate / state->o_rate); *othersize = floor (size * state->i_rate / state->o_rate);
*othersize -= *othersize % state->sample_size;
} }
*othersize += state->sample_size; *othersize += state->sample_size;
g_assert (*othersize % state->sample_size == 0);
/* we make room for one extra sample, given that the resampling filter /* we make room for one extra sample, given that the resampling filter
* can output an extra one for non-integral i_rate/o_rate */ * can output an extra one for non-integral i_rate/o_rate */
GST_DEBUG_OBJECT (base, "transformed size %d to %d", size, *othersize); GST_DEBUG_OBJECT (base, "transformed size %d to %d", size, *othersize);
@ -396,7 +399,7 @@ static GstFlowReturn
outsize, outsamples); outsize, outsamples);
GST_BUFFER_OFFSET (outbuf) = audioresample->offset; GST_BUFFER_OFFSET (outbuf) = audioresample->offset;
GST_BUFFER_TIMESTAMP (outbuf) = GST_BUFFER_TIMESTAMP (outbuf) = base->segment_start +
audioresample->offset * GST_SECOND / audioresample->o_rate; audioresample->offset * GST_SECOND / audioresample->o_rate;
audioresample->offset += outsamples; audioresample->offset += outsamples;
@ -405,7 +408,7 @@ static GstFlowReturn
/* we calculate DURATION as the difference between "next" timestamp /* we calculate DURATION as the difference between "next" timestamp
* and current timestamp so we ensure a contiguous stream, instead of * and current timestamp so we ensure a contiguous stream, instead of
* having rounding errors. */ * having rounding errors. */
GST_BUFFER_DURATION (outbuf) = GST_BUFFER_DURATION (outbuf) = base->segment_start +
audioresample->offset * GST_SECOND / audioresample->o_rate - audioresample->offset * GST_SECOND / audioresample->o_rate -
GST_BUFFER_TIMESTAMP (outbuf); GST_BUFFER_TIMESTAMP (outbuf);