OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 #ifndef SERVICES_UI_DISPLAY_PLATFORM_SCREEN_H_ | 5 #ifndef SERVICES_UI_DISPLAY_PLATFORM_SCREEN_H_ |
6 #define SERVICES_UI_DISPLAY_PLATFORM_SCREEN_H_ | 6 #define SERVICES_UI_DISPLAY_PLATFORM_SCREEN_H_ |
7 | 7 |
8 #include <memory> | 8 #include <memory> |
9 | 9 |
10 #include "base/macros.h" | 10 #include "base/macros.h" |
11 #include "services/ui/display/platform_screen_delegate.h" | 11 #include "services/ui/display/platform_screen_delegate.h" |
12 | 12 |
13 namespace shell { | 13 namespace service_manager { |
14 class InterfaceRegistry; | 14 class InterfaceRegistry; |
15 } | 15 } |
16 | 16 |
17 namespace display { | 17 namespace display { |
18 | 18 |
19 // PlatformScreen provides the necessary functionality to configure all | 19 // PlatformScreen provides the necessary functionality to configure all |
20 // attached physical displays. | 20 // attached physical displays. |
21 class PlatformScreen { | 21 class PlatformScreen { |
22 public: | 22 public: |
23 PlatformScreen(); | 23 PlatformScreen(); |
24 virtual ~PlatformScreen(); | 24 virtual ~PlatformScreen(); |
25 | 25 |
26 // Creates a singleton PlatformScreen instance. | 26 // Creates a singleton PlatformScreen instance. |
27 static std::unique_ptr<PlatformScreen> Create(); | 27 static std::unique_ptr<PlatformScreen> Create(); |
28 static PlatformScreen* GetInstance(); | 28 static PlatformScreen* GetInstance(); |
29 | 29 |
30 // Registers Mojo interfaces provided. | 30 // Registers Mojo interfaces provided. |
31 virtual void AddInterfaces(shell::InterfaceRegistry* registry) = 0; | 31 virtual void AddInterfaces(service_manager::InterfaceRegistry* registry) = 0; |
32 | 32 |
33 // Triggers initial display configuration to start. On device this will | 33 // Triggers initial display configuration to start. On device this will |
34 // configuration the connected displays. Off device this will create one or | 34 // configuration the connected displays. Off device this will create one or |
35 // more fake displays and pretend to configure them. A non-null |delegate| | 35 // more fake displays and pretend to configure them. A non-null |delegate| |
36 // must be provided that will receive notifications when displays are added, | 36 // must be provided that will receive notifications when displays are added, |
37 // removed or modified. | 37 // removed or modified. |
38 virtual void Init(PlatformScreenDelegate* delegate) = 0; | 38 virtual void Init(PlatformScreenDelegate* delegate) = 0; |
39 | 39 |
40 // Handle requests from the platform to close a display. | 40 // Handle requests from the platform to close a display. |
41 virtual void RequestCloseDisplay(int64_t display_id) = 0; | 41 virtual void RequestCloseDisplay(int64_t display_id) = 0; |
42 | 42 |
43 virtual int64_t GetPrimaryDisplayId() const = 0; | 43 virtual int64_t GetPrimaryDisplayId() const = 0; |
44 | 44 |
45 private: | 45 private: |
46 static PlatformScreen* instance_; // Instance is not owned. | 46 static PlatformScreen* instance_; // Instance is not owned. |
47 | 47 |
48 DISALLOW_COPY_AND_ASSIGN(PlatformScreen); | 48 DISALLOW_COPY_AND_ASSIGN(PlatformScreen); |
49 }; | 49 }; |
50 | 50 |
51 } // namespace display | 51 } // namespace display |
52 | 52 |
53 #endif // SERVICES_UI_DISPLAY_PLATFORM_SCREEN_H_ | 53 #endif // SERVICES_UI_DISPLAY_PLATFORM_SCREEN_H_ |
OLD | NEW |