// 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_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_ #define MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_ #include #include "base/macros.h" #include "base/memory/ref_counted.h" #include "base/memory/scoped_ptr.h" #include "base/memory/weak_ptr.h" #include "base/timer/timer.h" #include "media/base/buffering_state.h" #include "media/base/pipeline_status.h" #include "media/mojo/interfaces/renderer.mojom.h" #include "mojo/public/cpp/bindings/strong_binding.h" namespace media { class DemuxerStreamProviderShim; class MediaKeys; class MojoCdmServiceContext; class Renderer; // An interfaces::Renderer implementation that use a media::Renderer to render // media streams. class MojoRendererService : interfaces::Renderer { public: // |mojo_cdm_service_context| can be used to find the CDM to support // encrypted media. If null, encrypted media is not supported. MojoRendererService( base::WeakPtr mojo_cdm_service_context, scoped_ptr renderer, mojo::InterfaceRequest request); ~MojoRendererService() final; // interfaces::Renderer implementation. void Initialize(interfaces::RendererClientPtr client, interfaces::DemuxerStreamPtr audio, interfaces::DemuxerStreamPtr video, const mojo::Callback& callback) final; void Flush(const mojo::Closure& callback) final; void StartPlayingFrom(int64_t time_delta_usec) final; void SetPlaybackRate(double playback_rate) final; void SetVolume(float volume) final; void SetCdm(int32_t cdm_id, const mojo::Callback& callback) final; private: enum State { STATE_UNINITIALIZED, STATE_INITIALIZING, STATE_FLUSHING, STATE_PLAYING, STATE_ERROR }; // Called when the DemuxerStreamProviderShim is ready to go (has a config, // pipe handle, etc) and can be handed off to a renderer for use. void OnStreamReady(const mojo::Callback& callback); // Called when |audio_renderer_| initialization has completed. void OnRendererInitializeDone(const mojo::Callback& callback, PipelineStatus status); // Callback executed by filters to update statistics. void OnUpdateStatistics(const PipelineStatistics& stats); // Periodically polls the media time from the renderer and notifies the client // if the media time has changed since the last update. If |force| is true, // the client is notified even if the time is unchanged. void UpdateMediaTime(bool force); void CancelPeriodicMediaTimeUpdates(); void SchedulePeriodicMediaTimeUpdates(); // Callback executed by audio renderer when buffering state changes. // TODO(tim): Need old and new. void OnBufferingStateChanged(BufferingState new_buffering_state); // Callback executed when a renderer has ended. void OnRendererEnded(); // Callback executed when a runtime error happens. void OnError(PipelineStatus error); // Callback executed once Flush() completes. void OnFlushCompleted(const mojo::Closure& callback); // Callback executed once SetCdm() completes. void OnCdmAttached(scoped_refptr cdm, const mojo::Callback& callback, bool success); mojo::StrongBinding binding_; base::WeakPtr mojo_cdm_service_context_; State state_; scoped_ptr stream_provider_; base::RepeatingTimer time_update_timer_; uint64_t last_media_time_usec_; interfaces::RendererClientPtr client_; // Hold a reference to the CDM set on the |renderer_| so that the CDM won't be // destructed while the |renderer_| is still using it. scoped_refptr cdm_; // Note: Destroy |renderer_| first to avoid access violation into other // members, e.g. |stream_provider_| and |cdm_|. // Must use "media::" because "Renderer" is ambiguous. scoped_ptr renderer_; base::WeakPtr weak_this_; base::WeakPtrFactory weak_factory_; DISALLOW_COPY_AND_ASSIGN(MojoRendererService); }; } // namespace media #endif // MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_