Supervised user whitelists: Cleanup
[chromium-blink-merge.git] / content / common / media / media_player_messages_android.h
blob8cdf70305322684fbcfa0bbb4fc6424ea138dad8
1 // Copyright (c) 2012 The Chromium Authors. 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 // IPC messages for android media player.
6 // Multiply-included message file, hence no include guard.
8 #include "base/basictypes.h"
9 #include "base/time/time.h"
10 #include "content/common/content_export.h"
11 #include "content/common/media/media_player_messages_enums_android.h"
12 #include "ipc/ipc_message_macros.h"
13 #include "media/base/android/demuxer_stream_player_params.h"
14 #include "media/base/android/media_player_android.h"
15 #include "ui/gfx/geometry/rect_f.h"
16 #include "url/gurl.h"
18 #undef IPC_MESSAGE_EXPORT
19 #define IPC_MESSAGE_EXPORT CONTENT_EXPORT
20 #define IPC_MESSAGE_START MediaPlayerMsgStart
22 IPC_ENUM_TRAITS(media::AudioCodec)
23 IPC_ENUM_TRAITS(media::DemuxerStream::Status)
24 IPC_ENUM_TRAITS(media::DemuxerStream::Type)
25 IPC_ENUM_TRAITS(media::VideoCodec)
27 IPC_STRUCT_TRAITS_BEGIN(media::DemuxerConfigs)
28 IPC_STRUCT_TRAITS_MEMBER(audio_codec)
29 IPC_STRUCT_TRAITS_MEMBER(audio_channels)
30 IPC_STRUCT_TRAITS_MEMBER(audio_sampling_rate)
31 IPC_STRUCT_TRAITS_MEMBER(is_audio_encrypted)
32 IPC_STRUCT_TRAITS_MEMBER(audio_extra_data)
33 IPC_STRUCT_TRAITS_MEMBER(audio_codec_delay_ns)
34 IPC_STRUCT_TRAITS_MEMBER(audio_seek_preroll_ns)
36 IPC_STRUCT_TRAITS_MEMBER(video_codec)
37 IPC_STRUCT_TRAITS_MEMBER(video_size)
38 IPC_STRUCT_TRAITS_MEMBER(is_video_encrypted)
39 IPC_STRUCT_TRAITS_MEMBER(video_extra_data)
41 IPC_STRUCT_TRAITS_MEMBER(duration)
42 IPC_STRUCT_TRAITS_END()
44 IPC_STRUCT_TRAITS_BEGIN(media::DemuxerData)
45 IPC_STRUCT_TRAITS_MEMBER(type)
46 IPC_STRUCT_TRAITS_MEMBER(access_units)
47 IPC_STRUCT_TRAITS_MEMBER(demuxer_configs)
48 IPC_STRUCT_TRAITS_END()
50 IPC_STRUCT_TRAITS_BEGIN(media::AccessUnit)
51 IPC_STRUCT_TRAITS_MEMBER(status)
52 IPC_STRUCT_TRAITS_MEMBER(is_end_of_stream)
53 IPC_STRUCT_TRAITS_MEMBER(data)
54 IPC_STRUCT_TRAITS_MEMBER(timestamp)
55 IPC_STRUCT_TRAITS_MEMBER(key_id)
56 IPC_STRUCT_TRAITS_MEMBER(iv)
57 IPC_STRUCT_TRAITS_MEMBER(subsamples)
58 IPC_STRUCT_TRAITS_MEMBER(is_key_frame)
59 IPC_STRUCT_TRAITS_END()
61 IPC_STRUCT_TRAITS_BEGIN(media::SubsampleEntry)
62 IPC_STRUCT_TRAITS_MEMBER(clear_bytes)
63 IPC_STRUCT_TRAITS_MEMBER(cypher_bytes)
64 IPC_STRUCT_TRAITS_END()
66 IPC_ENUM_TRAITS_MAX_VALUE(MediaPlayerHostMsg_Initialize_Type,
67 MEDIA_PLAYER_TYPE_LAST)
69 // Parameters to describe a media player
70 IPC_STRUCT_BEGIN(MediaPlayerHostMsg_Initialize_Params)
71 IPC_STRUCT_MEMBER(MediaPlayerHostMsg_Initialize_Type, type)
72 IPC_STRUCT_MEMBER(base::SharedMemoryHandle, metafile_data_handle)
73 IPC_STRUCT_MEMBER(int, player_id)
74 IPC_STRUCT_MEMBER(int, demuxer_client_id)
75 IPC_STRUCT_MEMBER(GURL, url)
76 IPC_STRUCT_MEMBER(GURL, first_party_for_cookies)
77 IPC_STRUCT_MEMBER(GURL, frame_url)
78 IPC_STRUCT_MEMBER(bool, allow_credentials)
79 IPC_STRUCT_END()
81 // Chrome for Android seek message sequence is:
82 // 1. Renderer->Browser MediaPlayerHostMsg_Seek
83 // This is the beginning of actual seek flow in response to web app requests
84 // for seeks and browser MediaPlayerMsg_SeekRequests. With this message,
85 // the renderer asks browser to perform actual seek. At most one of these
86 // actual seeks will be in process between this message and renderer's later
87 // receipt of MediaPlayerMsg_SeekCompleted from the browser.
88 // 2. Browser->Renderer MediaPlayerMsg_SeekCompleted
89 // Once the browser determines the seek is complete, it sends this message to
90 // notify the renderer of seek completion.
92 // Other seek-related IPC messages:
93 // Browser->Renderer MediaPlayerMsg_SeekRequest
94 // Browser requests to begin a seek. All browser-initiated seeks must begin
95 // with this request. Renderer controls actual seek initiation via the normal
96 // seek flow, above, keeping web apps aware of seeks. These requests are
97 // also allowed while another actual seek is in progress.
99 // If the demuxer is located in the renderer, as in media source players, the
100 // browser must ensure the renderer demuxer is appropriately seeked between
101 // receipt of MediaPlayerHostMsg_Seek and transmission of
102 // MediaPlayerMsg_SeekCompleted. The following two renderer-demuxer control
103 // messages book-end the renderer-demuxer seek:
104 // 1.1 Browser->Renderer MediaPlayerMsg_DemuxerSeekRequest
105 // 1.2 Renderer->Browser MediaPlayerHostMsg_DemuxerSeekDone
107 // Only in short-term hack to seek to reach I-Frame to feed a newly constructed
108 // video decoder may the above IPC sequence be modified to exclude SeekRequest,
109 // Seek and SeekCompleted, with condition that DemuxerSeekRequest's
110 // |is_browser_seek| parameter be true. Regular seek messages must still be
111 // handled even when a hack browser seek is in progress. In this case, the
112 // browser seek request's |time_to_seek| may no longer be buffered and the
113 // demuxer may instead seek to a future buffered time. The resulting
114 // DemuxerSeekDone message's |actual_browser_seek_time| is the time actually
115 // seeked-to, and is only meaningful for these hack browser seeks.
116 // TODO(wolenetz): Instead of doing browser seek, replay cached data since last
117 // keyframe. See http://crbug.com/304234.
119 // Messages for notifying the render process of media playback status -------
121 // Media buffering has updated.
122 IPC_MESSAGE_ROUTED2(MediaPlayerMsg_MediaBufferingUpdate,
123 int /* player_id */,
124 int /* percent */)
126 // A media playback error has occurred.
127 IPC_MESSAGE_ROUTED2(MediaPlayerMsg_MediaError,
128 int /* player_id */,
129 int /* error */)
131 // Playback is completed.
132 IPC_MESSAGE_ROUTED1(MediaPlayerMsg_MediaPlaybackCompleted,
133 int /* player_id */)
135 // Media metadata has changed.
136 IPC_MESSAGE_ROUTED5(MediaPlayerMsg_MediaMetadataChanged,
137 int /* player_id */,
138 base::TimeDelta /* duration */,
139 int /* width */,
140 int /* height */,
141 bool /* success */)
143 // Requests renderer player to ask its client (blink HTMLMediaElement) to seek.
144 IPC_MESSAGE_ROUTED2(MediaPlayerMsg_SeekRequest,
145 int /* player_id */,
146 base::TimeDelta /* time_to_seek_to */)
148 // Media seek is completed.
149 IPC_MESSAGE_ROUTED2(MediaPlayerMsg_SeekCompleted,
150 int /* player_id */,
151 base::TimeDelta /* current_time */)
153 // Video size has changed.
154 IPC_MESSAGE_ROUTED3(MediaPlayerMsg_MediaVideoSizeChanged,
155 int /* player_id */,
156 int /* width */,
157 int /* height */)
159 // The current play time has updated.
160 IPC_MESSAGE_ROUTED3(MediaPlayerMsg_MediaTimeUpdate,
161 int /* player_id */,
162 base::TimeDelta /* current_timestamp */,
163 base::TimeTicks /* current_time_ticks */)
165 // A new key is required in order to continue decrypting encrypted content.
166 IPC_MESSAGE_ROUTED1(MediaPlayerMsg_WaitingForDecryptionKey, int /* player_id */)
168 // The player has been released.
169 IPC_MESSAGE_ROUTED1(MediaPlayerMsg_MediaPlayerReleased,
170 int /* player_id */)
172 // The player exited fullscreen.
173 IPC_MESSAGE_ROUTED1(MediaPlayerMsg_DidExitFullscreen,
174 int /* player_id */)
176 // The player started playing.
177 IPC_MESSAGE_ROUTED1(MediaPlayerMsg_DidMediaPlayerPlay,
178 int /* player_id */)
180 // The player was paused.
181 IPC_MESSAGE_ROUTED1(MediaPlayerMsg_DidMediaPlayerPause,
182 int /* player_id */)
184 // Requests renderer demuxer seek.
185 IPC_MESSAGE_CONTROL3(MediaPlayerMsg_DemuxerSeekRequest,
186 int /* demuxer_client_id */,
187 base::TimeDelta /* time_to_seek */,
188 bool /* is_browser_seek */)
190 // The media source player reads data from demuxer
191 IPC_MESSAGE_CONTROL2(MediaPlayerMsg_ReadFromDemuxer,
192 int /* demuxer_client_id */,
193 media::DemuxerStream::Type /* type */)
195 // Clank has connected to the remote device.
196 IPC_MESSAGE_ROUTED2(MediaPlayerMsg_ConnectedToRemoteDevice,
197 int /* player_id */,
198 std::string /* remote_playback_message */)
200 // Clank has disconnected from the remote device.
201 IPC_MESSAGE_ROUTED1(MediaPlayerMsg_DisconnectedFromRemoteDevice,
202 int /* player_id */)
204 // The availability of remote devices has changed
205 IPC_MESSAGE_ROUTED2(MediaPlayerMsg_RemoteRouteAvailabilityChanged,
206 int /* player_id */,
207 bool /* routes_available */)
209 // Instructs the video element to enter fullscreen.
210 IPC_MESSAGE_ROUTED1(MediaPlayerMsg_RequestFullscreen,
211 int /*player_id */)
213 // Messages for controlling the media playback in browser process ----------
215 // Destroy the media player object.
216 IPC_MESSAGE_ROUTED1(MediaPlayerHostMsg_DestroyMediaPlayer,
217 int /* player_id */)
219 // Initialize a media player object.
220 IPC_MESSAGE_ROUTED1(
221 MediaPlayerHostMsg_Initialize,
222 MediaPlayerHostMsg_Initialize_Params);
224 // Pause the player.
225 IPC_MESSAGE_ROUTED2(MediaPlayerHostMsg_Pause,
226 int /* player_id */,
227 bool /* is_media_related_action */)
229 // Release player resources, but keep the object for future usage.
230 IPC_MESSAGE_ROUTED1(MediaPlayerHostMsg_Release, int /* player_id */)
232 // Perform a seek.
233 IPC_MESSAGE_ROUTED2(MediaPlayerHostMsg_Seek,
234 int /* player_id */,
235 base::TimeDelta /* time */)
237 // Start the player for playback.
238 IPC_MESSAGE_ROUTED1(MediaPlayerHostMsg_Start, int /* player_id */)
240 // Set the volume.
241 IPC_MESSAGE_ROUTED2(MediaPlayerHostMsg_SetVolume,
242 int /* player_id */,
243 double /* volume */)
245 // Set the poster image.
246 IPC_MESSAGE_ROUTED2(MediaPlayerHostMsg_SetPoster,
247 int /* player_id */,
248 GURL /* poster url */)
250 // Requests the player to enter fullscreen.
251 IPC_MESSAGE_ROUTED1(MediaPlayerHostMsg_EnterFullscreen, int /* player_id */)
253 // Requests the player to exit fullscreen.
254 IPC_MESSAGE_ROUTED1(MediaPlayerHostMsg_ExitFullscreen, int /* player_id */)
256 // Play the media on a remote device, if possible.
257 IPC_MESSAGE_ROUTED1(MediaPlayerHostMsg_RequestRemotePlayback,
258 int /* demuxer_client_id */)
260 // Control media playing on a remote device.
261 IPC_MESSAGE_ROUTED1(MediaPlayerHostMsg_RequestRemotePlaybackControl,
262 int /* demuxer_client_id */)
264 // Requests the player with |player_id| to use the CDM with |cdm_id|.
265 IPC_MESSAGE_ROUTED2(MediaPlayerHostMsg_SetCdm,
266 int /* player_id */,
267 int /* cdm_id */);
269 // Sent after the renderer demuxer has seeked.
270 IPC_MESSAGE_CONTROL2(MediaPlayerHostMsg_DemuxerSeekDone,
271 int /* demuxer_client_id */,
272 base::TimeDelta /* actual_browser_seek_time */)
274 // Inform the media source player that the demuxer is ready.
275 IPC_MESSAGE_CONTROL2(MediaPlayerHostMsg_DemuxerReady,
276 int /* demuxer_client_id */,
277 media::DemuxerConfigs)
279 // Sent when the data was read from the ChunkDemuxer.
280 IPC_MESSAGE_CONTROL2(MediaPlayerHostMsg_ReadFromDemuxerAck,
281 int /* demuxer_client_id */,
282 media::DemuxerData)
284 // Inform the media source player of changed media duration from demuxer.
285 IPC_MESSAGE_CONTROL2(MediaPlayerHostMsg_DurationChanged,
286 int /* demuxer_client_id */,
287 base::TimeDelta /* duration */)
289 #if defined(VIDEO_HOLE)
290 // Notify the player about the external surface, requesting it if necessary.
291 // |is_request| true if the player is requesting the external surface.
292 // |rect| the boundary rectangle of the video element.
293 IPC_MESSAGE_ROUTED3(MediaPlayerHostMsg_NotifyExternalSurface,
294 int /* player_id */,
295 bool /* is_request */,
296 gfx::RectF /* rect */)
297 #endif // defined(VIDEO_HOLE)