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 module mojo; | 5 module mojo; |
6 | 6 |
7 import "components/gpu/public/interfaces/context_provider.mojom"; | 7 import "components/gpu/public/interfaces/context_provider.mojom"; |
8 import "ui/mojo/geometry/geometry.mojom"; | 8 import "ui/mojo/geometry/geometry.mojom"; |
9 import "ui/mojo/events/input_events.mojom"; | 9 import "ui/mojo/events/input_events.mojom"; |
10 | 10 |
11 struct ViewportMetrics { | 11 struct ViewportMetrics { |
12 Size size; | 12 Size size; |
13 float device_pixel_ratio = 1.0; | 13 // A value of 0 indicates the real value is not yet available. |
| 14 float device_pixel_ratio = 0.0; |
14 }; | 15 }; |
15 | 16 |
16 interface NativeViewport { | 17 interface NativeViewport { |
17 // TODO(sky): having a create function is awkward. Should there be a factory | 18 // TODO(sky): having a create function is awkward. Should there be a factory |
18 // to create the NativeViewport that takes the size? | 19 // to create the NativeViewport that takes the size? |
19 Create(Size size) => (ViewportMetrics metrics); | 20 Create(Size size) => (ViewportMetrics metrics); |
20 | 21 |
21 Show(); | 22 Show(); |
22 Hide(); | 23 Hide(); |
23 Close(); | 24 Close(); |
24 SetSize(Size size); | 25 SetSize(Size size); |
25 SetEventDispatcher(NativeViewportEventDispatcher dispatcher); | 26 SetEventDispatcher(NativeViewportEventDispatcher dispatcher); |
26 | 27 |
27 // Requests a ContextProvider capable of producing contexts that draw to | 28 // Requests a ContextProvider capable of producing contexts that draw to |
28 // this native viewport. | 29 // this native viewport. |
29 GetContextProvider(ContextProvider& provider); | 30 GetContextProvider(ContextProvider& provider); |
30 | 31 |
31 // The initial viewport metrics will be sent in the reply to the Create | 32 // The initial viewport metrics will be sent in the reply to the Create |
32 // method. Call RequestMetrics() to receive updates when the viewport metrics | 33 // method. Call RequestMetrics() to receive updates when the viewport metrics |
33 // change. The reply will be sent when the viewport metrics are different from | 34 // change. The reply will be sent when the viewport metrics are different from |
34 // the values last sent, so to receive continuous updates call this method | 35 // the values last sent, so to receive continuous updates call this method |
35 // again after receiving the callback. | 36 // again after receiving the callback. |
36 RequestMetrics() => (ViewportMetrics metrics); | 37 RequestMetrics() => (ViewportMetrics metrics); |
37 }; | 38 }; |
38 | 39 |
39 interface NativeViewportEventDispatcher { | 40 interface NativeViewportEventDispatcher { |
40 OnEvent(Event event) => (); | 41 OnEvent(Event event) => (); |
41 }; | 42 }; |
OLD | NEW |