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

Unified Diff: mash/wm/window_manager.cc

Issue 1994763002: Wires up WorkspaceLayoutManager in mash (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: data deps Created 4 years, 7 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
« no previous file with comments | « mash/wm/window_manager.h ('k') | mash/wm/window_manager_application.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: mash/wm/window_manager.cc
diff --git a/mash/wm/window_manager.cc b/mash/wm/window_manager.cc
index 5e2b3f5827e5c5af369559ef6c0edd6d36192cc9..614aaf6bc40e5caadca455ed81a893b31c68c045 100644
--- a/mash/wm/window_manager.cc
+++ b/mash/wm/window_manager.cc
@@ -8,13 +8,16 @@
#include <utility>
+#include "ash/wm/common/container_finder.h"
#include "components/mus/common/types.h"
+#include "components/mus/public/cpp/property_type_converters.h"
#include "components/mus/public/cpp/window.h"
#include "components/mus/public/cpp/window_property.h"
#include "components/mus/public/cpp/window_tree_connection.h"
#include "components/mus/public/interfaces/input_events.mojom.h"
#include "components/mus/public/interfaces/mus_constants.mojom.h"
#include "components/mus/public/interfaces/window_manager.mojom.h"
+#include "mash/wm/bridge/wm_window_mus.h"
#include "mash/wm/non_client_frame_controller.h"
#include "mash/wm/property_util.h"
#include "mash/wm/public/interfaces/container.mojom.h"
@@ -75,30 +78,6 @@ void WindowManager::Initialize(RootWindowController* root_controller,
session->AddScreenlockStateListener(binding_.CreateInterfacePtrAndBind());
}
-gfx::Rect WindowManager::CalculateDefaultBounds(mus::Window* window) const {
- DCHECK(root_controller_);
- int width, height;
- const gfx::Size pref = GetWindowPreferredSize(window);
- const mus::Window* root = root_controller_->root();
- if (pref.IsEmpty()) {
- width = root->bounds().width() - 240;
- height = root->bounds().height() - 240;
- } else {
- // TODO(sky): likely want to constrain more than root size.
- const gfx::Size max_size = GetMaximizedWindowBounds().size();
- width = std::max(0, std::min(max_size.width(), pref.width()));
- height = std::max(0, std::min(max_size.height(), pref.height()));
- }
- return gfx::Rect(40 + (root_controller_->window_count() % 4) * 40,
- 40 + (root_controller_->window_count() % 4) * 40, width,
- height);
-}
-
-gfx::Rect WindowManager::GetMaximizedWindowBounds() const {
- DCHECK(root_controller_);
- return gfx::Rect(root_controller_->root()->bounds().size());
-}
-
mus::Window* WindowManager::NewTopLevelWindow(
std::map<std::string, std::vector<uint8_t>>* properties) {
DCHECK(root_controller_);
@@ -114,15 +93,24 @@ mus::Window* WindowManager::NewTopLevelWindow(
mus::Window* window = root->connection()->NewWindow(properties);
window->SetBounds(CalculateDefaultBounds(window));
- mojom::Container container = GetRequestedContainer(window);
- mus::Window* container_window =
- root_controller_->GetWindowForContainer(container);
+ mus::Window* container_window = nullptr;
+ if (window->HasSharedProperty(mojom::kWindowContainer_Property)) {
+ container_window =
+ root_controller_->GetWindowForContainer(GetRequestedContainer(window));
+ } else {
+ // TODO(sky): window->bounds() isn't quite right.
+ container_window = WmWindowMus::GetMusWindow(
+ ash::wm::GetDefaultParent(WmWindowMus::Get(root_controller_->root()),
+ WmWindowMus::Get(window), window->bounds()));
+ }
DCHECK(root_controller_->WindowIsContainer(container_window));
- container_window->AddChild(window);
if (provide_non_client_frame) {
- NonClientFrameController::Create(root_controller_->GetConnector(), window,
+ NonClientFrameController::Create(root_controller_->GetConnector(),
+ container_window, window,
root_controller_->window_manager_client());
+ } else {
+ container_window->AddChild(window);
}
root_controller_->IncrementWindowCount();
@@ -130,6 +118,36 @@ mus::Window* WindowManager::NewTopLevelWindow(
return window;
}
+gfx::Rect WindowManager::CalculateDefaultBounds(mus::Window* window) const {
+ if (window->HasSharedProperty(
+ mus::mojom::WindowManager::kInitialBounds_Property)) {
+ return window->GetSharedProperty<gfx::Rect>(
+ mus::mojom::WindowManager::kInitialBounds_Property);
+ }
+
+ DCHECK(root_controller_);
+ int width, height;
+ const gfx::Size pref = GetWindowPreferredSize(window);
+ const mus::Window* root = root_controller_->root();
+ if (pref.IsEmpty()) {
+ width = root->bounds().width() - 240;
+ height = root->bounds().height() - 240;
+ } else {
+ // TODO(sky): likely want to constrain more than root size.
+ const gfx::Size max_size = GetMaximizedWindowBounds().size();
+ width = std::max(0, std::min(max_size.width(), pref.width()));
+ height = std::max(0, std::min(max_size.height(), pref.height()));
+ }
+ return gfx::Rect(40 + (root_controller_->window_count() % 4) * 40,
+ 40 + (root_controller_->window_count() % 4) * 40, width,
+ height);
+}
+
+gfx::Rect WindowManager::GetMaximizedWindowBounds() const {
+ DCHECK(root_controller_);
+ return gfx::Rect(root_controller_->root()->bounds().size());
+}
+
void WindowManager::OnTreeChanging(const TreeChangeParams& params) {
DCHECK(root_controller_);
if (params.old_parent == params.receiver &&
@@ -148,7 +166,10 @@ void WindowManager::SetWindowManagerClient(mus::WindowManagerClient* client) {
}
bool WindowManager::OnWmSetBounds(mus::Window* window, gfx::Rect* bounds) {
- // By returning true the bounds of |window| is updated.
+ // TODO(sky): this indirectly sets bounds, which is against what
+ // OnWmSetBounds() recommends doing. Remove that restriction, or fix this.
+ WmWindowMus::Get(window)->SetBounds(*bounds);
+ *bounds = window->bounds();
return true;
}
« no previous file with comments | « mash/wm/window_manager.h ('k') | mash/wm/window_manager_application.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698