diff options
Diffstat (limited to 'chrome/browser/gtk/tabs')
-rw-r--r-- | chrome/browser/gtk/tabs/tab_strip_gtk.cc | 14 | ||||
-rw-r--r-- | chrome/browser/gtk/tabs/tab_strip_gtk.h | 8 |
2 files changed, 18 insertions, 4 deletions
diff --git a/chrome/browser/gtk/tabs/tab_strip_gtk.cc b/chrome/browser/gtk/tabs/tab_strip_gtk.cc index 2c75bed..cc07a98 100644 --- a/chrome/browser/gtk/tabs/tab_strip_gtk.cc +++ b/chrome/browser/gtk/tabs/tab_strip_gtk.cc @@ -11,6 +11,7 @@ #include "base/gfx/gtk_util.h" #include "base/gfx/point.h" #include "chrome/browser/browser.h" +#include "chrome/browser/browser_theme_provider.h" #include "chrome/browser/gtk/custom_button.h" #include "chrome/browser/gtk/tabs/dragged_tab_controller_gtk.h" #include "chrome/browser/tab_contents/tab_contents.h" @@ -449,13 +450,13 @@ TabStripGtk::~TabStripGtk() { tab_data_.clear(); } -void TabStripGtk::Init(int width) { - ResourceBundle &rb = ResourceBundle::GetSharedInstance(); +void TabStripGtk::Init(int width, Profile* profile) { + ThemeProvider* theme_provider = profile->GetThemeProvider(); model_->AddObserver(this); if (!background) { - background = rb.GetBitmapNamed(IDR_WINDOW_TOP_CENTER); + background = theme_provider->GetBitmapNamed(IDR_THEME_FRAME); } tabstrip_.Own(gtk_fixed_new()); @@ -993,6 +994,8 @@ gboolean TabStripGtk::OnExpose(GtkWidget* widget, GdkEventExpose* event, event->area.height = tabstrip->bounds_.height(); gdk_region_union_with_rect(event->region, &event->area); + tabstrip->PaintBackground(event); + // Paint the New Tab button. gtk_container_propagate_expose(GTK_CONTAINER(tabstrip->tabstrip_.get()), tabstrip->newtab_button_.get()->widget(), event); @@ -1056,6 +1059,11 @@ void TabStripGtk::OnNewTabClicked(GtkWidget* widget, TabStripGtk* tabstrip) { tabstrip->model_->delegate()->AddBlankTab(true); } +void TabStripGtk::PaintBackground(GdkEventExpose* event) { + ChromeCanvasPaint canvas(event); + canvas.TileImageInt(*background, 0, 0, bounds_.width(), bounds_.height()); +} + void TabStripGtk::SetTabBounds(TabGtk* tab, const gfx::Rect& bounds) { tab->SetBounds(bounds); gtk_fixed_move(GTK_FIXED(tabstrip_.get()), tab->widget(), diff --git a/chrome/browser/gtk/tabs/tab_strip_gtk.h b/chrome/browser/gtk/tabs/tab_strip_gtk.h index d79ed11..d5b1244 100644 --- a/chrome/browser/gtk/tabs/tab_strip_gtk.h +++ b/chrome/browser/gtk/tabs/tab_strip_gtk.h @@ -26,7 +26,10 @@ class TabStripGtk : public TabStripModelObserver, virtual ~TabStripGtk(); // Initialize and load the TabStrip into a container. - void Init(int width); + // TODO(jhawkins): We have to pass in |profile| in order to get a pointer to + // the theme provider. In views, all instances of views::View have access to + // the theme provider. + void Init(int width, Profile* profile); void AddTabStripToBox(GtkWidget* box); void Show(); @@ -112,6 +115,9 @@ class TabStripGtk : public TabStripModelObserver, // Handles the clicked signal from the new tab button. static void OnNewTabClicked(GtkWidget* widget, TabStripGtk* tabstrip); + // Renders the tabstrip background. + void PaintBackground(GdkEventExpose* event); + // Sets the bounds of the tab and moves the tab widget to those bounds. void SetTabBounds(TabGtk* tab, const gfx::Rect& bounds); |