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

Side by Side Diff: mojo/services/window_manager/window_manager_app.h

Issue 396563002: Window Manager service.. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 6 years, 5 months 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 | Annotate | Revision Log
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #ifndef MOJO_SERVICES_WINDOW_MANAGER_WINDOW_MANAGER_APP_H_
6 #define MOJO_SERVICES_WINDOW_MANAGER_WINDOW_MANAGER_APP_H_
7
8 #include <set>
9
10 #include "base/memory/scoped_ptr.h"
11 #include "mojo/aura/window_tree_host_mojo_delegate.h"
12 #include "mojo/public/cpp/application/application_delegate.h"
13 #include "mojo/services/public/cpp/view_manager/types.h"
14 #include "mojo/services/public/cpp/view_manager/view_manager_delegate.h"
15
16 namespace aura {
17 class Window;
18 }
19
20 namespace wm {
21 class ScopedCaptureClient;
22 }
23
24 namespace mojo {
25
26 class AuraInit;
27 class WindowManagerServiceImpl;
28 class WindowTreeHostMojo;
29
30 class WindowManagerApp : public ApplicationDelegate,
31 public view_manager::ViewManagerDelegate,
32 public WindowTreeHostMojoDelegate {
33 public:
34 WindowManagerApp();
35 virtual ~WindowManagerApp();
36
37 void AddConnection(WindowManagerServiceImpl* connection);
38 void RemoveConnection(WindowManagerServiceImpl* connection);
39
40 view_manager::Id OpenWindow();
41 void SetCapture(view_manager::Id node);
42
43 bool IsReady() const;
44
45 private:
46 typedef std::set<WindowManagerServiceImpl*> Connections;
47
48 // Overridden from ApplicationDelegate:
49 virtual void Initialize(ApplicationImpl* impl) MOJO_OVERRIDE;
50 virtual bool ConfigureIncomingConnection(ApplicationConnection* connection)
51 MOJO_OVERRIDE;
52
53 // Overridden from view_manager::ViewManagerDelegate:
54 virtual void OnRootAdded(view_manager::ViewManager* view_manager,
55 view_manager::Node* root) MOJO_OVERRIDE;
56 virtual void OnViewManagerDisconnected(
57 view_manager::ViewManager* view_manager) MOJO_OVERRIDE;
58
59 // Overridden from WindowTreeHostMojoDelegate:
60 virtual void CompositorContentsChanged(const SkBitmap& bitmap) MOJO_OVERRIDE;
61
62 aura::Window* GetWindowForNodeId(view_manager::Id node) const;
63
64 view_manager::ViewManager* view_manager_;
65 view_manager::Node* root_;
66
67 scoped_ptr<AuraInit> aura_init_;
68 scoped_ptr<WindowTreeHostMojo> window_tree_host_;
69
70 scoped_ptr<wm::ScopedCaptureClient> capture_client_;
71
72 Connections connections_;
73
74 DISALLOW_COPY_AND_ASSIGN(WindowManagerApp);
75 };
76
77 } // namespace mojo
78
79 #endif // MOJO_SERVICES_WINDOW_MANAGER_WINDOW_MANAGER_APP_H_
OLDNEW
« no previous file with comments | « mojo/services/window_manager/window_manager_api_unittest.cc ('k') | mojo/services/window_manager/window_manager_app.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698