Chromium Code Reviews| Index: media/base/renderer.h |
| diff --git a/media/base/renderer.h b/media/base/renderer.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..7cbf6508d84af3cf7b69b21977408aa2854a8387 |
| --- /dev/null |
| +++ b/media/base/renderer.h |
| @@ -0,0 +1,74 @@ |
| +// 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_BASE_RENDERER_H_ |
| +#define MEDIA_BASE_RENDERER_H_ |
| + |
| +#include "base/callback.h" |
| +#include "base/time/time.h" |
| +#include "media/base/buffering_state.h" |
| +#include "media/base/media_export.h" |
| +#include "media/base/pipeline_status.h" |
| + |
| +namespace media { |
| + |
| +class MediaKeys; |
| +class TimeDeltaInterpolator; |
| + |
| +class MEDIA_EXPORT Renderer { |
| + public: |
| + Renderer(); |
| + |
| + // Stops rendering and fires any pending callbacks. |
| + virtual ~Renderer(); |
| + |
| + // Initializes the Renderer, executing |init_cb| upon completion. |
| + // TODO(xhwang): Provide a set of DemuxerStreams in Initialize(). |
| + // TODO(xhwang): Replace |init_cb|, |flush_cb| and |stop_cb| with Closures. |
| + // |
| + // Permanent callbacks: |
| + // - |statistics_cb|: Executed periodically with rendering statistics. |
| + // - |time_cb|: Executed whenever time has advanced through rendering. |
| + // - |ended_cb|: Executed when rendering has reached the end of stream. |
| + // - |error_cb|: Executed if any error was encountered during rendering. |
| + virtual void Initialize(const PipelineStatusCB& init_cb, |
| + const StatisticsCB& statistics_cb, |
| + const base::Closure& ended_cb, |
| + const PipelineStatusCB& error_cb, |
| + const BufferingStateCB& buffering_state_cb) = 0; |
| + |
| + // Discards any buffered data, executing |done_cb| when completed. |
| + virtual void Flush(const base::Closure& flush_cb) = 0; |
| + |
| + // Starts rendering from |timestamp|. |
| + // TODO(xhwang): Switch to SetMediaTime() + StartPlaying() model? |
|
xhwang
2014/07/25 00:39:29
See TODO :)
|
| + virtual void StartPlayingFrom(base::TimeDelta timestamp) = 0; |
| + |
| + // Updates the current playback rate. The default playback rate should be 1. |
| + virtual void SetPlaybackRate(float playback_rate) = 0; |
| + |
| + // Sets the output volume. The default volume should be 1. |
| + virtual void SetVolume(float volume) = 0; |
| + |
| + virtual base::TimeDelta GetMediaTime() const = 0; |
| + |
| + virtual bool HasAudio() const = 0; |
| + |
| + virtual bool HasVideo() const = 0; |
| + |
| + // Associates the |cdm| with this Renderer. |
| + virtual void SetCdm(MediaKeys* cdm) = 0; |
| + |
| + // Helper functions for testing purposes. Must be called before Initialize(). |
| + virtual void DisableUnderflowForTesting(); |
| + virtual void SetTimeDeltaInterpolatorForTesting( |
| + TimeDeltaInterpolator* interpolator); |
|
xhwang
2014/07/25 00:39:29
It's ugly to put these two here. But I don't have
|
| + |
| + private: |
| + DISALLOW_COPY_AND_ASSIGN(Renderer); |
| +}; |
| + |
| +} // namespace media |
| + |
| +#endif // MEDIA_BASE_RENDERER_H_ |