Index: media/filters/frame_processor_base.h |
diff --git a/media/filters/frame_processor_base.h b/media/filters/frame_processor_base.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..4943ba941eab4c9c6543f256d4ad243754ba19a2 |
--- /dev/null |
+++ b/media/filters/frame_processor_base.h |
@@ -0,0 +1,140 @@ |
+// Copyright 2014 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef MEDIA_FILTERS_FRAME_PROCESSOR_BASE_H_ |
+#define MEDIA_FILTERS_FRAME_PROCESSOR_BASE_H_ |
+ |
+#include <map> |
+ |
+#include "base/basictypes.h" |
+#include "base/time/time.h" |
+#include "media/base/media_export.h" |
+#include "media/base/stream_parser.h" |
+#include "media/filters/chunk_demuxer.h" |
+ |
+namespace media { |
+ |
+// Helper class to capture per-track details needed by a frame processor. Some |
+// of this information may be duplicated in the short-term in the associated |
+// ChunkDemuxerStream and SourceBufferStream for a track. |
+// This parallels the MSE spec each of a SourceBuffer's Track Buffers at |
+// http://www.w3.org/TR/media-source/#track-buffers. |
+class MseTrackBuffer { |
+ public: |
+ explicit MseTrackBuffer(ChunkDemuxerStream* stream); |
+ ~MseTrackBuffer(); |
+ |
+ // Get/set |needs_random_access_point_|. |
+ bool needs_random_access_point() const { |
+ return needs_random_access_point_; |
+ } |
+ void set_needs_random_access_point(bool needs_random_access_point) { |
+ needs_random_access_point_ = needs_random_access_point; |
+ } |
+ |
+ // Gets a pointer to this track's ChunkDemuxerStream. |
+ ChunkDemuxerStream* stream() const { return stream_; } |
+ |
+ // Sets |needs_random_access_point_| to true. |
+ // TODO(wolenetz): Add the rest of the new coded frame processing algorithm |
+ // track buffer attributes and reset them here. See http://crbug.com/249422. |
+ void Reset(); |
+ |
+ private: |
+ // Keeps track of whether the track buffer is waiting for a random access |
+ // point coded frame. Initially set to true to indicate that a random access |
+ // point coded frame is needed before anything can be added to the track |
+ // buffer. |
+ bool needs_random_access_point_; |
+ |
+ // Pointer to the stream associated with this track. The stream is not owned |
+ // by |this|. |
+ ChunkDemuxerStream* const stream_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(MseTrackBuffer); |
+}; |
+ |
+// Abstract interface for helper class implementation of Media Source |
+// Extension's coded frame processing algorithm. |
+// TODO(wolenetz): Once the new FrameProcessor implementation stabilizes, remove |
+// LegacyFrameProcessor and fold this interface into FrameProcessor. See |
+// http://crbug.com/249422. |
+class MEDIA_EXPORT FrameProcessorBase { |
+ public: |
+ // TODO(wolenetz/acolwell): Ensure that all TrackIds are coherent and unique |
+ // for each track buffer. For now, special track identifiers are used for each |
+ // of audio and video here, and text TrackIds are assumed to be non-negative. |
+ // See http://crbug.com/341581. |
+ enum { |
+ kAudioTrackId = -2, |
+ kVideoTrackId = -3 |
+ }; |
+ |
+ // Callback signature used to notify ChunkDemuxer of timestamps that may cause |
+ // the duration to be updated. |
+ typedef base::Callback<void( |
+ base::TimeDelta, ChunkDemuxerStream*)> IncreaseDurationCB; |
+ |
+ virtual ~FrameProcessorBase(); |
+ |
+ // Get/set the current append mode, which if true means "sequence" and if |
+ // false means "segments". |
+ // See http://www.w3.org/TR/media-source/#widl-SourceBuffer-mode. |
+ bool sequence_mode() { return sequence_mode_; } |
+ virtual void SetSequenceMode(bool sequence_mode) = 0; |
+ |
+ // Processes buffers in |audio_buffers|, |video_buffers|, and |text_map|. |
+ // Returns true on success or false on failure which indicates decode error. |
+ // |append_window_start| and |append_window_end| correspond to the MSE spec's |
+ // similarly named source buffer attributes that are used in coded frame |
+ // processing. |
+ // |*new_media_segment| tracks whether the next buffers processed within the |
+ // append window represent the start of a new media segment. This method may |
+ // both use and update this flag. |
+ // Uses |*timestamp_offset| according to the coded frame processing algorithm, |
+ // including updating it as required in 'sequence' mode frame processing. |
+ virtual bool ProcessFrames(const StreamParser::BufferQueue& audio_buffers, |
+ const StreamParser::BufferQueue& video_buffers, |
+ const StreamParser::TextBufferQueueMap& text_map, |
+ base::TimeDelta append_window_start, |
+ base::TimeDelta append_window_end, |
+ bool* new_media_segment, |
+ base::TimeDelta* timestamp_offset) = 0; |
+ |
+ // Adds a new track with unique track ID |id|. |
+ // If |id| has previously been added, returns false to indicate error. |
+ // Otherwise, returns true, indicating future ProcessFrames() will emit |
+ // frames for the track |id| to |stream|. |
+ bool AddTrack(StreamParser::TrackId id, ChunkDemuxerStream* stream); |
+ |
+ // Resets state for the coded frame processing algorithm as described in steps |
+ // 2-5 of the MSE Reset Parser State algorithm described at |
+ // http://www.w3.org/TR/media-source/#sourcebuffer-reset-parser-state |
+ void Reset(); |
+ |
+ protected: |
+ typedef std::map<StreamParser::TrackId, MseTrackBuffer*> TrackBufferMap; |
+ |
+ explicit FrameProcessorBase(const IncreaseDurationCB& increase_duration_cb); |
+ |
+ // If |track_buffers_| contains |id|, returns a pointer to the associated |
+ // MseTrackBuffer. Otherwise, returns NULL. |
+ MseTrackBuffer* FindTrack(StreamParser::TrackId id); |
+ |
+ // The AppendMode of the associated SourceBuffer. |
+ // See SetSequenceMode() for interpretation of |sequence_mode_|. |
+ // Per http://www.w3.org/TR/media-source/#widl-SourceBuffer-mode: |
+ // Controls how a sequence of media segments are handled. This is initially |
+ // set to false ("segments"). |
+ bool sequence_mode_; |
+ |
+ IncreaseDurationCB increase_duration_cb_; |
+ |
+ // TrackId-indexed map of each track's stream. |
+ TrackBufferMap track_buffers_; |
+}; |
+ |
+} // namespace media |
+ |
+#endif // MEDIA_FILTERS_FRAME_PROCESSOR_BASE_H_ |