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

Side by Side Diff: ash/host/ash_window_tree_host_win.cc

Issue 1390883003: aura: Unify WindowTreeHost for some platforms (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: win build Created 5 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 unified diff | Download patch
« no previous file with comments | « ash/host/ash_window_tree_host_ozone.cc ('k') | ash/test/ash_test_base.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 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 "ash/host/ash_window_tree_host.h" 5 #include "ash/host/ash_window_tree_host.h"
6 6
7 #include "ash/ash_export.h" 7 #include "ash/ash_export.h"
8 #include "ash/ash_switches.h" 8 #include "ash/ash_switches.h"
9 #include "ash/host/ash_remote_window_tree_host_win.h" 9 #include "ash/host/ash_remote_window_tree_host_win.h"
10 #include "ash/host/ash_window_tree_host_init_params.h" 10 #include "ash/host/ash_window_tree_host_init_params.h"
11 #include "ash/host/root_window_transformer.h" 11 #include "ash/host/root_window_transformer.h"
12 #include "ash/host/transformer_helper.h" 12 #include "ash/host/transformer_helper.h"
13 #include "ash/ime/input_method_event_handler.h" 13 #include "ash/ime/input_method_event_handler.h"
14 #include "base/command_line.h" 14 #include "base/command_line.h"
15 #include "base/win/windows_version.h" 15 #include "base/win/windows_version.h"
16 #include "ui/aura/window_tree_host_win.h" 16 #include "ui/aura/window_tree_host_platform.h"
17 #include "ui/events/event_processor.h" 17 #include "ui/events/event_processor.h"
18 #include "ui/gfx/geometry/insets.h" 18 #include "ui/gfx/geometry/insets.h"
19 #include "ui/gfx/transform.h" 19 #include "ui/gfx/transform.h"
20 20
21 namespace ash { 21 namespace ash {
22 namespace { 22 namespace {
23 23
24 class AshWindowTreeHostWin : public AshWindowTreeHost, 24 class AshWindowTreeHostWin : public AshWindowTreeHost,
25 public aura::WindowTreeHostWin { 25 public aura::WindowTreeHostPlatform {
26 public: 26 public:
27 explicit AshWindowTreeHostWin(const gfx::Rect& initial_bounds) 27 explicit AshWindowTreeHostWin(const gfx::Rect& initial_bounds)
28 : aura::WindowTreeHostWin(initial_bounds), 28 : aura::WindowTreeHostPlatform(initial_bounds),
29 fullscreen_(false), 29 fullscreen_(false),
30 saved_window_style_(0), 30 saved_window_style_(0),
31 saved_window_ex_style_(0), 31 saved_window_ex_style_(0),
32 transformer_helper_(this) { 32 transformer_helper_(this) {
33 transformer_helper_.Init(); 33 transformer_helper_.Init();
34 } 34 }
35 ~AshWindowTreeHostWin() override {} 35 ~AshWindowTreeHostWin() override {}
36 36
37 private: 37 private:
38 // AshWindowTreeHost: 38 // AshWindowTreeHost:
39 void ToggleFullScreen() override { 39 void ToggleFullScreen() override {
40 gfx::Rect target_rect; 40 gfx::Rect target_rect;
41 gfx::AcceleratedWidget hwnd = GetAcceleratedWidget();
41 if (!fullscreen_) { 42 if (!fullscreen_) {
42 fullscreen_ = true; 43 fullscreen_ = true;
43 saved_window_style_ = GetWindowLong(hwnd(), GWL_STYLE); 44 saved_window_style_ = GetWindowLong(hwnd, GWL_STYLE);
44 saved_window_ex_style_ = GetWindowLong(hwnd(), GWL_EXSTYLE); 45 saved_window_ex_style_ = GetWindowLong(hwnd, GWL_EXSTYLE);
45 GetWindowRect(hwnd(), &saved_window_rect_); 46 GetWindowRect(hwnd, &saved_window_rect_);
46 SetWindowLong(hwnd(), 47 SetWindowLong(hwnd, GWL_STYLE,
47 GWL_STYLE,
48 saved_window_style_ & ~(WS_CAPTION | WS_THICKFRAME)); 48 saved_window_style_ & ~(WS_CAPTION | WS_THICKFRAME));
49 SetWindowLong( 49 SetWindowLong(hwnd, GWL_EXSTYLE,
50 hwnd(), 50 saved_window_ex_style_ &
51 GWL_EXSTYLE, 51 ~(WS_EX_DLGMODALFRAME | WS_EX_WINDOWEDGE |
52 saved_window_ex_style_ & ~(WS_EX_DLGMODALFRAME | WS_EX_WINDOWEDGE | 52 WS_EX_CLIENTEDGE | WS_EX_STATICEDGE));
53 WS_EX_CLIENTEDGE | WS_EX_STATICEDGE));
54 53
55 MONITORINFO mi; 54 MONITORINFO mi;
56 mi.cbSize = sizeof(mi); 55 mi.cbSize = sizeof(mi);
57 GetMonitorInfo(MonitorFromWindow(hwnd(), MONITOR_DEFAULTTONEAREST), &mi); 56 GetMonitorInfo(MonitorFromWindow(hwnd, MONITOR_DEFAULTTONEAREST), &mi);
58 target_rect = gfx::Rect(mi.rcMonitor); 57 target_rect = gfx::Rect(mi.rcMonitor);
59 } else { 58 } else {
60 fullscreen_ = false; 59 fullscreen_ = false;
61 SetWindowLong(hwnd(), GWL_STYLE, saved_window_style_); 60 SetWindowLong(hwnd, GWL_STYLE, saved_window_style_);
62 SetWindowLong(hwnd(), GWL_EXSTYLE, saved_window_ex_style_); 61 SetWindowLong(hwnd, GWL_EXSTYLE, saved_window_ex_style_);
63 target_rect = gfx::Rect(saved_window_rect_); 62 target_rect = gfx::Rect(saved_window_rect_);
64 } 63 }
65 SetWindowPos(hwnd(), 64 SetWindowPos(hwnd, NULL, target_rect.x(), target_rect.y(),
66 NULL, 65 target_rect.width(), target_rect.height(),
67 target_rect.x(),
68 target_rect.y(),
69 target_rect.width(),
70 target_rect.height(),
71 SWP_NOZORDER | SWP_NOACTIVATE | SWP_FRAMECHANGED); 66 SWP_NOZORDER | SWP_NOACTIVATE | SWP_FRAMECHANGED);
72 } 67 }
73 bool ConfineCursorToRootWindow() override { return false; } 68 bool ConfineCursorToRootWindow() override { return false; }
74 void UnConfineCursor() override { NOTIMPLEMENTED(); } 69 void UnConfineCursor() override { NOTIMPLEMENTED(); }
75 void SetRootWindowTransformer( 70 void SetRootWindowTransformer(
76 scoped_ptr<RootWindowTransformer> transformer) override { 71 scoped_ptr<RootWindowTransformer> transformer) override {
77 transformer_helper_.SetRootWindowTransformer(transformer.Pass()); 72 transformer_helper_.SetRootWindowTransformer(transformer.Pass());
78 } 73 }
79 gfx::Insets GetHostInsets() const override { 74 gfx::Insets GetHostInsets() const override {
80 return transformer_helper_.GetHostInsets(); 75 return transformer_helper_.GetHostInsets();
81 } 76 }
82 aura::WindowTreeHost* AsWindowTreeHost() override { return this; } 77 aura::WindowTreeHost* AsWindowTreeHost() override { return this; }
83 78
84 // WindowTreeHostWin: 79 // WindowTreeHost:
85 void SetBounds(const gfx::Rect& bounds) override { 80 void SetBounds(const gfx::Rect& bounds) override {
86 if (fullscreen_) { 81 if (fullscreen_) {
87 saved_window_rect_.right = saved_window_rect_.left + bounds.width(); 82 saved_window_rect_.right = saved_window_rect_.left + bounds.width();
88 saved_window_rect_.bottom = saved_window_rect_.top + bounds.height(); 83 saved_window_rect_.bottom = saved_window_rect_.top + bounds.height();
89 return; 84 return;
90 } 85 }
91 WindowTreeHostWin::SetBounds(bounds); 86 aura::WindowTreeHostPlatform::SetBounds(bounds);
92 } 87 }
93 void SetRootTransform(const gfx::Transform& transform) override { 88 void SetRootTransform(const gfx::Transform& transform) override {
94 transformer_helper_.SetTransform(transform); 89 transformer_helper_.SetTransform(transform);
95 } 90 }
96 gfx::Transform GetRootTransform() const override { 91 gfx::Transform GetRootTransform() const override {
97 return transformer_helper_.GetTransform(); 92 return transformer_helper_.GetTransform();
98 } 93 }
99 gfx::Transform GetInverseRootTransform() const override { 94 gfx::Transform GetInverseRootTransform() const override {
100 return transformer_helper_.GetInverseTransform(); 95 return transformer_helper_.GetInverseTransform();
101 } 96 }
(...skipping 28 matching lines...) Expand all
130 const AshWindowTreeHostInitParams& init_params) { 125 const AshWindowTreeHostInitParams& init_params) {
131 if (base::win::GetVersion() >= base::win::VERSION_WIN7 && 126 if (base::win::GetVersion() >= base::win::VERSION_WIN7 &&
132 !base::CommandLine::ForCurrentProcess()->HasSwitch( 127 !base::CommandLine::ForCurrentProcess()->HasSwitch(
133 ash::switches::kForceAshToDesktop)) 128 ash::switches::kForceAshToDesktop))
134 return new AshRemoteWindowTreeHostWin(init_params.remote_hwnd); 129 return new AshRemoteWindowTreeHostWin(init_params.remote_hwnd);
135 130
136 return new AshWindowTreeHostWin(init_params.initial_bounds); 131 return new AshWindowTreeHostWin(init_params.initial_bounds);
137 } 132 }
138 133
139 } // namespace ash 134 } // namespace ash
OLDNEW
« no previous file with comments | « ash/host/ash_window_tree_host_ozone.cc ('k') | ash/test/ash_test_base.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698