OLD | NEW |
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 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/gtk/browser_window_gtk.h" | 5 #include "chrome/browser/gtk/browser_window_gtk.h" |
6 | 6 |
7 #include <gdk/gdkkeysyms.h> | 7 #include <gdk/gdkkeysyms.h> |
8 #include <X11/XF86keysym.h> | 8 #include <X11/XF86keysym.h> |
9 | 9 |
10 #include <string> | 10 #include <string> |
(...skipping 23 matching lines...) Expand all Loading... |
34 #include "chrome/browser/debugger/devtools_window.h" | 34 #include "chrome/browser/debugger/devtools_window.h" |
35 #include "chrome/browser/download/download_item_model.h" | 35 #include "chrome/browser/download/download_item_model.h" |
36 #include "chrome/browser/download/download_manager.h" | 36 #include "chrome/browser/download/download_manager.h" |
37 #include "chrome/browser/find_bar_controller.h" | 37 #include "chrome/browser/find_bar_controller.h" |
38 #include "chrome/browser/gtk/about_chrome_dialog.h" | 38 #include "chrome/browser/gtk/about_chrome_dialog.h" |
39 #include "chrome/browser/gtk/active_window_watcher.h" | 39 #include "chrome/browser/gtk/active_window_watcher.h" |
40 #include "chrome/browser/gtk/bookmark_bar_gtk.h" | 40 #include "chrome/browser/gtk/bookmark_bar_gtk.h" |
41 #include "chrome/browser/gtk/bookmark_manager_gtk.h" | 41 #include "chrome/browser/gtk/bookmark_manager_gtk.h" |
42 #include "chrome/browser/gtk/browser_titlebar.h" | 42 #include "chrome/browser/gtk/browser_titlebar.h" |
43 #include "chrome/browser/gtk/browser_toolbar_gtk.h" | 43 #include "chrome/browser/gtk/browser_toolbar_gtk.h" |
| 44 #include "chrome/browser/gtk/cairo_cached_surface.h" |
44 #include "chrome/browser/gtk/clear_browsing_data_dialog_gtk.h" | 45 #include "chrome/browser/gtk/clear_browsing_data_dialog_gtk.h" |
45 #include "chrome/browser/gtk/download_shelf_gtk.h" | 46 #include "chrome/browser/gtk/download_shelf_gtk.h" |
46 #include "chrome/browser/gtk/edit_search_engine_dialog.h" | 47 #include "chrome/browser/gtk/edit_search_engine_dialog.h" |
47 #include "chrome/browser/gtk/extension_shelf_gtk.h" | 48 #include "chrome/browser/gtk/extension_shelf_gtk.h" |
48 #include "chrome/browser/gtk/find_bar_gtk.h" | 49 #include "chrome/browser/gtk/find_bar_gtk.h" |
49 #include "chrome/browser/gtk/go_button_gtk.h" | 50 #include "chrome/browser/gtk/go_button_gtk.h" |
50 #include "chrome/browser/gtk/gtk_theme_provider.h" | 51 #include "chrome/browser/gtk/gtk_theme_provider.h" |
51 #include "chrome/browser/gtk/import_dialog_gtk.h" | 52 #include "chrome/browser/gtk/import_dialog_gtk.h" |
52 #include "chrome/browser/gtk/info_bubble_gtk.h" | 53 #include "chrome/browser/gtk/info_bubble_gtk.h" |
53 #include "chrome/browser/gtk/infobar_container_gtk.h" | 54 #include "chrome/browser/gtk/infobar_container_gtk.h" |
(...skipping 278 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
332 GdkEventExpose* e, | 333 GdkEventExpose* e, |
333 BrowserWindowGtk* window) { | 334 BrowserWindowGtk* window) { |
334 cairo_t* cr = gdk_cairo_create(GDK_DRAWABLE(widget->window)); | 335 cairo_t* cr = gdk_cairo_create(GDK_DRAWABLE(widget->window)); |
335 cairo_rectangle(cr, e->area.x, e->area.y, e->area.width, e->area.height); | 336 cairo_rectangle(cr, e->area.x, e->area.y, e->area.width, e->area.height); |
336 cairo_clip(cr); | 337 cairo_clip(cr); |
337 // The toolbar is supposed to blend in with the active tab, so we have to pass | 338 // The toolbar is supposed to blend in with the active tab, so we have to pass |
338 // coordinates for the IDR_THEME_TOOLBAR bitmap relative to the top of the | 339 // coordinates for the IDR_THEME_TOOLBAR bitmap relative to the top of the |
339 // tab strip. | 340 // tab strip. |
340 gfx::Point tabstrip_origin = | 341 gfx::Point tabstrip_origin = |
341 window->tabstrip()->GetTabStripOriginForWidget(widget); | 342 window->tabstrip()->GetTabStripOriginForWidget(widget); |
342 ThemeProvider* theme_provider = | 343 GtkThemeProvider* theme_provider = GtkThemeProvider::GetFrom( |
343 window->browser()->profile()->GetThemeProvider(); | 344 window->browser()->profile()); |
344 GdkPixbuf* toolbar_background = theme_provider->GetPixbufNamed( | 345 CairoCachedSurface* background = theme_provider->GetSurfaceNamed( |
345 IDR_THEME_TOOLBAR); | 346 IDR_THEME_TOOLBAR, widget); |
346 gdk_cairo_set_source_pixbuf(cr, toolbar_background, tabstrip_origin.x(), | 347 background->SetSource(cr, tabstrip_origin.x(), tabstrip_origin.y()); |
347 tabstrip_origin.y()); | |
348 // We tile the toolbar background in both directions. | 348 // We tile the toolbar background in both directions. |
349 cairo_pattern_set_extend(cairo_get_source(cr), CAIRO_EXTEND_REPEAT); | 349 cairo_pattern_set_extend(cairo_get_source(cr), CAIRO_EXTEND_REPEAT); |
350 cairo_rectangle(cr, | 350 cairo_rectangle(cr, |
351 tabstrip_origin.x(), | 351 tabstrip_origin.x(), |
352 tabstrip_origin.y(), | 352 tabstrip_origin.y(), |
353 e->area.x + e->area.width - tabstrip_origin.x(), | 353 e->area.x + e->area.width - tabstrip_origin.x(), |
354 e->area.y + e->area.height - tabstrip_origin.y()); | 354 e->area.y + e->area.height - tabstrip_origin.y()); |
355 cairo_fill(cr); | 355 cairo_fill(cr); |
356 cairo_destroy(cr); | 356 cairo_destroy(cr); |
357 | 357 |
(...skipping 231 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
589 // gtk_window_activate_key() takes care of it automatically. | 589 // gtk_window_activate_key() takes care of it automatically. |
590 if (!HandleCustomAccelerator(event->keyval, GdkModifierType(event->state), | 590 if (!HandleCustomAccelerator(event->keyval, GdkModifierType(event->state), |
591 browser_.get())) { | 591 browser_.get())) { |
592 gtk_window_activate_key(window_, event); | 592 gtk_window_activate_key(window_, event); |
593 } | 593 } |
594 } | 594 } |
595 | 595 |
596 gboolean BrowserWindowGtk::OnCustomFrameExpose(GtkWidget* widget, | 596 gboolean BrowserWindowGtk::OnCustomFrameExpose(GtkWidget* widget, |
597 GdkEventExpose* event, | 597 GdkEventExpose* event, |
598 BrowserWindowGtk* window) { | 598 BrowserWindowGtk* window) { |
599 ThemeProvider* theme_provider = | 599 GtkThemeProvider* theme_provider = GtkThemeProvider::GetFrom( |
600 window->browser()->profile()->GetThemeProvider(); | 600 window->browser()->profile()); |
601 | 601 |
602 // Draw the default background. | 602 // Draw the default background. |
603 cairo_t* cr = gdk_cairo_create(GDK_DRAWABLE(widget->window)); | 603 cairo_t* cr = gdk_cairo_create(GDK_DRAWABLE(widget->window)); |
604 cairo_rectangle(cr, event->area.x, event->area.y, event->area.width, | 604 cairo_rectangle(cr, event->area.x, event->area.y, event->area.width, |
605 event->area.height); | 605 event->area.height); |
606 cairo_clip(cr); | 606 cairo_clip(cr); |
607 | 607 |
608 int image_name; | 608 int image_name; |
609 if (window->IsActive()) { | 609 if (window->IsActive()) { |
610 image_name = window->browser()->profile()->IsOffTheRecord() ? | 610 image_name = window->browser()->profile()->IsOffTheRecord() ? |
611 IDR_THEME_FRAME_INCOGNITO : IDR_THEME_FRAME; | 611 IDR_THEME_FRAME_INCOGNITO : IDR_THEME_FRAME; |
612 } else { | 612 } else { |
613 image_name = window->browser()->profile()->IsOffTheRecord() ? | 613 image_name = window->browser()->profile()->IsOffTheRecord() ? |
614 IDR_THEME_FRAME_INCOGNITO_INACTIVE : IDR_THEME_FRAME_INACTIVE; | 614 IDR_THEME_FRAME_INCOGNITO_INACTIVE : IDR_THEME_FRAME_INACTIVE; |
615 } | 615 } |
616 GdkPixbuf* pixbuf = theme_provider->GetPixbufNamed(image_name); | 616 CairoCachedSurface* surface = theme_provider->GetSurfaceNamed( |
617 gdk_cairo_set_source_pixbuf(cr, pixbuf, 0, 0); | 617 image_name, widget); |
| 618 surface->SetSource(cr, 0, 0); |
618 cairo_pattern_set_extend(cairo_get_source(cr), CAIRO_EXTEND_REPEAT); | 619 cairo_pattern_set_extend(cairo_get_source(cr), CAIRO_EXTEND_REPEAT); |
619 cairo_rectangle(cr, event->area.x, event->area.y, | 620 cairo_rectangle(cr, event->area.x, event->area.y, |
620 event->area.width, event->area.height); | 621 event->area.width, event->area.height); |
621 cairo_fill(cr); | 622 cairo_fill(cr); |
622 | 623 |
623 if (theme_provider->HasCustomImage(IDR_THEME_FRAME_OVERLAY)) { | 624 if (theme_provider->HasCustomImage(IDR_THEME_FRAME_OVERLAY)) { |
624 GdkPixbuf* theme_overlay = theme_provider->GetPixbufNamed( | 625 CairoCachedSurface* theme_overlay = theme_provider->GetSurfaceNamed( |
625 window->IsActive() ? IDR_THEME_FRAME_OVERLAY | 626 window->IsActive() ? IDR_THEME_FRAME_OVERLAY |
626 : IDR_THEME_FRAME_OVERLAY_INACTIVE); | 627 : IDR_THEME_FRAME_OVERLAY_INACTIVE, widget); |
627 gdk_cairo_set_source_pixbuf(cr, theme_overlay, 0, 0); | 628 theme_overlay->SetSource(cr, 0, 0); |
628 cairo_paint(cr); | 629 cairo_paint(cr); |
629 } | 630 } |
630 | 631 |
631 DrawContentShadow(cr, window); | 632 DrawContentShadow(cr, window); |
632 | 633 |
633 cairo_destroy(cr); | 634 cairo_destroy(cr); |
634 | 635 |
635 if (window->UseCustomFrame() && !window->IsMaximized()) { | 636 if (window->UseCustomFrame() && !window->IsMaximized()) { |
636 static NineBox custom_frame_border( | 637 static NineBox custom_frame_border( |
637 IDR_WINDOW_TOP_LEFT_CORNER, | 638 IDR_WINDOW_TOP_LEFT_CORNER, |
638 IDR_WINDOW_TOP_CENTER, | 639 IDR_WINDOW_TOP_CENTER, |
639 IDR_WINDOW_TOP_RIGHT_CORNER, | 640 IDR_WINDOW_TOP_RIGHT_CORNER, |
640 IDR_WINDOW_LEFT_SIDE, | 641 IDR_WINDOW_LEFT_SIDE, |
641 NULL, | 642 NULL, |
642 IDR_WINDOW_RIGHT_SIDE, | 643 IDR_WINDOW_RIGHT_SIDE, |
643 IDR_WINDOW_BOTTOM_LEFT_CORNER, | 644 IDR_WINDOW_BOTTOM_LEFT_CORNER, |
644 IDR_WINDOW_BOTTOM_CENTER, | 645 IDR_WINDOW_BOTTOM_CENTER, |
645 IDR_WINDOW_BOTTOM_RIGHT_CORNER); | 646 IDR_WINDOW_BOTTOM_RIGHT_CORNER); |
646 | 647 |
647 custom_frame_border.RenderToWidget(widget); | 648 custom_frame_border.RenderToWidget(widget); |
648 } | 649 } |
649 | 650 |
650 return FALSE; // Allow subwidgets to paint. | 651 return FALSE; // Allow subwidgets to paint. |
651 } | 652 } |
652 | 653 |
653 // static | 654 // static |
654 void BrowserWindowGtk::DrawContentShadow(cairo_t* cr, | 655 void BrowserWindowGtk::DrawContentShadow(cairo_t* cr, |
655 BrowserWindowGtk* window) { | 656 BrowserWindowGtk* window) { |
656 // Draw the shadow above the toolbar. Tabs on the tabstrip will draw over us. | 657 // Draw the shadow above the toolbar. Tabs on the tabstrip will draw over us. |
657 ThemeProvider* theme_provider = | 658 GtkThemeProvider* theme_provider = GtkThemeProvider::GetFrom( |
658 window->browser()->profile()->GetThemeProvider(); | 659 window->browser()->profile()); |
659 int left_x, top_y; | 660 int left_x, top_y; |
660 gtk_widget_translate_coordinates(window->content_vbox_, | 661 gtk_widget_translate_coordinates(window->content_vbox_, |
661 GTK_WIDGET(window->window_), 0, 0, &left_x, | 662 GTK_WIDGET(window->window_), 0, 0, &left_x, |
662 &top_y); | 663 &top_y); |
663 int width = window->content_vbox_->allocation.width; | 664 int width = window->content_vbox_->allocation.width; |
664 | 665 |
665 GdkPixbuf* top_center = | 666 CairoCachedSurface* top_center = theme_provider->GetSurfaceNamed( |
666 theme_provider->GetPixbufNamed(IDR_CONTENT_TOP_CENTER); | 667 IDR_CONTENT_TOP_CENTER, window->content_vbox_); |
667 gdk_cairo_set_source_pixbuf(cr, top_center, | 668 top_center->SetSource(cr, left_x, top_y - kContentShadowThickness); |
668 left_x, top_y - kContentShadowThickness); | |
669 cairo_pattern_set_extend(cairo_get_source(cr), CAIRO_EXTEND_REPEAT); | 669 cairo_pattern_set_extend(cairo_get_source(cr), CAIRO_EXTEND_REPEAT); |
670 cairo_rectangle(cr, left_x, top_y - kContentShadowThickness, width, | 670 cairo_rectangle(cr, left_x, top_y - kContentShadowThickness, width, |
671 gdk_pixbuf_get_height(top_center)); | 671 top_center->Height()); |
672 cairo_fill(cr); | 672 cairo_fill(cr); |
673 | 673 |
674 // Only draw the rest of the shadow if the user has the custom frame enabled. | 674 // Only draw the rest of the shadow if the user has the custom frame enabled. |
675 if (!window->UseCustomFrame()) | 675 if (!window->UseCustomFrame()) |
676 return; | 676 return; |
677 | 677 |
678 // The top left corner has a width of 3 pixels. On Windows, the last column | 678 // The top left corner has a width of 3 pixels. On Windows, the last column |
679 // of pixels overlap the toolbar. We just crop it off on Linux. The top | 679 // of pixels overlap the toolbar. We just crop it off on Linux. The top |
680 // corners extend to the base of the toolbar (one pixel above the dividing | 680 // corners extend to the base of the toolbar (one pixel above the dividing |
681 // line). | 681 // line). |
682 int right_x = left_x + width; | 682 int right_x = left_x + width; |
683 GdkPixbuf* top_left = | 683 CairoCachedSurface* top_left = theme_provider->GetSurfaceNamed( |
684 theme_provider->GetPixbufNamed(IDR_CONTENT_TOP_LEFT_CORNER); | 684 IDR_CONTENT_TOP_LEFT_CORNER, window->content_vbox_); |
685 gdk_cairo_set_source_pixbuf(cr, top_left, | 685 top_left->SetSource( |
686 left_x - kContentShadowThickness, top_y - kContentShadowThickness); | 686 cr, left_x - kContentShadowThickness, top_y - kContentShadowThickness); |
687 // The toolbar is shorter in location bar only mode so clip the image to the | 687 // The toolbar is shorter in location bar only mode so clip the image to the |
688 // height of the toolbar + the amount of shadow above the toolbar. | 688 // height of the toolbar + the amount of shadow above the toolbar. |
689 int top_corner_height = | 689 int top_corner_height = |
690 window->toolbar_->widget()->allocation.height + kContentShadowThickness; | 690 window->toolbar_->widget()->allocation.height + kContentShadowThickness; |
691 cairo_rectangle(cr, | 691 cairo_rectangle(cr, |
692 left_x - kContentShadowThickness, | 692 left_x - kContentShadowThickness, |
693 top_y - kContentShadowThickness, | 693 top_y - kContentShadowThickness, |
694 kContentShadowThickness, | 694 kContentShadowThickness, |
695 top_corner_height); | 695 top_corner_height); |
696 cairo_fill(cr); | 696 cairo_fill(cr); |
697 | 697 |
698 // Likewise, we crop off the left column of pixels for the top right corner. | 698 // Likewise, we crop off the left column of pixels for the top right corner. |
699 GdkPixbuf* top_right = | 699 CairoCachedSurface* top_right = theme_provider->GetSurfaceNamed( |
700 theme_provider->GetPixbufNamed(IDR_CONTENT_TOP_RIGHT_CORNER); | 700 IDR_CONTENT_TOP_RIGHT_CORNER, window->content_vbox_); |
701 gdk_cairo_set_source_pixbuf(cr, top_right, | 701 top_right->SetSource(cr, right_x - 1, top_y - kContentShadowThickness); |
702 right_x - 1, top_y - kContentShadowThickness); | |
703 cairo_rectangle(cr, | 702 cairo_rectangle(cr, |
704 right_x, | 703 right_x, |
705 top_y - kContentShadowThickness, | 704 top_y - kContentShadowThickness, |
706 kContentShadowThickness, | 705 kContentShadowThickness, |
707 top_corner_height); | 706 top_corner_height); |
708 cairo_fill(cr); | 707 cairo_fill(cr); |
709 | 708 |
710 // Fill in the sides. As above, we only draw 2 of the 3 columns on Linux. | 709 // Fill in the sides. As above, we only draw 2 of the 3 columns on Linux. |
711 int height = window->content_vbox_->allocation.height; | 710 int height = window->content_vbox_->allocation.height; |
712 int bottom_y = top_y + height; | 711 int bottom_y = top_y + height; |
713 // |side_y| is where to start drawing the side shadows. The top corners draw | 712 // |side_y| is where to start drawing the side shadows. The top corners draw |
714 // the sides down to the bottom of the toolbar. | 713 // the sides down to the bottom of the toolbar. |
715 int side_y = top_y - kContentShadowThickness + top_corner_height; | 714 int side_y = top_y - kContentShadowThickness + top_corner_height; |
716 // |side_height| is how many pixels to draw for the side borders. We do one | 715 // |side_height| is how many pixels to draw for the side borders. We do one |
717 // pixel before the bottom of the web contents because that extra pixel is | 716 // pixel before the bottom of the web contents because that extra pixel is |
718 // drawn by the bottom corners. | 717 // drawn by the bottom corners. |
719 int side_height = bottom_y - side_y - 1; | 718 int side_height = bottom_y - side_y - 1; |
720 if (side_height > 0) { | 719 if (side_height > 0) { |
721 GdkPixbuf* left = theme_provider->GetPixbufNamed(IDR_CONTENT_LEFT_SIDE); | 720 CairoCachedSurface* left = theme_provider->GetSurfaceNamed( |
722 gdk_cairo_set_source_pixbuf(cr, left, | 721 IDR_CONTENT_LEFT_SIDE, window->content_vbox_); |
723 left_x - kContentShadowThickness, side_y); | 722 left->SetSource(cr, left_x - kContentShadowThickness, side_y); |
724 cairo_pattern_set_extend(cairo_get_source(cr), CAIRO_EXTEND_REPEAT); | 723 cairo_pattern_set_extend(cairo_get_source(cr), CAIRO_EXTEND_REPEAT); |
725 cairo_rectangle(cr, | 724 cairo_rectangle(cr, |
726 left_x - kContentShadowThickness, | 725 left_x - kContentShadowThickness, |
727 side_y, | 726 side_y, |
728 kContentShadowThickness, | 727 kContentShadowThickness, |
729 side_height); | 728 side_height); |
730 cairo_fill(cr); | 729 cairo_fill(cr); |
731 | 730 |
732 GdkPixbuf* right = theme_provider->GetPixbufNamed(IDR_CONTENT_RIGHT_SIDE); | 731 CairoCachedSurface* right = theme_provider->GetSurfaceNamed( |
733 gdk_cairo_set_source_pixbuf(cr, right, right_x - 1, side_y); | 732 IDR_CONTENT_RIGHT_SIDE, window->content_vbox_); |
| 733 right->SetSource(cr, right_x - 1, side_y); |
734 cairo_pattern_set_extend(cairo_get_source(cr), CAIRO_EXTEND_REPEAT); | 734 cairo_pattern_set_extend(cairo_get_source(cr), CAIRO_EXTEND_REPEAT); |
735 cairo_rectangle(cr, | 735 cairo_rectangle(cr, |
736 right_x, | 736 right_x, |
737 side_y, | 737 side_y, |
738 kContentShadowThickness, | 738 kContentShadowThickness, |
739 side_height); | 739 side_height); |
740 cairo_fill(cr); | 740 cairo_fill(cr); |
741 } | 741 } |
742 | 742 |
743 // Draw the bottom corners. The bottom corners also draw the bottom row of | 743 // Draw the bottom corners. The bottom corners also draw the bottom row of |
744 // pixels of the side shadows. | 744 // pixels of the side shadows. |
745 GdkPixbuf* bottom_left = | 745 CairoCachedSurface* bottom_left = theme_provider->GetSurfaceNamed( |
746 theme_provider->GetPixbufNamed(IDR_CONTENT_BOTTOM_LEFT_CORNER); | 746 IDR_CONTENT_BOTTOM_LEFT_CORNER, window->content_vbox_); |
747 gdk_cairo_set_source_pixbuf(cr, bottom_left, | 747 bottom_left->SetSource(cr, left_x - kContentShadowThickness, bottom_y - 1); |
748 left_x - kContentShadowThickness, bottom_y - 1); | |
749 cairo_paint(cr); | 748 cairo_paint(cr); |
750 | 749 |
751 GdkPixbuf* bottom_right = | 750 CairoCachedSurface* bottom_right = theme_provider->GetSurfaceNamed( |
752 theme_provider->GetPixbufNamed(IDR_CONTENT_BOTTOM_RIGHT_CORNER); | 751 IDR_CONTENT_BOTTOM_RIGHT_CORNER, window->content_vbox_); |
753 gdk_cairo_set_source_pixbuf(cr, bottom_right, | 752 bottom_right->SetSource(cr, right_x - 1, bottom_y - 1); |
754 right_x - 1, bottom_y - 1); | |
755 cairo_paint(cr); | 753 cairo_paint(cr); |
756 | 754 |
757 // Finally, draw the bottom row. Since we don't overlap the contents, we clip | 755 // Finally, draw the bottom row. Since we don't overlap the contents, we clip |
758 // the top row of pixels. | 756 // the top row of pixels. |
759 GdkPixbuf* bottom = | 757 CairoCachedSurface* bottom = theme_provider->GetSurfaceNamed( |
760 theme_provider->GetPixbufNamed(IDR_CONTENT_BOTTOM_CENTER); | 758 IDR_CONTENT_BOTTOM_CENTER, window->content_vbox_); |
761 gdk_cairo_set_source_pixbuf(cr, bottom, | 759 bottom->SetSource(cr, left_x + 1, bottom_y - 1); |
762 left_x + 1, bottom_y - 1); | |
763 cairo_pattern_set_extend(cairo_get_source(cr), CAIRO_EXTEND_REPEAT); | 760 cairo_pattern_set_extend(cairo_get_source(cr), CAIRO_EXTEND_REPEAT); |
764 cairo_rectangle(cr, | 761 cairo_rectangle(cr, |
765 left_x + 1, | 762 left_x + 1, |
766 bottom_y, | 763 bottom_y, |
767 width - 2, | 764 width - 2, |
768 kContentShadowThickness); | 765 kContentShadowThickness); |
769 cairo_fill(cr); | 766 cairo_fill(cr); |
770 } | 767 } |
771 | 768 |
772 void BrowserWindowGtk::Show() { | 769 void BrowserWindowGtk::Show() { |
(...skipping 1383 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2156 // special-case the ones where the custom frame should be used. These names | 2153 // special-case the ones where the custom frame should be used. These names |
2157 // are taken from the WMs' source code. | 2154 // are taken from the WMs' source code. |
2158 return (wm_name == "Blackbox" || | 2155 return (wm_name == "Blackbox" || |
2159 wm_name == "compiz" || | 2156 wm_name == "compiz" || |
2160 wm_name == "e16" || // Enlightenment DR16 | 2157 wm_name == "e16" || // Enlightenment DR16 |
2161 wm_name == "KWin" || | 2158 wm_name == "KWin" || |
2162 wm_name == "Metacity" || | 2159 wm_name == "Metacity" || |
2163 wm_name == "Openbox" || | 2160 wm_name == "Openbox" || |
2164 wm_name == "Xfwm4"); | 2161 wm_name == "Xfwm4"); |
2165 } | 2162 } |
OLD | NEW |