| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 [DartPackage="mojo_services"] | 5 [DartPackage="mojo_services"] |
| 6 module mojo; | 6 module mojo; |
| 7 | 7 |
| 8 import "geometry/public/interfaces/geometry.mojom"; | 8 import "geometry/public/interfaces/geometry.mojom"; |
| 9 import "gpu/public/interfaces/context_provider.mojom"; | 9 import "gpu/public/interfaces/context_provider.mojom"; |
| 10 import "input_events/public/interfaces/input_events.mojom"; | 10 import "input_events/public/interfaces/input_events.mojom"; |
| 11 | 11 |
| 12 struct ViewportMetrics { | 12 struct ViewportMetrics { |
| 13 Size size; | 13 Size size; |
| 14 float device_pixel_ratio = 1.0; | 14 float device_pixel_ratio = 1.0; |
| 15 }; | 15 }; |
| 16 | 16 |
| 17 struct SurfaceConfiguration { | 17 struct SurfaceConfiguration { |
| 18 uint8 red_bits = 8; | 18 uint8 red_bits = 8; |
| 19 uint8 green_bits = 8; | 19 uint8 green_bits = 8; |
| 20 uint8 blue_bits = 8; | 20 uint8 blue_bits = 8; |
| 21 uint8 alpha_bits = 8; | 21 uint8 alpha_bits = 8; |
| 22 uint8 depth_bits; | 22 uint8 depth_bits; |
| 23 uint8 stencil_bits; | 23 uint8 stencil_bits; |
| 24 }; | 24 }; |
| 25 | 25 |
| 26 interface NativeViewport { | 26 interface NativeViewport { |
| 27 // TODO(sky): having a create function is awkward. Should there be a factory | 27 // TODO(sky): having a create function is awkward. Should there be a factory |
| 28 // to create the NativeViewport that takes the size? | 28 // to create the NativeViewport that takes the size? |
| 29 // When the viewport is created it is initially shown. |
| 29 Create(Size size, SurfaceConfiguration? requested_configuration) => (ViewportM
etrics metrics); | 30 Create(Size size, SurfaceConfiguration? requested_configuration) => (ViewportM
etrics metrics); |
| 30 | 31 |
| 31 Show(); | 32 Show(); |
| 32 Hide(); | 33 Hide(); |
| 33 Close(); | 34 Close(); |
| 34 SetSize(Size size); | 35 SetSize(Size size); |
| 35 SetEventDispatcher(NativeViewportEventDispatcher dispatcher); | 36 SetEventDispatcher(NativeViewportEventDispatcher dispatcher); |
| 36 | 37 |
| 37 // Requests a ContextProvider capable of producing contexts that draw to | 38 // Requests a ContextProvider capable of producing contexts that draw to |
| 38 // this native viewport. | 39 // this native viewport. |
| 39 GetContextProvider(ContextProvider& provider); | 40 GetContextProvider(ContextProvider& provider); |
| 40 | 41 |
| 41 // The initial viewport metrics will be sent in the reply to the Create | 42 // The initial viewport metrics will be sent in the reply to the Create |
| 42 // method. Call RequestMetrics() to receive updates when the viewport metrics | 43 // method. Call RequestMetrics() to receive updates when the viewport metrics |
| 43 // change. The reply will be sent when the viewport metrics are different from | 44 // change. The reply will be sent when the viewport metrics are different from |
| 44 // the values last sent, so to receive continuous updates call this method | 45 // the values last sent, so to receive continuous updates call this method |
| 45 // again after receiving the callback. | 46 // again after receiving the callback. |
| 46 RequestMetrics() => (ViewportMetrics metrics); | 47 RequestMetrics() => (ViewportMetrics metrics); |
| 47 }; | 48 }; |
| 48 | 49 |
| 49 interface NativeViewportEventDispatcher { | 50 interface NativeViewportEventDispatcher { |
| 50 OnEvent(Event event) => (); | 51 OnEvent(Event event) => (); |
| 51 }; | 52 }; |
| OLD | NEW |