| Index: chrome/browser/ui/libgtk2ui/gtk2_border.h
|
| diff --git a/chrome/browser/ui/libgtk2ui/gtk2_border.h b/chrome/browser/ui/libgtk2ui/gtk2_border.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..5d789ba7ed6956cbf10d4564321da4c85d872f84
|
| --- /dev/null
|
| +++ b/chrome/browser/ui/libgtk2ui/gtk2_border.h
|
| @@ -0,0 +1,60 @@
|
| +// Copyright 2014 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#ifndef CHROME_BROWSER_UI_LIBGTK2UI_GTK2_BORDER_H_
|
| +#define CHROME_BROWSER_UI_LIBGTK2UI_GTK2_BORDER_H_
|
| +
|
| +#include "ui/gfx/image/image_skia.h"
|
| +#include "ui/views/border.h"
|
| +
|
| +namespace gfx {
|
| +class Canvas;
|
| +}
|
| +
|
| +namespace views {
|
| +class CustomButton;
|
| +}
|
| +
|
| +namespace libgtk2ui {
|
| +class Gtk2UI;
|
| +
|
| +// Draws a gtk button border, and manages the memory of the resulting pixbufs.
|
| +class Gtk2Border : public views::Border {
|
| + public:
|
| + Gtk2Border(Gtk2UI* gtk2_ui,
|
| + views::CustomButton* owning_button,
|
| + views::Border* border);
|
| + virtual ~Gtk2Border();
|
| +
|
| + // Called on theme changes. We invalidate the layout, drop our cached images,
|
| + // and update our GTK state.
|
| + void InvalidateAndSetUsesGtk(bool use_gtk);
|
| +
|
| + // Overridden from views::Border:
|
| + virtual void Paint(const views::View& view, gfx::Canvas* canvas) OVERRIDE;
|
| + virtual gfx::Insets GetInsets() const OVERRIDE;
|
| + virtual gfx::Size GetMinimumSize() const OVERRIDE;
|
| +
|
| + private:
|
| + Gtk2UI* gtk2_ui_;
|
| + bool use_gtk_;
|
| +
|
| + gfx::ImageSkia hovered_;
|
| + gfx::ImageSkia pressed_;
|
| +
|
| + // The view to which we are a border. We keep track of this so that we can
|
| + // force invalidate the layout on theme changes.
|
| + views::CustomButton* owning_button_;
|
| +
|
| + // Since we don't want to expose the concept of whether we're using a GTK
|
| + // theme down to the cross platform views layer, we keep a normal Border and
|
| + // delegate to it whenever we aren't in GTK theme mode.
|
| + scoped_ptr<views::Border> border_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(Gtk2Border);
|
| +};
|
| +
|
| +} // namespace libgtk2ui
|
| +
|
| +#endif // CHROME_BROWSER_UI_LIBGTK2UI_GTK2_BORDER_H_
|
|
|