Index: media/filters/frame_processor_base.cc |
diff --git a/media/filters/frame_processor_base.cc b/media/filters/frame_processor_base.cc |
index 3e088ed5dc2966926443e23717ddb7086d636a52..130245a970f22f3d5dc4311409ca80bd193763b7 100644 |
--- a/media/filters/frame_processor_base.cc |
+++ b/media/filters/frame_processor_base.cc |
@@ -10,7 +10,10 @@ |
namespace media { |
MseTrackBuffer::MseTrackBuffer(ChunkDemuxerStream* stream) |
- : needs_random_access_point_(true), |
+ : last_decode_timestamp_(kNoTimestamp()), |
+ last_frame_duration_(kNoTimestamp()), |
+ highest_presentation_timestamp_(kNoTimestamp()), |
+ needs_random_access_point_(true), |
stream_(stream) { |
DCHECK(stream_); |
} |
@@ -22,9 +25,20 @@ MseTrackBuffer::~MseTrackBuffer() { |
void MseTrackBuffer::Reset() { |
DVLOG(2) << __FUNCTION__ << "()"; |
+ last_decode_timestamp_ = kNoTimestamp(); |
+ last_frame_duration_ = kNoTimestamp(); |
+ highest_presentation_timestamp_ = kNoTimestamp(); |
needs_random_access_point_ = true; |
} |
+void MseTrackBuffer::SetHighestPresentationTimestampIfIncreased( |
+ base::TimeDelta timestamp) { |
+ if (highest_presentation_timestamp_ == kNoTimestamp() || |
+ timestamp > highest_presentation_timestamp_) { |
+ highest_presentation_timestamp_ = timestamp; |
+ } |
+} |
+ |
FrameProcessorBase::FrameProcessorBase() |
: sequence_mode_(false) {} |
@@ -63,4 +77,14 @@ MseTrackBuffer* FrameProcessorBase::FindTrack(StreamParser::TrackId id) { |
return itr->second; |
} |
+void FrameProcessorBase::NotifyNewMediaSegmentStarting( |
+ base::TimeDelta segment_timestamp) { |
+ DVLOG(2) << __FUNCTION__ << "(" << segment_timestamp.InSecondsF() << ")"; |
+ |
+ for (TrackBufferMap::iterator itr = track_buffers_.begin(); |
+ itr != track_buffers_.end(); ++itr) { |
+ itr->second->stream()->OnNewMediaSegment(segment_timestamp); |
+ } |
+} |
+ |
} // namespace media |