blob: 2fe503e4b0366302a9bb08977c3467a754892bdd (
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
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
|
// Copyright (c) 2010 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 VIEWS_CONTROLS_TABBED_PANE_H_
#define VIEWS_CONTROLS_TABBED_PANE_H_
#include "views/view.h"
namespace views {
class NativeTabbedPaneWrapper;
// The TabbedPane class is a view that shows tabs. When the user clicks on a
// tab, the associated view is displayed.
// TODO (jcampan): implement GetPreferredSize().
class TabbedPane : public View {
public:
TabbedPane();
virtual ~TabbedPane();
// An interface an object can implement to be notified about events within
// the TabbedPane.
class Listener {
public:
// Called when the tab at the specified |index| is selected by the user.
virtual void TabSelectedAt(int index) = 0;
};
void SetListener(Listener* listener);
// Returns the number of tabs.
int GetTabCount();
// Returns the index of the selected tab.
int GetSelectedTabIndex();
// Returns the contents of the selected tab.
View* GetSelectedTab();
// Adds a new tab at the end of this TabbedPane with the specified |title|.
// |contents| is the view displayed when the tab is selected and is owned by
// the TabbedPane.
void AddTab(const std::wstring& title, View* contents);
// Adds a new tab at the specified |index| with the specified |title|.
// |contents| is the view displayed when the tab is selected and is owned by
// the TabbedPane. If |select_if_first_tab| is true and the tabbed pane is
// currently empty, the new tab is selected. If you pass in false for
// |select_if_first_tab| you need to explicitly invoke SelectTabAt, otherwise
// the tabbed pane will not have a valid selection.
void AddTabAtIndex(int index,
const std::wstring& title,
View* contents,
bool select_if_first_tab);
// Removes the tab at the specified |index| and returns the associated content
// view. The caller becomes the owner of the returned view.
View* RemoveTabAtIndex(int index);
// Selects the tab at the specified |index|, which must be valid.
void SelectTabAt(int index);
Listener* listener() const { return listener_; }
// View overrides:
virtual void ViewHierarchyChanged(bool is_add, View* parent, View* child);
// Handles Ctrl+Tab and Ctrl+Shift+Tab navigation of pages.
virtual bool AcceleratorPressed(const views::Accelerator& accelerator);
virtual std::string GetClassName() const;
virtual void Layout();
virtual void Focus();
virtual void PaintFocusBorder(gfx::Canvas* canvas);
virtual bool GetAccessibleRole(AccessibilityTypes::Role* role);
NativeTabbedPaneWrapper* native_wrapper() const {
return native_tabbed_pane_;
}
protected:
// The object that actually implements the tabbed-pane.
// Protected for tests access.
NativeTabbedPaneWrapper* native_tabbed_pane_;
private:
// The tabbed-pane's class name.
static const char kViewClassName[];
// Creates the native wrapper.
void CreateWrapper();
// We support Ctrl+Tab and Ctrl+Shift+Tab to navigate tabbed option pages.
void LoadAccelerators();
// The listener we notify about tab selection changes.
Listener* listener_;
DISALLOW_COPY_AND_ASSIGN(TabbedPane);
};
} // namespace views
#endif // VIEWS_CONTROLS_TABBED_PANE_H_
|