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

Side by Side Diff: examples/wm_flow/app/app.cc

Issue 817573003: Move wm_flow off of views and onto Sky (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Fix comments Created 5 years, 11 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
OLDNEW
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 #include <map> 5 #include <map>
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/macros.h" 8 #include "base/macros.h"
9 #include "base/stl_util.h" 9 #include "base/stl_util.h"
10 #include "examples/bitmap_uploader/bitmap_uploader.h" 10 #include "examples/bitmap_uploader/bitmap_uploader.h"
11 #include "examples/wm_flow/app/embedder.mojom.h" 11 #include "examples/wm_flow/app/embedder.mojom.h"
12 #include "examples/wm_flow/embedded/embeddee.mojom.h" 12 #include "examples/wm_flow/embedded/embeddee.mojom.h"
13 #include "mojo/application/application_runner_chromium.h" 13 #include "mojo/application/application_runner_chromium.h"
14 #include "mojo/public/c/system/main.h" 14 #include "mojo/public/c/system/main.h"
15 #include "mojo/public/cpp/application/application_connection.h" 15 #include "mojo/public/cpp/application/application_connection.h"
16 #include "mojo/public/cpp/application/application_delegate.h" 16 #include "mojo/public/cpp/application/application_delegate.h"
17 #include "mojo/public/cpp/application/application_impl.h" 17 #include "mojo/public/cpp/application/application_impl.h"
18 #include "mojo/public/cpp/application/connect.h" 18 #include "mojo/public/cpp/application/connect.h"
19 #include "mojo/public/cpp/application/interface_factory_impl.h" 19 #include "mojo/public/cpp/application/interface_factory_impl.h"
20 #include "mojo/public/cpp/application/service_provider_impl.h" 20 #include "mojo/public/cpp/application/service_provider_impl.h"
21 #include "mojo/public/interfaces/application/service_provider.mojom.h" 21 #include "mojo/public/interfaces/application/service_provider.mojom.h"
22 #include "mojo/services/view_manager/public/cpp/view.h" 22 #include "mojo/services/view_manager/public/cpp/view.h"
23 #include "mojo/services/view_manager/public/cpp/view_manager.h" 23 #include "mojo/services/view_manager/public/cpp/view_manager.h"
24 #include "mojo/services/view_manager/public/cpp/view_manager_client_factory.h" 24 #include "mojo/services/view_manager/public/cpp/view_manager_client_factory.h"
25 #include "mojo/services/view_manager/public/cpp/view_manager_context.h" 25 #include "mojo/services/view_manager/public/cpp/view_manager_context.h"
26 #include "mojo/services/view_manager/public/cpp/view_manager_delegate.h" 26 #include "mojo/services/view_manager/public/cpp/view_manager_delegate.h"
27 #include "mojo/services/view_manager/public/cpp/view_observer.h" 27 #include "mojo/services/view_manager/public/cpp/view_observer.h"
28 #include "third_party/skia/include/core/SkColor.h" 28 #include "third_party/skia/include/core/SkColor.h"
29 #include "url/gurl.h"
29 30
30 namespace examples { 31 namespace examples {
31 namespace { 32 namespace {
32 33
33 const SkColor kColors[] = { SK_ColorRED, SK_ColorGREEN, SK_ColorYELLOW }; 34 const SkColor kColors[] = { SK_ColorRED, SK_ColorGREEN, SK_ColorYELLOW };
34 35
35 class EmbedderImpl : public mojo::InterfaceImpl<Embedder> { 36 class EmbedderImpl : public mojo::InterfaceImpl<Embedder> {
36 public: 37 public:
37 EmbedderImpl() {} 38 EmbedderImpl() {}
38 virtual ~EmbedderImpl() {} 39 virtual ~EmbedderImpl() {}
(...skipping 22 matching lines...) Expand all
61 62
62 private: 63 private:
63 typedef std::map<mojo::View*, mojo::BitmapUploader*> ViewToUploader; 64 typedef std::map<mojo::View*, mojo::BitmapUploader*> ViewToUploader;
64 65
65 // Overridden from Application: 66 // Overridden from Application:
66 virtual void Initialize(mojo::ApplicationImpl* app) override { 67 virtual void Initialize(mojo::ApplicationImpl* app) override {
67 shell_ = app->shell(); 68 shell_ = app->shell();
68 view_manager_client_factory_.reset( 69 view_manager_client_factory_.reset(
69 new mojo::ViewManagerClientFactory(app->shell(), this)); 70 new mojo::ViewManagerClientFactory(app->shell(), this));
70 view_manager_context_.reset(new mojo::ViewManagerContext(app)); 71 view_manager_context_.reset(new mojo::ViewManagerContext(app));
72 // FIXME: Mojo applications don't know their URLs yet:
73 // https://docs.google.com/a/chromium.org/document/d/1AQ2y6ekzvbdaMF5WrUQmne yXJnke-MnYYL4Gz1AKDos
74 url_ = GURL(app->args()[1]);
71 OpenNewWindow(); 75 OpenNewWindow();
72 OpenNewWindow(); 76 OpenNewWindow();
73 OpenNewWindow(); 77 OpenNewWindow();
74 } 78 }
75 virtual bool ConfigureIncomingConnection( 79 virtual bool ConfigureIncomingConnection(
76 mojo::ApplicationConnection* connection) override { 80 mojo::ApplicationConnection* connection) override {
77 connection->AddService(view_manager_client_factory_.get()); 81 connection->AddService(view_manager_client_factory_.get());
78 return true; 82 return true;
79 } 83 }
80 84
81 void OnConnect(bool success) {} 85 void OnConnect(bool success) {}
82 86
83 // Overridden from mojo::ViewManagerDelegate: 87 // Overridden from mojo::ViewManagerDelegate:
84 virtual void OnEmbed( 88 virtual void OnEmbed(
85 mojo::View* root, 89 mojo::View* root,
86 mojo::ServiceProviderImpl* exported_services, 90 mojo::ServiceProviderImpl* exported_services,
87 scoped_ptr<mojo::ServiceProvider> imported_services) override { 91 scoped_ptr<mojo::ServiceProvider> imported_services) override {
88 root->AddObserver(this); 92 root->AddObserver(this);
89 mojo::BitmapUploader* uploader = new mojo::BitmapUploader(root); 93 mojo::BitmapUploader* uploader = new mojo::BitmapUploader(root);
90 uploaders_[root] = uploader; 94 uploaders_[root] = uploader;
91 uploader->Init(shell_); 95 uploader->Init(shell_);
96 // BitmapUploader does not track view size changes, we would
97 // need to subscribe to OnViewBoundsChanged and tell the bitmap uploader
98 // to invalidate itself. This is better done once if had a per-view
99 // object instead of holding per-view state on the ApplicationDelegate.
92 uploader->SetColor(kColors[embed_count_++ % arraysize(kColors)]); 100 uploader->SetColor(kColors[embed_count_++ % arraysize(kColors)]);
93 101
94 mojo::View* embed = root->view_manager()->CreateView(); 102 mojo::View* embed = root->view_manager()->CreateView();
95 root->AddChild(embed); 103 root->AddChild(embed);
96 mojo::Rect bounds; 104 mojo::Rect bounds;
97 bounds.x = bounds.y = 25; 105 bounds.x = bounds.y = 25;
98 bounds.width = root->bounds().width - 50; 106 bounds.width = root->bounds().width - 50;
99 bounds.height = root->bounds().height - 50; 107 bounds.height = root->bounds().height - 50;
100 embed->SetBounds(bounds); 108 embed->SetBounds(bounds);
101 embed->SetVisible(true); 109 embed->SetVisible(true);
102 110
103 scoped_ptr<mojo::ServiceProviderImpl> registry( 111 scoped_ptr<mojo::ServiceProviderImpl> registry(
104 new mojo::ServiceProviderImpl); 112 new mojo::ServiceProviderImpl);
105 // Expose some services to the embeddee... 113 // Expose some services to the embeddee...
106 registry->AddService(&embedder_factory_); 114 registry->AddService(&embedder_factory_);
115
116 GURL embedded_app_url = url_.Resolve("wm_flow_embedded.mojo");
107 scoped_ptr<mojo::ServiceProvider> imported = 117 scoped_ptr<mojo::ServiceProvider> imported =
108 embed->Embed("mojo:wm_flow_embedded", registry.Pass()); 118 embed->Embed(embedded_app_url.spec(), registry.Pass());
119 // FIXME: This is wrong. We're storing per-view state on this per-app
120 // delegate. Every time a new view is created embedee_ is replaced
121 // causing the previous one to shut down. This class should not
122 // be a ViewManagerDelegate, but rather a separate object should be
123 // created for each embedding.
109 mojo::ConnectToService(imported.get(), &embeddee_); 124 mojo::ConnectToService(imported.get(), &embeddee_);
110 embeddee_->HelloBack(base::Bind(&WMFlowApp::HelloBackAck, 125 embeddee_->HelloBack(base::Bind(&WMFlowApp::HelloBackAck,
111 base::Unretained(this))); 126 base::Unretained(this)));
112 } 127 }
113 virtual void OnViewManagerDisconnected( 128 virtual void OnViewManagerDisconnected(
114 mojo::ViewManager* view_manager) override { 129 mojo::ViewManager* view_manager) override {
115 STLDeleteValues(&uploaders_); 130 STLDeleteValues(&uploaders_);
116 } 131 }
117 132
118 // Overridden from mojo::ViewObserver: 133 // Overridden from mojo::ViewObserver:
(...skipping 10 matching lines...) Expand all
129 uploaders_.erase(view); 144 uploaders_.erase(view);
130 } 145 }
131 --embed_count_; 146 --embed_count_;
132 view->RemoveObserver(this); 147 view->RemoveObserver(this);
133 } 148 }
134 149
135 void HelloBackAck() { 150 void HelloBackAck() {
136 printf("HelloBack() ack'ed\n"); 151 printf("HelloBack() ack'ed\n");
137 } 152 }
138 153
139 void OpenNewWindow() { view_manager_context_->Embed("mojo:wm_flow_app"); } 154 void OpenNewWindow() { view_manager_context_->Embed(url_.spec()); }
sky 2015/01/06 21:26:55 Why do you need to change this and 108?
eseidel 2015/01/06 21:48:18 Sky has multi-file dependencies. When you load "w
140 155
141 mojo::Shell* shell_; 156 mojo::Shell* shell_;
142 int embed_count_; 157 int embed_count_;
143 scoped_ptr<mojo::ViewManagerClientFactory> view_manager_client_factory_; 158 scoped_ptr<mojo::ViewManagerClientFactory> view_manager_client_factory_;
144 mojo::InterfaceFactoryImpl<EmbedderImpl> embedder_factory_; 159 mojo::InterfaceFactoryImpl<EmbedderImpl> embedder_factory_;
145 scoped_ptr<mojo::ViewManagerContext> view_manager_context_; 160 scoped_ptr<mojo::ViewManagerContext> view_manager_context_;
146 EmbeddeePtr embeddee_; 161 EmbeddeePtr embeddee_;
147 ViewToUploader uploaders_; 162 ViewToUploader uploaders_;
163 GURL url_;
148 164
149 DISALLOW_COPY_AND_ASSIGN(WMFlowApp); 165 DISALLOW_COPY_AND_ASSIGN(WMFlowApp);
150 }; 166 };
151 167
152 } // namespace examples 168 } // namespace examples
153 169
154 MojoResult MojoMain(MojoHandle shell_handle) { 170 MojoResult MojoMain(MojoHandle shell_handle) {
155 mojo::ApplicationRunnerChromium runner(new examples::WMFlowApp); 171 mojo::ApplicationRunnerChromium runner(new examples::WMFlowApp);
156 return runner.Run(shell_handle); 172 return runner.Run(shell_handle);
157 } 173 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698