1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
// Copyright (c) 2009 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_GTK_CUSTOM_BUTTON_H_
#define CHROME_BROWSER_GTK_CUSTOM_BUTTON_H_
#include <gtk/gtk.h>
#include <string>
#include "base/gfx/rect.h"
#include "base/scoped_ptr.h"
#include "chrome/common/owned_widget_gtk.h"
class NineBox;
// These classes implement two kinds of custom-drawn buttons. They're
// used on the toolbar and the bookmarks bar.
// CustomDrawButtonBase provides the base for building a custom drawn button.
// It handles managing the pixbufs containing all the static images used to draw
// the button. It also manages painting these pixbufs.
class CustomDrawButtonBase {
public:
CustomDrawButtonBase(int normal_id,
int active_id,
int highlight_id,
int depressed_id);
~CustomDrawButtonBase();
GdkPixbuf* pixbufs(int i) const { return pixbufs_[i]; }
gboolean OnExpose(GtkWidget* widget, GdkEventExpose* e);
void set_paint_override(int state) { paint_override_ = state; }
private:
// We store one GdkPixbuf* for each possible state of the button;
// INSENSITIVE is the last available state;
GdkPixbuf* pixbufs_[GTK_STATE_INSENSITIVE + 1];
// If non-negative, the state to paint the button.
int paint_override_;
DISALLOW_COPY_AND_ASSIGN(CustomDrawButtonBase);
};
// CustomDrawButton is a plain button where all its various states are drawn
// with static images.
class CustomDrawButton {
public:
// The constructor takes 4 resource ids. If a resource doesn't exist for a
// button, pass in 0.
CustomDrawButton(int normal_id,
int active_id,
int highlight_id,
int depressed_id);
explicit CustomDrawButton(const std::string& filename);
~CustomDrawButton();
GtkWidget* widget() const { return widget_.get(); }
gfx::Rect bounds() const {
return gfx::Rect(widget_.get()->allocation.x,
widget_.get()->allocation.y,
widget_.get()->allocation.width,
widget_.get()->allocation.height);
}
int width() const { return widget_.get()->allocation.width; }
// Set the state to draw. We will paint the widget as if it were in this
// state.
void SetPaintOverride(GtkStateType state);
// Resume normal drawing of the widget's state.
void UnsetPaintOverride();
// Returns a standard close button.
static CustomDrawButton* CloseButton();
private:
// Callback for expose, used to draw the custom graphics.
static gboolean OnExpose(GtkWidget* widget,
GdkEventExpose* e,
CustomDrawButton* obj);
// The actual button widget.
OwnedWidgetGtk widget_;
CustomDrawButtonBase button_base_;
DISALLOW_COPY_AND_ASSIGN(CustomDrawButton);
};
#endif // CHROME_BROWSER_GTK_CUSTOM_BUTTON_H_
|