|
JavaTM 2 Platform Std. Ed. v1.3 |
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object | +--java.awt.Component | +--java.awt.Container | +--javax.swing.JComponent | +--javax.swing.JTabbedPane
A component that lets the user switch between a group of components by clicking on a tab with a given title and/or icon. For examples and information on using tabbed panes see How to Use Tabbed Panes, a section in The Java Tutorial.
Tabs/components are added to a TabbedPane
object by using the
addTab and
insertTab methods. A tab is represented by an index corresponding
to the position it was added in, where the first tab has an index equal to 0
and the last tab has an index equal to the tab count minus 1.
The TabbedPane
uses a SingleSelectionModel
to represent the set
of tab indices and the currently selected index. If the tab count
is greater than 0, then there will always be a selected index, which
by default will be initialized to the first tab. If the tab count is
0, then the selected index will be -1.
For the keyboard keys used by this component in the standard Look and Feel (L&F) renditions, see the JTabbedPane key assignments.
Warning: Serialized objects of this class will not be compatible with future Swing releases. The current serialization support is appropriate for short term storage or RMI between applications running the same version of Swing. A future release of Swing will provide support for long term persistence.
SingleSelectionModel
, Serialized FormInner Class Summary | |
protected class |
JTabbedPane.AccessibleJTabbedPane
This class implements accessibility support for the JTabbedPane class. |
protected class |
JTabbedPane.ModelListener
We pass ModelChanged events along to the listeners with
the tabbedpane (instead of the model itself) as the event source. |
Inner classes inherited from class javax.swing.JComponent |
JComponent.AccessibleJComponent |
Inner classes inherited from class java.awt.Container |
Container.AccessibleAWTContainer |
Inner classes inherited from class java.awt.Component |
Component.AccessibleAWTComponent |
Field Summary | |
protected ChangeEvent |
changeEvent
Only one ChangeEvent is needed per TabPane
instance since the
event's only (read-only) state is the source property. |
protected ChangeListener |
changeListener
The changeListener is the listener we add to the model. |
protected SingleSelectionModel |
model
The default selection model |
protected int |
tabPlacement
Where the tabs are placed. |
Fields inherited from class javax.swing.JComponent |
accessibleContext, listenerList, TOOL_TIP_TEXT_KEY, ui, UNDEFINED_CONDITION, WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, WHEN_FOCUSED, WHEN_IN_FOCUSED_WINDOW |
Fields inherited from class java.awt.Component |
BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENT |
Fields inherited from interface javax.swing.SwingConstants |
BOTTOM, CENTER, EAST, HORIZONTAL, LEADING, LEFT, NORTH, NORTH_EAST, NORTH_WEST, RIGHT, SOUTH, SOUTH_EAST, SOUTH_WEST, TOP, TRAILING, VERTICAL, WEST |
Fields inherited from interface java.awt.image.ImageObserver |
ABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH |
Constructor Summary | |
JTabbedPane()
Creates an empty TabbedPane . |
|
JTabbedPane(int tabPlacement)
Creates an empty TabbedPane with the specified tab placement
of either: TOP, BOTTOM, LEFT, or RIGHT. |
Method Summary | |
Component |
add(Component component)
Adds a component with a tab title defaulting to
the name of the component. |
Component |
add(Component component,
int index)
Adds a component at the specified tab index with a tab
title defaulting to the name of the component. |
void |
add(Component component,
Object constraints)
Adds a component to the tabbed pane. |
void |
add(Component component,
Object constraints,
int index)
Adds a component at the specified tab index. |
Component |
add(String title,
Component component)
Adds a component with the specified tab title. |
void |
addChangeListener(ChangeListener l)
Adds a ChangeListener to this tabbedpane. |
void |
addTab(String title,
Component component)
Adds a component represented by a title
and no icon. |
void |
addTab(String title,
Icon icon,
Component component)
Adds a component represented by a title and/or
icon ,
either of which can be null . |
void |
addTab(String title,
Icon icon,
Component component,
String tip)
Adds a component and tip
represented by a title
and/or icon , either of which can be null . |
protected ChangeListener |
createChangeListener()
Subclasses that want to handle ChangeEvents differently
can override this to return a subclass of ModelListener or
another ChangeListener implementation. |
protected void |
fireStateChanged()
Send a ChangeEvent , whose source is this tabbedpane, to
each listener. |
AccessibleContext |
getAccessibleContext()
Gets the AccessibleContext associated with this JTabbedPane. |
Color |
getBackgroundAt(int index)
Returns the tab background color at index . |
Rectangle |
getBoundsAt(int index)
Returns the tab bounds at index . |
Component |
getComponentAt(int index)
Returns the component at index . |
Icon |
getDisabledIconAt(int index)
Returns the tab disabled icon at index . |
Color |
getForegroundAt(int index)
Returns the tab foreground color at index . |
Icon |
getIconAt(int index)
Returns the tab icon at index . |
SingleSelectionModel |
getModel()
Returns the model associated with this tabbedpane. |
Component |
getSelectedComponent()
Returns the currently selected component for this tabbedpane. |
int |
getSelectedIndex()
Returns the currently selected index for this tabbedpane. |
int |
getTabCount()
Returns the number of tabs in this tabbedpane . |
int |
getTabPlacement()
Returns the placement of the tabs for this tabbedpane. |
int |
getTabRunCount()
Returns the number of tab runs currently used to display the tabs. |
String |
getTitleAt(int index)
Returns the tab title at index . |
String |
getToolTipText(MouseEvent event)
Returns the tooltip text for the component determined by the mouse event location. |
String |
getToolTipTextAt(int index)
Returns the tab tooltip text at index . |
TabbedPaneUI |
getUI()
Returns the UI object which implements the L&F for this component. |
String |
getUIClassID()
Returns the name of the UI class that implements the L&F for this component. |
int |
indexOfComponent(Component component)
Returns the index of the tab for the specified component. |
int |
indexOfTab(Icon icon)
Returns the first tab index with a given icon ,
or -1 if no tab has this icon. |
int |
indexOfTab(String title)
Returns the first tab index with a given title , or
-1 if no tab has this title. |
void |
insertTab(String title,
Icon icon,
Component component,
String tip,
int index)
Inserts a component , at index ,
represented by a
title and/or icon , either of which may be
null . |
boolean |
isEnabledAt(int index)
Returns whether or not the tab at index is
currently enabled. |
protected String |
paramString()
Returns a string representation of this JTabbedPane . |
void |
remove(Component component)
Removes the tab which corresponds to the specified component. |
void |
remove(int index)
Removes the tab and component which corresponds to the specified index. |
void |
removeAll()
Removes all the tabs and their corresponding components from the tabbedpane . |
void |
removeChangeListener(ChangeListener l)
Removes a ChangeListener from this tabbedpane. |
void |
removeTabAt(int index)
Removes the tab at index . |
void |
setBackgroundAt(int index,
Color background)
Sets the background color at index to
background
which can be null , in which case the tab's background color
will default to the background color of the tabbedpane . |
void |
setComponentAt(int index,
Component component)
Sets the component at index to component . |
void |
setDisabledIconAt(int index,
Icon disabledIcon)
Sets the disabled icon at index to icon
which can be null . |
void |
setEnabledAt(int index,
boolean enabled)
Sets whether or not the tab at index is enabled. |
void |
setForegroundAt(int index,
Color foreground)
Sets the foreground color at index to
foreground which can be
null , in which case the tab's foreground color
will default to the foreground color of this tabbedpane . |
void |
setIconAt(int index,
Icon icon)
Sets the icon at index to icon which can be
null . |
void |
setModel(SingleSelectionModel model)
Sets the model to be used with this tabbedpane. |
void |
setSelectedComponent(Component c)
Sets the selected component for this tabbedpane. |
void |
setSelectedIndex(int index)
Sets the selected index for this tabbedpane. |
void |
setTabPlacement(int tabPlacement)
Sets the tab placement for this tabbedpane. |
void |
setTitleAt(int index,
String title)
Sets the title at index to title which
can be null . |
void |
setToolTipTextAt(int index,
String toolTipText)
Sets the tooltip text at index to toolTipText
which can be null . |
void |
setUI(TabbedPaneUI ui)
Sets the UI object which implements the L&F for this component. |
void |
updateUI()
Notification from the UIManager that the L&F has changed. |
Methods inherited from class java.awt.Container |
addContainerListener, addImpl, countComponents, deliverEvent, doLayout, findComponentAt, findComponentAt, getComponent, getComponentAt, getComponentAt, getComponentCount, getComponents, getLayout, insets, invalidate, isAncestorOf, layout, list, list, locate, minimumSize, paintComponents, preferredSize, printComponents, processContainerEvent, processEvent, removeContainerListener, setLayout, validate, validateTree |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Field Detail |
protected int tabPlacement
setTabPlacement(int)
protected SingleSelectionModel model
protected ChangeListener changeListener
protected transient ChangeEvent changeEvent
ChangeEvent
is needed per TabPane
instance since the
event's only (read-only) state is the source property. The source
of events generated here is always "this".Constructor Detail |
public JTabbedPane()
TabbedPane
. The default
tab placement is TOP.addTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String)
public JTabbedPane(int tabPlacement)
TabbedPane
with the specified tab placement
of either: TOP, BOTTOM, LEFT, or RIGHT.tabPlacement
- the placement for the tabs relative to the contentaddTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String)
Method Detail |
public TabbedPaneUI getUI()
setUI(javax.swing.plaf.TabbedPaneUI)
public void setUI(TabbedPaneUI ui)
ui
- the new UI objectUIDefaults.getUI(javax.swing.JComponent)
public void updateUI()
UIManager
that the L&F has changed.
Called to replace the UI with the latest version from the
default UIFactory
.updateUI
in class JComponent
JComponent.updateUI()
public String getUIClassID()
getUIClassID
in class JComponent
JComponent.getUIClassID()
,
UIDefaults.getUI(javax.swing.JComponent)
protected ChangeListener createChangeListener()
ChangeEvents
differently
can override this to return a subclass of ModelListener
or
another ChangeListener
implementation.fireStateChanged()
public void addChangeListener(ChangeListener l)
ChangeListener
to this tabbedpane.l
- the ChangeListener
to addfireStateChanged()
,
removeChangeListener(javax.swing.event.ChangeListener)
public void removeChangeListener(ChangeListener l)
ChangeListener
from this tabbedpane.l
- the ChangeListener to removefireStateChanged()
,
addChangeListener(javax.swing.event.ChangeListener)
protected void fireStateChanged()
ChangeEvent
, whose source is this tabbedpane, to
each listener. This method method is called each time
a ChangeEvent
is received from the model.addChangeListener(javax.swing.event.ChangeListener)
,
EventListenerList
public SingleSelectionModel getModel()
setModel(javax.swing.SingleSelectionModel)
public void setModel(SingleSelectionModel model)
model
- the model to be usedgetModel()
public int getTabPlacement()
setTabPlacement(int)
public void setTabPlacement(int tabPlacement)
SwingConstants.TOP
.tabPlacement
- the placement for the tabs relative to the contentIllegalArgumentException
- if tab placement value isn't one
of the above valid valuespublic int getSelectedIndex()
setSelectedIndex(int)
public void setSelectedIndex(int index)
index
- the index to be selectedIllegalArgumentException
- if index is out of boundsgetSelectedIndex()
,
SingleSelectionModel.setSelectedIndex(int)
public Component getSelectedComponent()
null
if there is no currently selected tab.setSelectedComponent(java.awt.Component)
public void setSelectedComponent(Component c)
selectedIndex
to the index
corresponding to the specified component.IllegalArgumentException
- if component not found in tabbed
panegetSelectedComponent()
public void insertTab(String title, Icon icon, Component component, String tip, int index)
component
, at index
,
represented by a
title
and/or icon
, either of which may be
null
.
Uses java.util.Vector internally, see insertElementAt
for details of insertion conventions.title
- the title to be displayed in this tabicon
- the icon to be displayed in this tabcomponent
- The component to be displayed when this tab is clicked.tip
- the tooltip to be displayed for this tabindex
- the position to insert this new tabaddTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String)
,
removeTabAt(int)
public void addTab(String title, Icon icon, Component component, String tip)
component
and tip
represented by a title
and/or icon
, either of which can be null
.
Cover method for insertTab
.title
- the title to be displayed in this tabicon
- the icon to be displayed in this tabcomponent
- The component to be displayed when this tab is clicked.tip
- the tooltip to be displayed for this tabinsertTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String, int)
,
removeTabAt(int)
public void addTab(String title, Icon icon, Component component)
component
represented by a title
and/or
icon
,
either of which can be null
.
Cover method for insertTab
.title
- the title to be displayed in this tabicon
- the icon to be displayed in this tabcomponent
- the component to be displayed when this tab is clickedinsertTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String, int)
,
removeTabAt(int)
public void addTab(String title, Component component)
component
represented by a title
and no icon.
Cover method for insertTab
.title
- the title to be displayed in this tabcomponent
- The component to be displayed when this tab is clicked.insertTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String, int)
,
removeTabAt(int)
public Component add(Component component)
component
with a tab title defaulting to
the name of the component.
Cover method for insertTab
.add
in class Container
component
- the component to be displayed when this tab is clickedinsertTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String, int)
,
removeTabAt(int)
public Component add(String title, Component component)
component
with the specified tab title.
Cover method for insertTab
.add
in class Container
title
- the title to be displayed in this tabcomponent
- the component to be displayed when this tab is clickedinsertTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String, int)
,
removeTabAt(int)
public Component add(Component component, int index)
component
at the specified tab index with a tab
title defaulting to the name of the component.
Cover method for insertTab
.add
in class Container
component
- the component to be displayed when this tab is clickedindex
- the position to insert this new tabinsertTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String, int)
,
removeTabAt(int)
public void add(Component component, Object constraints)
component
to the tabbed pane.
If constraints
is a String
or an
Icon
, it will be used for the tab title,
otherwise the component's name will be used as the tab title.
Cover method for insertTab
.add
in class Container
component
- the component to be displayed when this tab is clickedconstraints
- the object to be displayed in the tabinsertTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String, int)
,
removeTabAt(int)
public void add(Component component, Object constraints, int index)
component
at the specified tab index.
If constraints
is a String
or an
Icon
, it will be used for the tab title,
otherwise the component's name will be used as the tab title.
Cover method for insertTab
.add
in class Container
component
- the component to be displayed when this tab is clickedindex
- the position to insert this new tabinsertTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String, int)
,
removeTabAt(int)
public void removeTabAt(int index)
index
.
After the component associated with index
is removed,
its visibility is reset to true to ensure it will be visible
if added to other containers.index
- the index of the tab to be removedaddTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String)
,
insertTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String, int)
public void remove(Component component)
remove
in class Container
component
- the component to remove from the tabbedpaneaddTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String)
,
removeTabAt(int)
public void remove(int index)
remove
in class Container
index
- the index of the component to remove from the
tabbedpane
addTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String)
,
removeTabAt(int)
public void removeAll()
tabbedpane
.removeAll
in class Container
addTab(java.lang.String, javax.swing.Icon, java.awt.Component, java.lang.String)
,
removeTabAt(int)
public int getTabCount()
tabbedpane
.public int getTabRunCount()
tabPlacement
is TOP or BOTTOM and the number of columns if
tabPlacement
is LEFT or RIGHT, or 0 if there is no UI set on this
tabbedpane
public String getTitleAt(int index)
index
.index
- the index of the item being queriedindex
IllegalArgumentException
- if index is out of boundssetTitleAt(int, java.lang.String)
public Icon getIconAt(int index)
index
.index
- the index of the item being queriedindex
IllegalArgumentException
- if index is out of boundssetIconAt(int, javax.swing.Icon)
public Icon getDisabledIconAt(int index)
index
.index
- the index of the item being queriedindex
IllegalArgumentException
- if index is out of boundssetDisabledIconAt(int, javax.swing.Icon)
public String getToolTipTextAt(int index)
index
.index
- the index of the item being queriedindex
IllegalArgumentException
- if index is out of boundssetToolTipTextAt(int, java.lang.String)
public Color getBackgroundAt(int index)
index
.index
- the index of the item being queriedColor
of the tab background at
index
IllegalArgumentException
- if index is out of boundssetBackgroundAt(int, java.awt.Color)
public Color getForegroundAt(int index)
index
.index
- the index of the item being queriedColor
of the tab foreground at
index
IllegalArgumentException
- if index is out of boundssetForegroundAt(int, java.awt.Color)
public boolean isEnabledAt(int index)
index
is
currently enabled.index
- the index of the item being queriedindex
is enabled;
false otherwiseIllegalArgumentException
- if index is out of boundssetEnabledAt(int, boolean)
public Component getComponentAt(int index)
index
.index
- the index of the item being queriedComponent
at index
IllegalArgumentException
- if index is out of boundssetComponentAt(int, java.awt.Component)
public Rectangle getBoundsAt(int index)
index
. If the tab at
this index is not currently visible in the UI, then returns
null
.
If there is no UI set on this tabbedpane
,
then returns null
.index
- the index to be queriedRectangle
containing the tab bounds at
index
, or null
if tab at
index
is not currently visible in the UI,
or if there is no UI set on this tabbedpane
public void setTitleAt(int index, String title)
index
to title
which
can be null
.
An internal exception is raised if there is no tab at that index.index
- the tab index where the title should be settitle
- the title to be displayed in the tabIllegalArgumentException
- if index is out of boundsgetTitleAt(int)
public void setIconAt(int index, Icon icon)
index
to icon
which can be
null
.
An internal exception is raised if there is no tab at that index.index
- the tab index where the icon should be seticon
- the icon to be displayed in the tabIllegalArgumentException
- if index is out of boundsgetIconAt(int)
public void setDisabledIconAt(int index, Icon disabledIcon)
index
to icon
which can be null
.
An internal exception is raised if there is no tab at that index.index
- the tab index where the disabled icon should be seticon
- the icon to be displayed in the tab when disabledIllegalArgumentException
- if index is out of boundsgetDisabledIconAt(int)
public void setToolTipTextAt(int index, String toolTipText)
index
to toolTipText
which can be null
.
An internal exception is raised if there is no tab at that index.index
- the tab index where the tooltip text should be settoolTipText
- the tooltip text to be displayed for the tabIllegalArgumentException
- if index is out of boundsgetToolTipTextAt(int)
public void setBackgroundAt(int index, Color background)
index
to
background
which can be null
, in which case the tab's background color
will default to the background color of the tabbedpane
.
An internal exception is raised if there is no tab at that index.index
- the tab index where the background should be setbackground
- the color to be displayed in the tab's backgroundIllegalArgumentException
- if index is out of boundsgetBackgroundAt(int)
public void setForegroundAt(int index, Color foreground)
index
to
foreground
which can be
null
, in which case the tab's foreground color
will default to the foreground color of this tabbedpane
.
An internal exception is raised if there is no tab at that index.index
- the tab index where the foreground should be setforeground
- the color to be displayed as the tab's foregroundIllegalArgumentException
- if index is out of boundsgetForegroundAt(int)
public void setEnabledAt(int index, boolean enabled)
index
is enabled.
An internal exception is raised if there is no tab at that index.index
- the tab index which should be enabled/disabledenabled
- whether or not the tab should be enabledIllegalArgumentException
- if index is out of boundsisEnabledAt(int)
public void setComponentAt(int index, Component component)
index
to component
.
An internal exception is raised if there is no tab at that index.index
- the tab index where this component is being placedcomponent
- the component for the tabIllegalArgumentException
- if index is out of boundsgetComponentAt(int)
public int indexOfTab(String title)
title
, or
-1 if no tab has this title.title
- the title for the tabtitle
, or
-1 if no tab has this titlepublic int indexOfTab(Icon icon)
icon
,
or -1 if no tab has this icon.icon
- the icon for the tabicon
,
or -1 if no tab has this iconpublic int indexOfComponent(Component component)
component
- the component for the tabpublic String getToolTipText(MouseEvent event)
getToolTipText
in class JComponent
event
- the MouseEvent
that tells where the
cursor is lingeringString
containing the tooltip textIllegalArgumentException
- if index is out of boundsprotected String paramString()
JTabbedPane
.
This method
is intended to be used only for debugging purposes, and the
content and format of the returned string may vary between
implementations. The returned string may be empty but may not
be null
.paramString
in class JComponent
public AccessibleContext getAccessibleContext()
getAccessibleContext
in interface Accessible
getAccessibleContext
in class JComponent
|
JavaTM 2 Platform Std. Ed. v1.3 |
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
Java, Java 2D, and JDBC are trademarks or registered trademarks of Sun Microsystems, Inc. in the US and other countries.
Copyright 1993-2000 Sun Microsystems, Inc. 901 San Antonio Road
Palo Alto, California, 94303, U.S.A. All Rights Reserved.