Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(708)

Side by Side Diff: device/vr/vr_device_manager.h

Issue 2488273002: Revert of mojo VR interface simplified (Closed)
Patch Set: Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « device/vr/vr_device.cc ('k') | device/vr/vr_device_manager.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 DEVICE_VR_VR_DEVICE_MANAGER_H 5 #ifndef DEVICE_VR_VR_DEVICE_MANAGER_H
6 #define DEVICE_VR_VR_DEVICE_MANAGER_H 6 #define DEVICE_VR_VR_DEVICE_MANAGER_H
7 7
8 #include <stdint.h> 8 #include <stdint.h>
9 9
10 #include <map> 10 #include <map>
11 #include <memory> 11 #include <memory>
12 #include <vector> 12 #include <vector>
13 13
14 #include "base/macros.h" 14 #include "base/macros.h"
15 #include "base/memory/linked_ptr.h" 15 #include "base/memory/linked_ptr.h"
16 #include "base/threading/thread_checker.h" 16 #include "base/threading/thread_checker.h"
17 #include "base/timer/timer.h" 17 #include "base/timer/timer.h"
18 #include "device/vr/vr_client_dispatcher.h"
18 #include "device/vr/vr_device.h" 19 #include "device/vr/vr_device.h"
19 #include "device/vr/vr_device_provider.h" 20 #include "device/vr/vr_device_provider.h"
20 #include "device/vr/vr_export.h" 21 #include "device/vr/vr_export.h"
21 #include "device/vr/vr_service.mojom.h" 22 #include "device/vr/vr_service.mojom.h"
22 #include "device/vr/vr_service_impl.h" 23 #include "device/vr/vr_service_impl.h"
23 #include "mojo/public/cpp/bindings/binding_set.h" 24 #include "mojo/public/cpp/bindings/binding_set.h"
24 25
25 namespace device { 26 namespace device {
26 27
27 class VRDeviceManager { 28 class VRDeviceManager : public VRClientDispatcher {
28 public: 29 public:
29 DEVICE_VR_EXPORT virtual ~VRDeviceManager(); 30 DEVICE_VR_EXPORT virtual ~VRDeviceManager();
30 31
31 // Returns the VRDeviceManager singleton. 32 // Returns the VRDeviceManager singleton.
32 static VRDeviceManager* GetInstance(); 33 static VRDeviceManager* GetInstance();
33 34
35 // Gets a VRDevice instance if the specified service is allowed to access it.
36 DEVICE_VR_EXPORT static VRDevice* GetAllowedDevice(VRServiceImpl* service,
37 unsigned int index);
38
34 // Adds a listener for device manager events. VRDeviceManager does not own 39 // Adds a listener for device manager events. VRDeviceManager does not own
35 // this object. 40 // this object.
36 void AddService(VRServiceImpl* service); 41 void AddService(VRServiceImpl* service);
37 void RemoveService(VRServiceImpl* service); 42 void RemoveService(VRServiceImpl* service);
38 43
39 DEVICE_VR_EXPORT bool GetVRDevices(VRServiceImpl* service); 44 DEVICE_VR_EXPORT mojo::Array<VRDisplayPtr> GetVRDevices();
40 DEVICE_VR_EXPORT unsigned int GetNumberOfConnectedDevices(); 45
46 // Manage presentation to only allow a single service and device at a time.
47 DEVICE_VR_EXPORT bool RequestPresent(VRServiceImpl* service,
48 unsigned int index,
49 bool secure_origin);
50 DEVICE_VR_EXPORT void ExitPresent(VRServiceImpl* service, unsigned int index);
51 void SubmitFrame(VRServiceImpl* service, unsigned int index, VRPosePtr pose);
52
53 // VRClientDispatcher implementation
54 void OnDeviceChanged(VRDisplayPtr device) override;
55 void OnDeviceConnectionStatusChanged(VRDevice* device,
56 bool is_connected) override;
57 void OnPresentEnded(VRDevice* device) override;
41 58
42 private: 59 private:
43 friend class VRDeviceManagerTest; 60 friend class VRDeviceManagerTest;
44 friend class VRServiceImplTest; 61 friend class VRServiceImplTest;
45 62
46 VRDeviceManager(); 63 VRDeviceManager();
47 // Constructor for testing. 64 // Constructor for testing.
48 DEVICE_VR_EXPORT explicit VRDeviceManager( 65 DEVICE_VR_EXPORT explicit VRDeviceManager(
49 std::unique_ptr<VRDeviceProvider> provider); 66 std::unique_ptr<VRDeviceProvider> provider);
50 67
(...skipping 14 matching lines...) Expand all
65 82
66 // Devices are owned by their providers. 83 // Devices are owned by their providers.
67 using DeviceMap = std::map<unsigned int, VRDevice*>; 84 using DeviceMap = std::map<unsigned int, VRDevice*>;
68 DeviceMap devices_; 85 DeviceMap devices_;
69 86
70 bool vr_initialized_; 87 bool vr_initialized_;
71 88
72 using ServiceList = std::vector<VRServiceImpl*>; 89 using ServiceList = std::vector<VRServiceImpl*>;
73 ServiceList services_; 90 ServiceList services_;
74 91
92 // Only one service and device is allowed to present at a time.
93 VRServiceImpl* presenting_service_;
94 VRDevice* presenting_device_;
95
75 // For testing. If true will not delete self when consumer count reaches 0. 96 // For testing. If true will not delete self when consumer count reaches 0.
76 bool keep_alive_; 97 bool keep_alive_;
77 98
78 bool has_scheduled_poll_; 99 bool has_scheduled_poll_;
79 100
80 base::ThreadChecker thread_checker_; 101 base::ThreadChecker thread_checker_;
81 102
82 base::RepeatingTimer timer_; 103 base::RepeatingTimer timer_;
83 104
84 DISALLOW_COPY_AND_ASSIGN(VRDeviceManager); 105 DISALLOW_COPY_AND_ASSIGN(VRDeviceManager);
85 }; 106 };
86 107
87 } // namespace content 108 } // namespace content
88 109
89 #endif // CONTENT_BROWSER_VR_VR_DEVICE_MANAGER_H 110 #endif // CONTENT_BROWSER_VR_VR_DEVICE_MANAGER_H
OLDNEW
« no previous file with comments | « device/vr/vr_device.cc ('k') | device/vr/vr_device_manager.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698