1 // Copyright 2022 Samsung Electronics Inc. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef MEDIA_RENDERERS_TIZEN_RENDERER_IMPL_H_
6 #define MEDIA_RENDERERS_TIZEN_RENDERER_IMPL_H_
10 #include "base/memory/raw_ptr.h"
11 #include "content/common/content_export.h"
12 #include "media/base/demuxer_stream.h"
13 #include "media/base/media_export.h"
14 #include "media/base/media_resource.h"
15 #include "media/base/pipeline_status.h"
16 #include "media/base/renderer.h"
17 #include "media/base/renderer_client.h"
18 #include "media/base/video_renderer_sink.h"
19 #include "media/base/waiting.h"
20 #include "media/mojo/mojom/renderer_extensions.mojom.h"
21 #include "mojo/public/cpp/bindings/pending_receiver.h"
22 #include "mojo/public/cpp/bindings/pending_remote.h"
23 #include "mojo/public/cpp/bindings/receiver.h"
24 #include "mojo/public/cpp/bindings/remote.h"
25 #include "third_party/abseil-cpp/absl/types/optional.h"
26 #include "ui/gfx/geometry/size.h"
29 class SingleThreadTaskRunner;
33 class MediaPlayerTizen;
40 class MediaPlayerRendererWebContentsObserver;
42 class CONTENT_EXPORT TizenRendererImpl
43 : public media::Renderer,
44 public media::mojom::MediaPlayerRendererExtension {
46 using RendererExtension = media::mojom::MediaPlayerRendererExtension;
47 using ClientExtension = media::mojom::MediaPlayerRendererClientExtension;
50 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner,
51 media::VideoRendererSink* sink);
55 WebContents* web_contents,
56 mojo::PendingReceiver<RendererExtension> renderer_extension_receiver,
57 mojo::PendingRemote<ClientExtension> client_extension_remote);
58 TizenRendererImpl(const TizenRendererImpl&) = delete;
59 TizenRendererImpl& operator=(const TizenRendererImpl&) = delete;
62 // Renderer implementation.
63 void Initialize(media::MediaResource* media_resource,
64 media::RendererClient* client,
65 media::PipelineStatusCallback init_cb) override;
66 void SetCdm(media::CdmContext* cdm_context,
67 CdmAttachedCB cdm_attached_cb) override;
68 void SetLatencyHint(absl::optional<base::TimeDelta> latency_hint) override;
69 void SetPreservesPitch(bool preserves_pitch) override;
70 void Flush(base::OnceClosure flush_cb) override;
71 void StartPlayingFrom(base::TimeDelta time) override;
72 void SetPlaybackRate(double playback_rate) override;
73 void SetVolume(float volume) override;
74 base::TimeDelta GetMediaTime() override;
75 void OnSelectedVideoTracksChanged(
76 const std::vector<media::DemuxerStream*>& enabled_tracks,
77 base::OnceClosure change_completed_cb) override;
78 void OnEnabledAudioTracksChanged(
79 const std::vector<media::DemuxerStream*>& enabled_tracks,
80 base::OnceClosure change_completed_cb) override;
81 void InitiateScopedSurfaceRequest(
82 InitiateScopedSurfaceRequestCallback callback) override;
83 void OnUpdateAudioMutingState(bool muted) {}
84 void OnWebContentsDestroyed() {}
87 void Seek(base::TimeDelta time);
89 void OnNewFrameAvailable(uint32_t playerId,
90 base::UnsafeSharedMemoryRegion frame,
92 base::TimeDelta timestamp,
97 class RendererClientInternal;
98 const float kDefaultVolume = 1.0;
102 STATE_INIT_PENDING_CDM, // Initialization is waiting for the CDM to be set.
103 STATE_INITIALIZING, // Initializing audio/video renderers.
104 STATE_FLUSHING, // Flushing is in progress.
105 STATE_FLUSHED, // After initialization or after flush completed.
106 STATE_PLAYING, // After StartPlayingFrom has been called.
110 void SetStreamInfo();
111 void SetPlayerVolume() const;
112 void OnRendererEnded();
113 void OnError(media::PipelineStatus error);
114 void OnStatisticsUpdate(const media::PipelineStatistics& stats);
115 void OnBufferingStateChange(media::BufferingState new_buffering_state,
116 media::BufferingStateChangeReason reason);
117 void OnWaiting(media::WaitingReason reason);
118 void OnAudioConfigChange(const media::AudioDecoderConfig& config);
119 void OnVideoConfigChange(const media::VideoDecoderConfig& config);
120 void OnVideoNaturalSizeChange(const gfx::Size& size);
121 void OnVideoOpacityChange(bool opaque);
122 void OnVideoFrameRateChange(absl::optional<int> fps);
124 media::RendererClient* client_;
128 // Task runner used to execute pipeline tasks.
129 scoped_refptr<base::SingleThreadTaskRunner> task_runner_;
131 media::VideoRendererSink* const sink_ = nullptr;
132 mojo::Remote<ClientExtension> client_extension_;
133 // Identifiers to find the RenderFrameHost that created |this|.
134 // NOTE: We store these IDs rather than a RenderFrameHost* because we do not
135 // know when the RenderFrameHost is destroyed.
136 int render_process_id_;
139 // Temporary callback used for Initialize() and Flush().
140 media::PipelineStatusCallback init_cb_;
141 base::OnceClosure flush_cb_;
143 std::unique_ptr<RendererClientInternal> audio_renderer_client_;
144 std::unique_ptr<RendererClientInternal> video_renderer_client_;
146 media::MediaResource* media_resource_;
147 media::DemuxerStream* audio_stream_;
148 media::DemuxerStream* video_stream_;
150 double volume_ = kDefaultVolume;
151 double playback_rate_ = 0.0;
153 // The time to start playback from after starting/seeking has completed.
154 base::TimeDelta start_time_;
156 media::BufferingState audio_buffering_state_;
157 media::BufferingState video_buffering_state_;
159 // Whether we've received the audio/video ended events.
160 bool media_ended_ = false;
161 bool web_contents_muted_ = false;
162 mojo::Receiver<MediaPlayerRendererExtension> renderer_extension_receiver_;
163 raw_ptr<content::MediaPlayerRendererWebContentsObserver>
164 web_contents_observer_;
166 // Indicates if a serious error has been encountered by the |media_player_|.
167 bool has_error_ = false;
169 base::WeakPtrFactory<TizenRendererImpl> weak_factory_{this};
172 } // namespace content
174 #endif // MEDIA_RENDERERS_TIZEN_RENDERER_IMPL_H_