Index: media/mojo/interfaces/media_renderer.mojom |
diff --git a/media/mojo/interfaces/media_renderer.mojom b/media/mojo/interfaces/media_renderer.mojom |
new file mode 100644 |
index 0000000000000000000000000000000000000000..91cbc441b9b55c1334ba91004e566496cbb4a73f |
--- /dev/null |
+++ b/media/mojo/interfaces/media_renderer.mojom |
@@ -0,0 +1,53 @@ |
+// 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. |
+ |
+import "media/mojo/interfaces/media_types.mojom" |
+ |
+module mojo { |
+ |
+[Client=MediaRendererClient] |
+interface MediaRenderer { |
+ // Initializes the Renderer, calling back with status upon completion. |
+ Initialize() => (bool succeeded); |
+ |
+ // Decodes and renders|buffer|, calling back when more data is required. |
xhwang
2014/09/03 16:09:38
add space after "renders"
tim (not reviewing)
2014/09/03 16:39:46
Done.
|
+ // NOTE: If an error occurs, MediaRendererClient::OnError will be called |
xhwang
2014/09/03 16:09:38
s/OnError/OnError()/
tim (not reviewing)
2014/09/03 16:39:46
Done.
|
+ // before the callback is executed. |
+ // TODO(tim): Switch decoding model to use framed data pipe when available. |
+ // In that world, the signalling for more would be implicit by a writable |
+ // pipe handle on the client side so this entire method + callback goes away. |
+ DecodeAndRender(MediaDecoderBuffer buffer) => (); |
+ |
+ // Discards any buffered data, executing callback when completed. |
+ // NOTE: If an error occurs, MediaRendererClient::OnError can be called |
xhwang
2014/09/03 16:09:38
ditto
tim (not reviewing)
2014/09/03 16:39:46
Done.
|
+ // before the callback is executed. |
+ Flush() => (); |
+ |
+ // Starts rendering from |time_usec|. |
+ StartPlayingFrom(int64 time_usec); |
+ |
+ // Updates the current playback rate. The default playback rate should be 1. |
+ SetPlaybackRate(float playback_rate); |
+ |
+ // Sets the output volume. The default volume should be 1. |
+ SetVolume(float volume); |
+}; |
+ |
+interface MediaRendererClient { |
+ // Called to report media time advance of |time_usec|. |
+ OnTimeUpdate(int64 time_delta_usec); |
xhwang
2014/09/03 16:09:38
s/time_delta_usec/time_usec/
tim (not reviewing)
2014/09/03 16:39:46
Done.
|
+ |
+ // Called to report buffering state changes, see media_types.mojom. |
+ OnBufferingStateChange(BufferingState state); |
+ |
+ // Executed when rendering has reached the end of stream. |
+ OnEnded(); |
+ |
+ // Executed if any error was encountered during decode or rendering. If |
+ // this error happens during an operation that has a completion callback, |
+ // OnError() will be called before firing the completion callback. |
+ OnError(); |
+}; |
+ |
+} // module mojo |