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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
|
// Copyright (c) 2006-2008 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_VIEWS_BASE_BUTTON_H__
#define CHROME_VIEWS_BASE_BUTTON_H__
#include "chrome/common/animation.h"
#include "chrome/views/event.h"
#include "chrome/views/view.h"
class OSExchangeData;
class ThrobAnimation;
namespace ChromeViews {
class MouseEvent;
////////////////////////////////////////////////////////////////////////////////
//
// BaseButton
//
// A base button class that shares common button functionality between various
// specializations.
//
////////////////////////////////////////////////////////////////////////////////
class BaseButton : public View,
public AnimationDelegate {
public:
// Possible states
typedef enum ButtonState { BS_NORMAL = 0,
BS_HOT = 1,
BS_PUSHED = 2,
BS_DISABLED = 3};
static const int kButtonStateCount = 4;
virtual ~BaseButton();
// Set / test whether the MenuButton is enabled.
virtual void SetEnabled(bool f);
virtual bool IsEnabled() const;
// Set / test whether the button is hot-tracked.
void SetHotTracked(bool f);
bool IsHotTracked() const;
// Set how long the hover animation will last for.
void SetAnimationDuration(int duration);
// Starts throbbing. See HoverAnimation for a description of cycles_til_stop.
void StartThrobbing(int cycles_til_stop);
// Returns whether the button is pushed.
bool IsPushed() const;
virtual bool GetTooltipText(int x, int y, std::wstring* tooltip);
void SetTooltipText(const std::wstring& tooltip);
// Overridden from View to take into account the enabled state.
virtual bool IsFocusable() const;
virtual bool AcceleratorPressed(const Accelerator& accelerator);
// Overridden from AnimationDelegate to advance the hover state.
virtual void AnimationProgressed(const Animation* animation);
// Returns a string containing the mnemonic, or the keyboard shortcut.
bool GetAccessibleKeyboardShortcut(std::wstring* shortcut);
// Returns a brief, identifying string, containing a unique, readable name.
bool GetAccessibleName(std::wstring* name);
// Assigns a keyboard shortcut string description.
void SetAccessibleKeyboardShortcut(const std::wstring& shortcut);
// Assigns an accessible string name.
void SetAccessibleName(const std::wstring& name);
//
// These methods are overriden to implement a simple push button
// behavior
virtual bool OnMousePressed(const ChromeViews::MouseEvent& e);
virtual bool OnMouseDragged(const ChromeViews::MouseEvent& e);
virtual void OnMouseReleased(const ChromeViews::MouseEvent& e,
bool canceled);
virtual void OnMouseMoved(const ChromeViews::MouseEvent& e);
virtual void OnMouseEntered(const ChromeViews::MouseEvent& e);
virtual void OnMouseExited(const ChromeViews::MouseEvent& e);
virtual bool OnKeyPressed(const KeyEvent& e);
virtual bool OnKeyReleased(const KeyEvent& e);
class ButtonListener {
public:
//
// This is invoked once the button is released use BaseButton::GetTag()
// to find out which button has been pressed.
//
virtual void ButtonPressed(BaseButton* sender) = 0;
};
//
// The the listener, the object that receives a notification when this
// button is pressed. tag is any int value to uniquely identify this
// button.
virtual void SetListener(ButtonListener *l, int tag);
//
// Return the button tag as set by SetListener()
virtual int GetTag();
//
// Cause the button to notify the listener that a click occured.
virtual void NotifyClick(int mouse_event_flags);
// Valid when the listener is notified. Contains the event flags from the
// mouse event, or 0 if not invoked from a mouse event.
int mouse_event_flags() { return mouse_event_flags_; }
//
// Get the state.
//
int GetState() const {
return state_;
}
virtual void Paint(ChromeCanvas* canvas);
// Variant of paint that allows you to specify whether the paint is for a
// drag operation. This may be used during drag and drop to get a
// representation of this button suitable for drag and drop.
virtual void Paint(ChromeCanvas* canvas, bool for_drag);
protected:
BaseButton();
// Returns true if the event is one that can trigger notifying the listener.
// This implementation returns true if the left mouse button is down.
virtual bool IsTriggerableEvent(const ChromeViews::MouseEvent& e);
//
// Set the state. If the state is different, causes the button
// to be repainted
//
virtual void SetState(ButtonState new_state);
virtual void OnDragDone();
// Overriden to reset the state to normal (as long as we're not disabled).
// This ensures we don't get stuck in a down state if on click our ancestor
// is removed.
virtual void ViewHierarchyChanged(bool is_add, View *parent, View *child);
// tooltip text storage
std::wstring tooltip_text_;
// storage of strings needed for accessibility
std::wstring accessible_shortcut_;
std::wstring accessible_name_;
// The button state (defined in implementation)
int state_;
// Hover animation.
scoped_ptr<ThrobAnimation> hover_animation_;
private:
DISALLOW_EVIL_CONSTRUCTORS(BaseButton);
// The current listener
ButtonListener* listener_;
// tag storage
int tag_;
// See description in mouse_event_flags().
int mouse_event_flags_;
// Should we animate when the state changes? Defaults to true, but false while
// throbbing.
bool animate_on_state_change_;
};
} // namespace
#endif // CHROME_VIEWS_BASE_BUTTON_H__
|