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

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

Issue 922843002: Fix software mirror mode on Ozone part 2/2 (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 9 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_x11.h ('k') | ash/touch/touch_transformer_controller.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_x11.h" 5 #include "ash/host/ash_window_tree_host_x11.h"
6 6
7 #include <X11/extensions/Xfixes.h> 7 #include <X11/extensions/Xfixes.h>
8 #include <X11/extensions/XInput2.h> 8 #include <X11/extensions/XInput2.h>
9 #include <X11/Xatom.h> 9 #include <X11/Xatom.h>
10 #include <X11/Xlib.h> 10 #include <X11/Xlib.h>
(...skipping 15 matching lines...) Expand all
26 #include "ui/events/event.h" 26 #include "ui/events/event.h"
27 #include "ui/events/event_utils.h" 27 #include "ui/events/event_utils.h"
28 #include "ui/events/null_event_targeter.h" 28 #include "ui/events/null_event_targeter.h"
29 #include "ui/events/platform/platform_event_source.h" 29 #include "ui/events/platform/platform_event_source.h"
30 #include "ui/gfx/geometry/rect.h" 30 #include "ui/gfx/geometry/rect.h"
31 #include "ui/gfx/screen.h" 31 #include "ui/gfx/screen.h"
32 32
33 namespace ash { 33 namespace ash {
34 34
35 AshWindowTreeHostX11::AshWindowTreeHostX11(const gfx::Rect& initial_bounds) 35 AshWindowTreeHostX11::AshWindowTreeHostX11(const gfx::Rect& initial_bounds)
36 : WindowTreeHostX11(initial_bounds), 36 : WindowTreeHostX11(initial_bounds), transformer_helper_(this) {
37 transformer_helper_(this),
38 display_ids_(std::make_pair(gfx::Display::kInvalidDisplayID,
39 gfx::Display::kInvalidDisplayID)) {
40 aura::Env::GetInstance()->AddObserver(this); 37 aura::Env::GetInstance()->AddObserver(this);
41 } 38 }
42 39
43 AshWindowTreeHostX11::~AshWindowTreeHostX11() { 40 AshWindowTreeHostX11::~AshWindowTreeHostX11() {
44 aura::Env::GetInstance()->RemoveObserver(this); 41 aura::Env::GetInstance()->RemoveObserver(this);
45 UnConfineCursor(); 42 UnConfineCursor();
46 } 43 }
47 44
48 void AshWindowTreeHostX11::ToggleFullScreen() { NOTIMPLEMENTED(); } 45 void AshWindowTreeHostX11::ToggleFullScreen() { NOTIMPLEMENTED(); }
49 46
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after
119 ConfineCursorToRootWindow(); 116 ConfineCursorToRootWindow();
120 } 117 }
121 } 118 }
122 119
123 gfx::Insets AshWindowTreeHostX11::GetHostInsets() const { 120 gfx::Insets AshWindowTreeHostX11::GetHostInsets() const {
124 return transformer_helper_.GetHostInsets(); 121 return transformer_helper_.GetHostInsets();
125 } 122 }
126 123
127 aura::WindowTreeHost* AshWindowTreeHostX11::AsWindowTreeHost() { return this; } 124 aura::WindowTreeHost* AshWindowTreeHostX11::AsWindowTreeHost() { return this; }
128 125
129 void AshWindowTreeHostX11::UpdateDisplayID(int64 id1, int64 id2) {
130 display_ids_.first = id1;
131 display_ids_.second = id2;
132 }
133
134 void AshWindowTreeHostX11::PrepareForShutdown() { 126 void AshWindowTreeHostX11::PrepareForShutdown() {
135 // Block the root window from dispatching events because it is weird for a 127 // Block the root window from dispatching events because it is weird for a
136 // ScreenPositionClient not to be attached to the root window and for 128 // ScreenPositionClient not to be attached to the root window and for
137 // ui::EventHandlers to be unable to convert the event's location to screen 129 // ui::EventHandlers to be unable to convert the event's location to screen
138 // coordinates. 130 // coordinates.
139 window()->SetEventTargeter( 131 window()->SetEventTargeter(
140 scoped_ptr<ui::EventTargeter>(new ui::NullEventTargeter)); 132 scoped_ptr<ui::EventTargeter>(new ui::NullEventTargeter));
141 133
142 if (ui::PlatformEventSource::GetInstance()) { 134 if (ui::PlatformEventSource::GetInstance()) {
143 // Block X events which are not turned into ui::Events from getting 135 // Block X events which are not turned into ui::Events from getting
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after
206 // For touch event, check if the root window is residing on the according 198 // For touch event, check if the root window is residing on the according
207 // touch display. 199 // touch display.
208 switch (type) { 200 switch (type) {
209 case ui::ET_TOUCH_MOVED: 201 case ui::ET_TOUCH_MOVED:
210 case ui::ET_TOUCH_PRESSED: 202 case ui::ET_TOUCH_PRESSED:
211 case ui::ET_TOUCH_CANCELLED: 203 case ui::ET_TOUCH_CANCELLED:
212 case ui::ET_TOUCH_RELEASED: { 204 case ui::ET_TOUCH_RELEASED: {
213 #if defined(OS_CHROMEOS) 205 #if defined(OS_CHROMEOS)
214 XIDeviceEvent* xiev = static_cast<XIDeviceEvent*>(xev->xcookie.data); 206 XIDeviceEvent* xiev = static_cast<XIDeviceEvent*>(xev->xcookie.data);
215 int64 touch_display_id = 207 int64 touch_display_id =
216 ui::DeviceDataManager::GetInstance()->GetDisplayForTouchDevice( 208 ui::DeviceDataManager::GetInstance()->GetTargetDisplayForTouchDevice(
217 xiev->deviceid); 209 xiev->deviceid);
218 // If we don't have record of display id for this touch device, check 210 // If we don't have record of display id for this touch device, check
219 // that if the event is within the bound of the root window. Note 211 // that if the event is within the bound of the root window. Note
220 // that in multi-monitor case, the event position is in framebuffer 212 // that in multi-monitor case, the event position is in framebuffer
221 // space so the bounds check will not work so well. 213 // space so the bounds check will not work so well.
222 if (touch_display_id == gfx::Display::kInvalidDisplayID) { 214 if (touch_display_id == gfx::Display::kInvalidDisplayID) {
223 if (base::SysInfo::IsRunningOnChromeOS() && 215 if (base::SysInfo::IsRunningOnChromeOS() &&
224 !bounds().Contains(ui::EventLocationFromNative(xev))) 216 !bounds().Contains(ui::EventLocationFromNative(xev)))
225 return false; 217 return false;
226 } else if (touch_display_id != display_ids_.first && 218 } else {
227 touch_display_id != display_ids_.second) { 219 gfx::Screen* screen = gfx::Screen::GetScreenFor(window());
228 return false; 220 gfx::Display display = screen->GetDisplayNearestWindow(window());
221 return touch_display_id == display.id();
229 } 222 }
230 #endif // defined(OS_CHROMEOS) 223 #endif // defined(OS_CHROMEOS)
231 return true; 224 return true;
232 } 225 }
233 default: 226 default:
234 return true; 227 return true;
235 } 228 }
236 } 229 }
237 void AshWindowTreeHostX11::TranslateAndDispatchLocatedEvent( 230 void AshWindowTreeHostX11::TranslateAndDispatchLocatedEvent(
238 ui::LocatedEvent* event) { 231 ui::LocatedEvent* event) {
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after
284 } 277 }
285 } 278 }
286 #endif 279 #endif
287 280
288 AshWindowTreeHost* AshWindowTreeHost::Create( 281 AshWindowTreeHost* AshWindowTreeHost::Create(
289 const AshWindowTreeHostInitParams& init_params) { 282 const AshWindowTreeHostInitParams& init_params) {
290 return new AshWindowTreeHostX11(init_params.initial_bounds); 283 return new AshWindowTreeHostX11(init_params.initial_bounds);
291 } 284 }
292 285
293 } // namespace ash 286 } // namespace ash
OLDNEW
« no previous file with comments | « ash/host/ash_window_tree_host_x11.h ('k') | ash/touch/touch_transformer_controller.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698