OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "chrome/browser/ui/gtk/gtk_util.h" | 5 #include "chrome/browser/ui/gtk/gtk_util.h" |
6 | 6 |
7 #include <cairo/cairo.h> | 7 #include <cairo/cairo.h> |
8 #include <gdk/gdkx.h> | 8 #include <gdk/gdkx.h> |
9 #include <gtk/gtk.h> | 9 #include <gtk/gtk.h> |
10 | 10 |
11 #include <cstdarg> | 11 #include <cstdarg> |
12 #include <map> | 12 #include <map> |
13 | 13 |
14 #include "app/l10n_util.h" | 14 #include "app/l10n_util.h" |
15 #include "app/resource_bundle.h" | 15 #include "app/resource_bundle.h" |
16 #include "app/x11_util.h" | |
17 #include "base/environment.h" | 16 #include "base/environment.h" |
18 #include "base/i18n/rtl.h" | 17 #include "base/i18n/rtl.h" |
19 #include "base/linux_util.h" | 18 #include "base/linux_util.h" |
20 #include "base/logging.h" | 19 #include "base/logging.h" |
21 #include "base/nix/xdg_util.h" | 20 #include "base/nix/xdg_util.h" |
22 #include "base/string_number_conversions.h" | 21 #include "base/string_number_conversions.h" |
23 #include "base/utf_string_conversions.h" | 22 #include "base/utf_string_conversions.h" |
24 #include "chrome/browser/autocomplete/autocomplete.h" | 23 #include "chrome/browser/autocomplete/autocomplete.h" |
25 #include "chrome/browser/autocomplete/autocomplete_classifier.h" | 24 #include "chrome/browser/autocomplete/autocomplete_classifier.h" |
26 #include "chrome/browser/autocomplete/autocomplete_match.h" | 25 #include "chrome/browser/autocomplete/autocomplete_match.h" |
27 #include "chrome/browser/browser_list.h" | 26 #include "chrome/browser/browser_list.h" |
28 #include "chrome/browser/browser_window.h" | 27 #include "chrome/browser/browser_window.h" |
29 #include "chrome/browser/profiles/profile.h" | 28 #include "chrome/browser/profiles/profile.h" |
30 #include "chrome/browser/renderer_host/render_view_host.h" | 29 #include "chrome/browser/renderer_host/render_view_host.h" |
31 #include "chrome/browser/tab_contents/tab_contents.h" | 30 #include "chrome/browser/tab_contents/tab_contents.h" |
32 #include "chrome/browser/ui/gtk/cairo_cached_surface.h" | 31 #include "chrome/browser/ui/gtk/cairo_cached_surface.h" |
33 #include "chrome/browser/ui/gtk/gtk_theme_provider.h" | 32 #include "chrome/browser/ui/gtk/gtk_theme_provider.h" |
34 #include "chrome/common/renderer_preferences.h" | 33 #include "chrome/common/renderer_preferences.h" |
35 #include "gfx/gtk_util.h" | 34 #include "gfx/gtk_util.h" |
36 #include "googleurl/src/gurl.h" | 35 #include "googleurl/src/gurl.h" |
37 #include "grit/theme_resources.h" | 36 #include "grit/theme_resources.h" |
38 #include "third_party/skia/include/core/SkBitmap.h" | 37 #include "third_party/skia/include/core/SkBitmap.h" |
39 #include "third_party/skia/include/core/SkColor.h" | 38 #include "third_party/skia/include/core/SkColor.h" |
| 39 #include "ui/base/x/x11_util.h" |
40 | 40 |
41 #if defined(OS_CHROMEOS) | 41 #if defined(OS_CHROMEOS) |
42 #include "chrome/browser/chromeos/frame/browser_view.h" | 42 #include "chrome/browser/chromeos/frame/browser_view.h" |
43 #include "chrome/browser/chromeos/native_dialog_window.h" | 43 #include "chrome/browser/chromeos/native_dialog_window.h" |
44 #include "chrome/browser/chromeos/options/options_window_view.h" | 44 #include "chrome/browser/chromeos/options/options_window_view.h" |
45 #include "views/window/window.h" | 45 #include "views/window/window.h" |
46 #else | 46 #else |
47 #include "chrome/browser/ui/gtk/browser_window_gtk.h" | 47 #include "chrome/browser/ui/gtk/browser_window_gtk.h" |
48 #endif | 48 #endif |
49 | 49 |
(...skipping 308 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
358 if (origin.x() < rect.x) | 358 if (origin.x() < rect.x) |
359 origin.set_x(rect.x); | 359 origin.set_x(rect.x); |
360 if (origin.y() < rect.y) | 360 if (origin.y() < rect.y) |
361 origin.set_y(rect.y); | 361 origin.set_y(rect.y); |
362 } | 362 } |
363 | 363 |
364 gtk_window_move(window, origin.x(), origin.y()); | 364 gtk_window_move(window, origin.x(), origin.y()); |
365 | 365 |
366 // Move to user expected desktop if window is already visible. | 366 // Move to user expected desktop if window is already visible. |
367 if (GTK_WIDGET(window)->window) { | 367 if (GTK_WIDGET(window)->window) { |
368 x11_util::ChangeWindowDesktop( | 368 ui::ChangeWindowDesktop( |
369 x11_util::GetX11WindowFromGtkWidget(GTK_WIDGET(window)), | 369 ui::GetX11WindowFromGtkWidget(GTK_WIDGET(window)), |
370 x11_util::GetX11WindowFromGtkWidget(GTK_WIDGET(parent))); | 370 ui::GetX11WindowFromGtkWidget(GTK_WIDGET(parent))); |
371 } | 371 } |
372 } | 372 } |
373 | 373 |
374 void MakeAppModalWindowGroup() { | 374 void MakeAppModalWindowGroup() { |
375 #if GTK_CHECK_VERSION(2, 14, 0) | 375 #if GTK_CHECK_VERSION(2, 14, 0) |
376 // Older versions of GTK+ don't give us gtk_window_group_list() which is what | 376 // Older versions of GTK+ don't give us gtk_window_group_list() which is what |
377 // we need to add current non-browser modal dialogs to the list. If | 377 // we need to add current non-browser modal dialogs to the list. If |
378 // we have 2.14+ we can do things the correct way. | 378 // we have 2.14+ we can do things the correct way. |
379 GtkWindowGroup* window_group = gtk_window_group_new(); | 379 GtkWindowGroup* window_group = gtk_window_group_new(); |
380 for (BrowserList::const_iterator it = BrowserList::begin(); | 380 for (BrowserList::const_iterator it = BrowserList::begin(); |
(...skipping 158 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
539 gtk_box_pack_start(GTK_BOX(hbox), centering_vbox, FALSE, FALSE, padding); | 539 gtk_box_pack_start(GTK_BOX(hbox), centering_vbox, FALSE, FALSE, padding); |
540 | 540 |
541 return centering_vbox; | 541 return centering_vbox; |
542 } | 542 } |
543 | 543 |
544 bool IsScreenComposited() { | 544 bool IsScreenComposited() { |
545 GdkScreen* screen = gdk_screen_get_default(); | 545 GdkScreen* screen = gdk_screen_get_default(); |
546 return gdk_screen_is_composited(screen) == TRUE; | 546 return gdk_screen_is_composited(screen) == TRUE; |
547 } | 547 } |
548 | 548 |
549 void EnumerateTopLevelWindows(x11_util::EnumerateWindowsDelegate* delegate) { | 549 void EnumerateTopLevelWindows(ui::EnumerateWindowsDelegate* delegate) { |
550 std::vector<XID> stack; | 550 std::vector<XID> stack; |
551 if (!x11_util::GetXWindowStack(&stack)) { | 551 if (!ui::GetXWindowStack(&stack)) { |
552 // Window Manager doesn't support _NET_CLIENT_LIST_STACKING, so fall back | 552 // Window Manager doesn't support _NET_CLIENT_LIST_STACKING, so fall back |
553 // to old school enumeration of all X windows. Some WMs parent 'top-level' | 553 // to old school enumeration of all X windows. Some WMs parent 'top-level' |
554 // windows in unnamed actual top-level windows (ion WM), so extend the | 554 // windows in unnamed actual top-level windows (ion WM), so extend the |
555 // search depth to all children of top-level windows. | 555 // search depth to all children of top-level windows. |
556 const int kMaxSearchDepth = 1; | 556 const int kMaxSearchDepth = 1; |
557 x11_util::EnumerateAllWindows(delegate, kMaxSearchDepth); | 557 ui::EnumerateAllWindows(delegate, kMaxSearchDepth); |
558 return; | 558 return; |
559 } | 559 } |
560 | 560 |
561 std::vector<XID>::iterator iter; | 561 std::vector<XID>::iterator iter; |
562 for (iter = stack.begin(); iter != stack.end(); iter++) { | 562 for (iter = stack.begin(); iter != stack.end(); iter++) { |
563 if (delegate->ShouldStopIterating(*iter)) | 563 if (delegate->ShouldStopIterating(*iter)) |
564 return; | 564 return; |
565 } | 565 } |
566 } | 566 } |
567 | 567 |
(...skipping 282 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
850 DCHECK(GTK_IS_WINDOW(toplevel) && GTK_WIDGET_TOPLEVEL(toplevel) && | 850 DCHECK(GTK_IS_WINDOW(toplevel) && GTK_WIDGET_TOPLEVEL(toplevel) && |
851 GTK_WIDGET_REALIZED(toplevel)); | 851 GTK_WIDGET_REALIZED(toplevel)); |
852 | 852 |
853 // Stack the |popup| window directly above the |toplevel| window. | 853 // Stack the |popup| window directly above the |toplevel| window. |
854 // The popup window is a direct child of the root window, so we need to | 854 // The popup window is a direct child of the root window, so we need to |
855 // find a similar ancestor for the toplevel window (which might have been | 855 // find a similar ancestor for the toplevel window (which might have been |
856 // reparented by a window manager). We grab the server while we're doing | 856 // reparented by a window manager). We grab the server while we're doing |
857 // this -- otherwise, we'll get an error if the window manager reparents the | 857 // this -- otherwise, we'll get an error if the window manager reparents the |
858 // toplevel window right after we call GetHighestAncestorWindow(). | 858 // toplevel window right after we call GetHighestAncestorWindow(). |
859 gdk_x11_display_grab(gtk_widget_get_display(toplevel)); | 859 gdk_x11_display_grab(gtk_widget_get_display(toplevel)); |
860 XID toplevel_window_base = x11_util::GetHighestAncestorWindow( | 860 XID toplevel_window_base = ui::GetHighestAncestorWindow( |
861 x11_util::GetX11WindowFromGtkWidget(toplevel), | 861 ui::GetX11WindowFromGtkWidget(toplevel), |
862 x11_util::GetX11RootWindow()); | 862 ui::GetX11RootWindow()); |
863 if (toplevel_window_base) { | 863 if (toplevel_window_base) { |
864 XID window_xid = x11_util::GetX11WindowFromGtkWidget(popup); | 864 XID window_xid = ui::GetX11WindowFromGtkWidget(popup); |
865 XID window_parent = x11_util::GetParentWindow(window_xid); | 865 XID window_parent = ui::GetParentWindow(window_xid); |
866 if (window_parent == x11_util::GetX11RootWindow()) { | 866 if (window_parent == ui::GetX11RootWindow()) { |
867 x11_util::RestackWindow(window_xid, toplevel_window_base, true); | 867 ui::RestackWindow(window_xid, toplevel_window_base, true); |
868 } else { | 868 } else { |
869 // The window manager shouldn't reparent override-redirect windows. | 869 // The window manager shouldn't reparent override-redirect windows. |
870 DLOG(ERROR) << "override-redirect window " << window_xid | 870 DLOG(ERROR) << "override-redirect window " << window_xid |
871 << "'s parent is " << window_parent | 871 << "'s parent is " << window_parent |
872 << ", rather than root window " | 872 << ", rather than root window " |
873 << x11_util::GetX11RootWindow(); | 873 << ui::GetX11RootWindow(); |
874 } | 874 } |
875 } | 875 } |
876 gdk_x11_display_ungrab(gtk_widget_get_display(toplevel)); | 876 gdk_x11_display_ungrab(gtk_widget_get_display(toplevel)); |
877 } | 877 } |
878 | 878 |
879 gfx::Rect GetWidgetRectRelativeToToplevel(GtkWidget* widget) { | 879 gfx::Rect GetWidgetRectRelativeToToplevel(GtkWidget* widget) { |
880 DCHECK(GTK_WIDGET_REALIZED(widget)); | 880 DCHECK(GTK_WIDGET_REALIZED(widget)); |
881 | 881 |
882 GtkWidget* toplevel = gtk_widget_get_toplevel(widget); | 882 GtkWidget* toplevel = gtk_widget_get_toplevel(widget); |
883 DCHECK(toplevel); | 883 DCHECK(toplevel); |
(...skipping 357 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1241 | 1241 |
1242 void DoCopy(BrowserWindow* window) { | 1242 void DoCopy(BrowserWindow* window) { |
1243 DoCutCopyPaste(window, &RenderViewHost::Copy, "copy-clipboard"); | 1243 DoCutCopyPaste(window, &RenderViewHost::Copy, "copy-clipboard"); |
1244 } | 1244 } |
1245 | 1245 |
1246 void DoPaste(BrowserWindow* window) { | 1246 void DoPaste(BrowserWindow* window) { |
1247 DoCutCopyPaste(window, &RenderViewHost::Paste, "paste-clipboard"); | 1247 DoCutCopyPaste(window, &RenderViewHost::Paste, "paste-clipboard"); |
1248 } | 1248 } |
1249 | 1249 |
1250 } // namespace gtk_util | 1250 } // namespace gtk_util |
OLD | NEW |