OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "ui/views/widget/desktop_aura/desktop_window_tree_host_x11.h" | 5 #include "ui/views/widget/desktop_aura/desktop_window_tree_host_x11.h" |
6 | 6 |
7 #include <X11/extensions/shape.h> | 7 #include <X11/extensions/shape.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/Xregion.h> | 10 #include <X11/Xregion.h> |
(...skipping 21 matching lines...) Expand all Loading... | |
32 #include "ui/base/ime/input_method.h" | 32 #include "ui/base/ime/input_method.h" |
33 #include "ui/base/x/x11_util.h" | 33 #include "ui/base/x/x11_util.h" |
34 #include "ui/base/x/x11_util_internal.h" | 34 #include "ui/base/x/x11_util_internal.h" |
35 #include "ui/base/x/x11_window_event_manager.h" | 35 #include "ui/base/x/x11_window_event_manager.h" |
36 #include "ui/display/display.h" | 36 #include "ui/display/display.h" |
37 #include "ui/display/screen.h" | 37 #include "ui/display/screen.h" |
38 #include "ui/events/devices/x11/device_data_manager_x11.h" | 38 #include "ui/events/devices/x11/device_data_manager_x11.h" |
39 #include "ui/events/devices/x11/device_list_cache_x11.h" | 39 #include "ui/events/devices/x11/device_list_cache_x11.h" |
40 #include "ui/events/devices/x11/touch_factory_x11.h" | 40 #include "ui/events/devices/x11/touch_factory_x11.h" |
41 #include "ui/events/event_utils.h" | 41 #include "ui/events/event_utils.h" |
42 #include "ui/events/null_event_targeter.h" | |
42 #include "ui/events/platform/platform_event_source.h" | 43 #include "ui/events/platform/platform_event_source.h" |
43 #include "ui/events/platform/x11/x11_event_source.h" | 44 #include "ui/events/platform/x11/x11_event_source.h" |
44 #include "ui/gfx/geometry/insets.h" | 45 #include "ui/gfx/geometry/insets.h" |
45 #include "ui/gfx/geometry/size_conversions.h" | 46 #include "ui/gfx/geometry/size_conversions.h" |
46 #include "ui/gfx/image/image_skia.h" | 47 #include "ui/gfx/image/image_skia.h" |
47 #include "ui/gfx/image/image_skia_rep.h" | 48 #include "ui/gfx/image/image_skia_rep.h" |
48 #include "ui/gfx/path.h" | 49 #include "ui/gfx/path.h" |
49 #include "ui/gfx/path_x11.h" | 50 #include "ui/gfx/path_x11.h" |
50 #include "ui/native_theme/native_theme.h" | 51 #include "ui/native_theme/native_theme.h" |
51 #include "ui/native_theme/native_theme_aura.h" | 52 #include "ui/native_theme/native_theme_aura.h" |
(...skipping 118 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
170 case XINotifyWhileGrabbed: | 171 case XINotifyWhileGrabbed: |
171 return NotifyWhileGrabbed; | 172 return NotifyWhileGrabbed; |
172 default: | 173 default: |
173 NOTREACHED(); | 174 NOTREACHED(); |
174 return NotifyNormal; | 175 return NotifyNormal; |
175 } | 176 } |
176 } | 177 } |
177 | 178 |
178 } // namespace | 179 } // namespace |
179 | 180 |
181 DesktopWindowTreeHostX11::ScopedHandle::ScopedHandle(const base::Closure& | |
182 destroy_callback) | |
183 : destroy_callback_(destroy_callback) { | |
184 } | |
185 | |
186 DesktopWindowTreeHostX11::ScopedHandle::~ScopedHandle() { | |
187 if (!destroy_callback_.is_null()) | |
188 destroy_callback_.Run(); | |
189 } | |
190 | |
180 //////////////////////////////////////////////////////////////////////////////// | 191 //////////////////////////////////////////////////////////////////////////////// |
181 // DesktopWindowTreeHostX11, public: | 192 // DesktopWindowTreeHostX11, public: |
182 | 193 |
183 DesktopWindowTreeHostX11::DesktopWindowTreeHostX11( | 194 DesktopWindowTreeHostX11::DesktopWindowTreeHostX11( |
184 internal::NativeWidgetDelegate* native_widget_delegate, | 195 internal::NativeWidgetDelegate* native_widget_delegate, |
185 DesktopNativeWidgetAura* desktop_native_widget_aura) | 196 DesktopNativeWidgetAura* desktop_native_widget_aura) |
186 : xdisplay_(gfx::GetXDisplay()), | 197 : xdisplay_(gfx::GetXDisplay()), |
187 xwindow_(0), | 198 xwindow_(0), |
188 x_root_window_(DefaultRootWindow(xdisplay_)), | 199 x_root_window_(DefaultRootWindow(xdisplay_)), |
189 atom_cache_(xdisplay_, kAtomsToCache), | 200 atom_cache_(xdisplay_, kAtomsToCache), |
190 window_mapped_(false), | 201 window_mapped_(false), |
191 wait_for_unmap_(false), | 202 wait_for_unmap_(false), |
192 is_fullscreen_(false), | 203 is_fullscreen_(false), |
193 is_always_on_top_(false), | 204 is_always_on_top_(false), |
194 use_native_frame_(false), | 205 use_native_frame_(false), |
195 should_maximize_after_map_(false), | 206 should_maximize_after_map_(false), |
196 use_argb_visual_(false), | 207 use_argb_visual_(false), |
197 drag_drop_client_(NULL), | 208 drag_drop_client_(NULL), |
198 native_widget_delegate_(native_widget_delegate), | 209 native_widget_delegate_(native_widget_delegate), |
199 desktop_native_widget_aura_(desktop_native_widget_aura), | 210 desktop_native_widget_aura_(desktop_native_widget_aura), |
200 content_window_(NULL), | 211 content_window_(NULL), |
201 window_parent_(NULL), | 212 window_parent_(NULL), |
202 custom_window_shape_(false), | 213 custom_window_shape_(false), |
203 urgency_hint_set_(false), | 214 urgency_hint_set_(false), |
204 has_pointer_grab_(false), | 215 has_pointer_grab_(false), |
205 activatable_(true), | 216 activatable_(true), |
206 has_pointer_(false), | 217 has_pointer_(false), |
207 has_window_focus_(false), | 218 has_window_focus_(false), |
208 has_pointer_focus_(false), | 219 has_pointer_focus_(false), |
209 close_widget_factory_(this) {} | 220 modal_dialog_xid_(0), |
221 scoped_handle_(NULL), | |
222 close_widget_factory_(this), | |
223 weak_factory_(this) {} | |
210 | 224 |
211 DesktopWindowTreeHostX11::~DesktopWindowTreeHostX11() { | 225 DesktopWindowTreeHostX11::~DesktopWindowTreeHostX11() { |
212 window()->ClearProperty(kHostForRootWindow); | 226 window()->ClearProperty(kHostForRootWindow); |
213 aura::client::SetWindowMoveClient(window(), NULL); | 227 aura::client::SetWindowMoveClient(window(), NULL); |
214 desktop_native_widget_aura_->OnDesktopWindowTreeHostDestroyed(this); | 228 desktop_native_widget_aura_->OnDesktopWindowTreeHostDestroyed(this); |
215 DestroyDispatcher(); | 229 DestroyDispatcher(); |
216 } | 230 } |
217 | 231 |
218 // static | 232 // static |
219 aura::Window* DesktopWindowTreeHostX11::GetContentWindowForXID(XID xid) { | 233 aura::Window* DesktopWindowTreeHostX11::GetContentWindowForXID(XID xid) { |
(...skipping 1547 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1767 if (g_current_capture && g_current_capture != this && | 1781 if (g_current_capture && g_current_capture != this && |
1768 event->type() == ui::ET_TOUCH_PRESSED) { | 1782 event->type() == ui::ET_TOUCH_PRESSED) { |
1769 ConvertEventToDifferentHost(event, g_current_capture); | 1783 ConvertEventToDifferentHost(event, g_current_capture); |
1770 g_current_capture->SendEventToProcessor(event); | 1784 g_current_capture->SendEventToProcessor(event); |
1771 } else { | 1785 } else { |
1772 SendEventToProcessor(event); | 1786 SendEventToProcessor(event); |
1773 } | 1787 } |
1774 } | 1788 } |
1775 | 1789 |
1776 void DesktopWindowTreeHostX11::DispatchKeyEvent(ui::KeyEvent* event) { | 1790 void DesktopWindowTreeHostX11::DispatchKeyEvent(ui::KeyEvent* event) { |
1777 GetInputMethod()->DispatchKeyEvent(event); | 1791 if (native_widget_delegate_->AsWidget()->IsActive()) |
1792 GetInputMethod()->DispatchKeyEvent(event); | |
1778 } | 1793 } |
1779 | 1794 |
1780 void DesktopWindowTreeHostX11::ConvertEventToDifferentHost( | 1795 void DesktopWindowTreeHostX11::ConvertEventToDifferentHost( |
1781 ui::LocatedEvent* located_event, | 1796 ui::LocatedEvent* located_event, |
1782 DesktopWindowTreeHostX11* host) { | 1797 DesktopWindowTreeHostX11* host) { |
1783 DCHECK_NE(this, host); | 1798 DCHECK_NE(this, host); |
1784 const display::Display display_src = | 1799 const display::Display display_src = |
1785 display::Screen::GetScreen()->GetDisplayNearestWindow(window()); | 1800 display::Screen::GetScreen()->GetDisplayNearestWindow(window()); |
1786 const display::Display display_dest = | 1801 const display::Display display_dest = |
1787 display::Screen::GetScreen()->GetDisplayNearestWindow(host->window()); | 1802 display::Screen::GetScreen()->GetDisplayNearestWindow(host->window()); |
(...skipping 501 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
2289 return gfx::ToEnclosingRect(rect_in_dip); | 2304 return gfx::ToEnclosingRect(rect_in_dip); |
2290 } | 2305 } |
2291 | 2306 |
2292 gfx::Rect DesktopWindowTreeHostX11::ToPixelRect( | 2307 gfx::Rect DesktopWindowTreeHostX11::ToPixelRect( |
2293 const gfx::Rect& rect_in_dip) const { | 2308 const gfx::Rect& rect_in_dip) const { |
2294 gfx::RectF rect_in_pixels = gfx::RectF(rect_in_dip); | 2309 gfx::RectF rect_in_pixels = gfx::RectF(rect_in_dip); |
2295 GetRootTransform().TransformRect(&rect_in_pixels); | 2310 GetRootTransform().TransformRect(&rect_in_pixels); |
2296 return gfx::ToEnclosingRect(rect_in_pixels); | 2311 return gfx::ToEnclosingRect(rect_in_pixels); |
2297 } | 2312 } |
2298 | 2313 |
2314 XID DesktopWindowTreeHostX11::GetModalDialog() { | |
2315 return modal_dialog_xid_; | |
2316 } | |
2317 | |
2318 std::unique_ptr<DesktopWindowTreeHostX11::ScopedHandle> | |
2319 DesktopWindowTreeHostX11::DisableEventListening(XID dialog) { | |
2320 DCHECK(dialog); | |
2321 DCHECK(!modal_dialog_xid_); | |
2322 modal_dialog_xid_ = dialog; | |
2323 // ScopedWindowTargeter is used to temporarily replace the event-targeter | |
2324 // with NullEventTargeter to make |dialog| modal. | |
2325 targeter_for_modal_.reset(new aura::ScopedWindowTargeter(window(), | |
2326 std::unique_ptr<ui::EventTargeter>(new ui::NullEventTargeter))); | |
2327 | |
2328 scoped_handle_ = new DesktopWindowTreeHostX11::ScopedHandle( | |
2329 base::Bind(&DesktopWindowTreeHostX11::EnableEventListening, | |
2330 weak_factory_.GetWeakPtr())); | |
2331 return base::WrapUnique(scoped_handle_); | |
sadrul
2016/09/30 12:22:27
return base::MakeUnique<...>(base::Bind...)
joone
2016/10/01 00:03:16
Done.
| |
2332 } | |
2333 | |
2334 void DesktopWindowTreeHostX11::EnableEventListening() { | |
2335 DCHECK(modal_dialog_xid_); | |
2336 modal_dialog_xid_ = 0; | |
2337 targeter_for_modal_.reset(); | |
2338 } | |
2339 | |
2299 //////////////////////////////////////////////////////////////////////////////// | 2340 //////////////////////////////////////////////////////////////////////////////// |
2300 // DesktopWindowTreeHost, public: | 2341 // DesktopWindowTreeHost, public: |
2301 | 2342 |
2302 // static | 2343 // static |
2303 DesktopWindowTreeHost* DesktopWindowTreeHost::Create( | 2344 DesktopWindowTreeHost* DesktopWindowTreeHost::Create( |
2304 internal::NativeWidgetDelegate* native_widget_delegate, | 2345 internal::NativeWidgetDelegate* native_widget_delegate, |
2305 DesktopNativeWidgetAura* desktop_native_widget_aura) { | 2346 DesktopNativeWidgetAura* desktop_native_widget_aura) { |
2306 return new DesktopWindowTreeHostX11(native_widget_delegate, | 2347 return new DesktopWindowTreeHostX11(native_widget_delegate, |
2307 desktop_native_widget_aura); | 2348 desktop_native_widget_aura); |
2308 } | 2349 } |
2309 | 2350 |
2310 // static | 2351 // static |
2311 ui::NativeTheme* DesktopWindowTreeHost::GetNativeTheme(aura::Window* window) { | 2352 ui::NativeTheme* DesktopWindowTreeHost::GetNativeTheme(aura::Window* window) { |
2312 const LinuxUI* linux_ui = LinuxUI::instance(); | 2353 const LinuxUI* linux_ui = LinuxUI::instance(); |
2313 if (linux_ui) { | 2354 if (linux_ui) { |
2314 ui::NativeTheme* native_theme = linux_ui->GetNativeTheme(window); | 2355 ui::NativeTheme* native_theme = linux_ui->GetNativeTheme(window); |
2315 if (native_theme) | 2356 if (native_theme) |
2316 return native_theme; | 2357 return native_theme; |
2317 } | 2358 } |
2318 | 2359 |
2319 return ui::NativeThemeAura::instance(); | 2360 return ui::NativeThemeAura::instance(); |
2320 } | 2361 } |
2321 | 2362 |
2322 } // namespace views | 2363 } // namespace views |
OLD | NEW |