blob: 1c0e5074bff86997058811cf0747534d137dbbcc (
plain)
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
|
// Copyright 2013 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 UI_VIEWS_BUBBLE_INFO_BUBBLE_H_
#define UI_VIEWS_BUBBLE_INFO_BUBBLE_H_
#include "base/compiler_specific.h"
#include "base/macros.h"
#include "base/strings/string16.h"
#include "ui/views/bubble/bubble_dialog_delegate.h"
namespace views {
class InfoBubbleFrame;
// Class to create and manage an information bubble for errors or tooltips.
class InfoBubble : public BubbleDialogDelegateView {
public:
InfoBubble(View* anchor, const base::string16& message);
~InfoBubble() override;
// Shows the bubble. |widget_| will be NULL until this is called.
void Show();
// Hides and closes the bubble.
void Hide();
// BubbleDialogDelegateView:
NonClientFrameView* CreateNonClientFrameView(Widget* widget) override;
gfx::Size CalculatePreferredSize() const override;
void OnWidgetDestroyed(Widget* widget) override;
void OnWidgetBoundsChanged(Widget* widget,
const gfx::Rect& new_bounds) override;
int GetDialogButtons() const override;
View* anchor() { return anchor_; }
const View* anchor() const { return anchor_; }
void set_preferred_width(int preferred_width) {
preferred_width_ = preferred_width;
}
private:
// Updates the position of the bubble.
void UpdatePosition();
Widget* widget_; // Weak, may be NULL.
View* const anchor_; // Weak.
InfoBubbleFrame* frame_; // Weak, owned by widget.
// The width this bubble prefers to be. Default is 0 (no preference).
int preferred_width_;
DISALLOW_COPY_AND_ASSIGN(InfoBubble);
};
} // namespace views
#endif // UI_VIEWS_BUBBLE_INFO_BUBBLE_H_
|