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

Unified Diff: ui/aura/mus/window_tree_host_mus.h

Issue 2445163002: Make aura work with mus (Closed)
Patch Set: split out Created 4 years, 2 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 side-by-side diff with in-line comments
Download patch
Index: ui/aura/mus/window_tree_host_mus.h
diff --git a/ui/views/mus/window_tree_host_mus.h b/ui/aura/mus/window_tree_host_mus.h
similarity index 31%
copy from ui/views/mus/window_tree_host_mus.h
copy to ui/aura/mus/window_tree_host_mus.h
index 84c4649e85265b581ab6e629a20fc7d179514358..e312b2ce66b4ec124e290be8939a1b7a8338996c 100644
--- a/ui/views/mus/window_tree_host_mus.h
+++ b/ui/aura/mus/window_tree_host_mus.h
@@ -2,36 +2,57 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#ifndef UI_VIEWS_MUS_WINDOW_TREE_HOST_MUS_H_
-#define UI_VIEWS_MUS_WINDOW_TREE_HOST_MUS_H_
+#ifndef UI_AURA_MUS_WINDOW_TREE_HOST_MUS_H_
+#define UI_AURA_MUS_WINDOW_TREE_HOST_MUS_H_
+
+#include <memory>
#include "base/macros.h"
#include "services/service_manager/public/cpp/connector.h"
+#include "ui/aura/aura_export.h"
#include "ui/aura/window_tree_host_platform.h"
-#include "ui/views/mus/mus_export.h"
class SkBitmap;
-namespace ui {
-class Window;
-}
-
namespace service_manager {
class Connector;
}
-namespace views {
+namespace aura {
-class NativeWidgetMus;
-class PlatformWindowMus;
+class InputMethodMus;
+class WindowPortMus;
-class VIEWS_MUS_EXPORT WindowTreeHostMus : public aura::WindowTreeHostPlatform {
+// WindowTreeHostMus is configured in two distinct modes:
+// . with a content window. In this case the content window is added as a child
+// of the Window created by this class. Any changes to the size of the content
+// window is propagated to its parent. Additionally once the content window is
+// destroyed the WindowTreeHostMus is destroyed.
+// . without a content window.
sadrul 2016/10/26 18:38:20 Who is the owner of WTHMus? especially when there
sky 2016/10/26 19:56:45 Good question. I added this: // If a content wind
+class AURA_EXPORT WindowTreeHostMus : public aura::WindowTreeHostPlatform {
public:
- WindowTreeHostMus(NativeWidgetMus* native_widget, ui::Window* window);
+ explicit WindowTreeHostMus(std::unique_ptr<WindowPortMus> window_port,
+ Window* content_window = nullptr);
~WindowTreeHostMus() override;
- NativeWidgetMus* native_widget() { return native_widget_; }
+
+ void CreateInputMethod(WindowPortMus* window_port_mus);
+
+ ui::EventDispatchDetails SendEventToProcessor(ui::Event* event) {
+ return aura::WindowTreeHostPlatform::SendEventToProcessor(event);
+ }
+
+ Window* content_window() { return content_window_; }
+
+ InputMethodMus* input_method() { return input_method_.get(); }
private:
+ class ContentWindowObserver;
+
+ // Called when various things happen to the content window.
+ void ContentWindowDestroyed();
+ void ContentWindowResized();
+ void ContentWindowVisibilityChanging(bool visible);
+
// aura::WindowTreeHostPlatform:
void DispatchEvent(ui::Event* event) override;
void OnClosed() override;
@@ -39,11 +60,15 @@ class VIEWS_MUS_EXPORT WindowTreeHostMus : public aura::WindowTreeHostPlatform {
void OnCloseRequest() override;
gfx::ICCProfile GetICCProfileForCurrentDisplay() override;
- NativeWidgetMus* native_widget_;
+ // May be null, see class description.
+ Window* content_window_;
+
+ std::unique_ptr<ContentWindowObserver> content_window_observer_;
+ std::unique_ptr<InputMethodMus> input_method_;
DISALLOW_COPY_AND_ASSIGN(WindowTreeHostMus);
};
-} // namespace views
+} // namespace aura
-#endif // UI_VIEWS_MUS_WINDOW_TREE_HOST_MUS_H_
+#endif // UI_AURA_MUS_WINDOW_TREE_HOST_MUS_H_

Powered by Google App Engine
This is Rietveld 408576698