Class JTabbedPane
- All Implemented Interfaces:
-
ImageObserver
,MenuContainer
,Serializable
,Accessible
,SwingConstants
@JavaBean(defaultProperty="UI", description="A component which provides a tab folder metaphor for displaying one component from a set of components.") public class JTabbedPane extends JComponent implements Serializable, Accessible, SwingConstants
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.
The tab title can be rendered by a Component
. For example, the following produce similar results:
// In this case the look and feel renders the title for the tab. tabbedPane.addTab("Tab", myComponent); // In this case the custom component is responsible for rendering the // title of the tab. tabbedPane.addTab(null, myComponent); tabbedPane.setTabComponentAt(0, new JLabel("Tab"));The latter is typically used when you want a more complex user interaction that requires custom components on the tab. For example, you could provide a custom component that animates or one that has widgets for closing the tab.
If you specify a component for a tab, the JTabbedPane
will not render any text or icon you have specified for the tab.
Note: Do not use setVisible
directly on a tab component to make it visible, use setSelectedComponent
or setSelectedIndex
methods instead.
Warning: Swing is not thread safe. For more information see Swing's Threading Policy.
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. As of 1.4, support for long term storage of all JavaBeans has been added to the java.beans
package. Please see XMLEncoder
.
- Since:
- 1.2
- See Also:
Nested Class Summary
Modifier and Type | Class | Description |
---|---|---|
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. |
Nested classes/interfaces declared in class javax.swing.JComponent
JComponent.AccessibleJComponent
Nested classes/interfaces declared in class java.awt.Container
Container.AccessibleAWTContainer
Nested classes/interfaces declared in class java.awt.Component
Component.AccessibleAWTComponent, Component.BaselineResizeBehavior, Component.BltBufferStrategy, Component.FlipBufferStrategy
Field Summary
Modifier and Type | Field | Description |
---|---|---|
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 |
static final int |
SCROLL_TAB_LAYOUT |
Tab layout policy for providing a subset of available tabs when all the tabs will not fit within a single run. |
protected int |
tabPlacement |
Where the tabs are placed. |
static final int |
WRAP_TAB_LAYOUT |
The tab layout policy for wrapping tabs in multiple runs when all tabs will not fit within a single run. |
Fields declared in class javax.swing.JComponent
listenerList, TOOL_TIP_TEXT_KEY, ui, UNDEFINED_CONDITION, WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, WHEN_FOCUSED, WHEN_IN_FOCUSED_WINDOW
Fields declared in class java.awt.Component
accessibleContext, BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENT
Fields declared in interface java.awt.image.ImageObserver
ABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH
Fields declared in interface javax.swing.SwingConstants
BOTTOM, CENTER, EAST, HORIZONTAL, LEADING, LEFT, NEXT, NORTH, NORTH_EAST, NORTH_WEST, PREVIOUS, RIGHT, SOUTH, SOUTH_EAST, SOUTH_WEST, TOP, TRAILING, VERTICAL, WEST
Constructor Summary
Constructor | Description |
---|---|
JTabbedPane() |
Creates an empty TabbedPane with a default tab placement of JTabbedPane.TOP . |
JTabbedPane |
Creates an empty TabbedPane with the specified tab placement of either: JTabbedPane.TOP , JTabbedPane.BOTTOM , JTabbedPane.LEFT , or JTabbedPane.RIGHT . |
JTabbedPane |
Creates an empty TabbedPane with the specified tab placement and tab layout policy. |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
Component |
add |
Adds a component with a tab title defaulting to the name of the component which is the result of calling component.getName . |
Component |
add |
Adds a component at the specified tab index with a tab title defaulting to the name of the component. |
void |
add |
Adds a component to the tabbed pane. |
void |
add |
Adds a component at the specified tab index. |
Component |
add |
Adds a component with the specified tab title. |
void |
addChangeListener |
Adds a ChangeListener to this tabbedpane. |
void |
addTab |
Adds a component represented by a title and no icon. |
void |
addTab |
Adds a component represented by a title and/or icon , either of which can be null . |
void |
addTab |
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() |
Sends a ChangeEvent , with this JTabbedPane as the source, to each registered listener. |
AccessibleContext |
getAccessibleContext() |
Gets the AccessibleContext associated with this JTabbedPane. |
Color |
getBackgroundAt |
Returns the tab background color at index . |
Rectangle |
getBoundsAt |
Returns the tab bounds at index . |
ChangeListener[] |
getChangeListeners() |
Returns an array of all the ChangeListener s added to this JTabbedPane with addChangeListener . |
Component |
getComponentAt |
Returns the component at index . |
Icon |
getDisabledIconAt |
Returns the tab disabled icon at index . |
int |
getDisplayedMnemonicIndexAt |
Returns the character, as an index, that the look and feel should provide decoration for as representing the mnemonic character. |
Color |
getForegroundAt |
Returns the tab foreground color at index . |
Icon |
getIconAt |
Returns the tab icon at index . |
int |
getMnemonicAt |
Returns the keyboard mnemonic for accessing the specified tab. |
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. |
Component |
getTabComponentAt |
Returns the tab component at index . |
int |
getTabCount() |
Returns the number of tabs in this tabbedpane . |
int |
getTabLayoutPolicy() |
Returns the policy used by the tabbedpane to layout the tabs when all the tabs will not fit within a single run. |
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 |
Returns the tab title at index . |
String |
getToolTipText |
Returns the tooltip text for the component determined by the mouse event location. |
String |
getToolTipTextAt |
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 |
indexAtLocation |
Returns the tab index corresponding to the tab whose bounds intersect the specified location. |
int |
indexOfComponent |
Returns the index of the tab for the specified component. |
int |
indexOfTab |
Returns the first tab index with a given title , or -1 if no tab has this title. |
int |
indexOfTab |
Returns the first tab index with a given icon , or -1 if no tab has this icon. |
int |
indexOfTabComponent |
Returns the index of the tab for the specified tab component. |
void |
insertTab |
Inserts a new tab for the given component, at the given index, represented by the given title and/or icon, either of which may be null . |
boolean |
isEnabledAt |
Returns whether or not the tab at index is currently enabled. |
protected String |
paramString() |
Returns a string representation of this JTabbedPane . |
void |
remove |
Removes the tab and component which corresponds to the specified index. |
void |
remove |
Removes the specified Component from the JTabbedPane . |
void |
removeAll() |
Removes all the tabs and their corresponding components from the tabbedpane . |
void |
removeChangeListener |
Removes a ChangeListener from this tabbedpane. |
void |
removeTabAt |
Removes the tab at index . |
void |
setBackgroundAt |
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 |
Sets the component at index to component . |
void |
setDisabledIconAt |
Sets the disabled icon at index to icon which can be null . |
void |
setDisplayedMnemonicIndexAt |
Provides a hint to the look and feel as to which character in the text should be decorated to represent the mnemonic. |
void |
setEnabledAt |
Sets whether or not the tab at index is enabled. |
void |
setForegroundAt |
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 |
Sets the icon at index to icon which can be null . |
void |
setMnemonicAt |
Sets the keyboard mnemonic for accessing the specified tab. |
void |
setModel |
Sets the model to be used with this tabbedpane. |
void |
setSelectedComponent |
Sets the selected component for this tabbedpane. |
void |
setSelectedIndex |
Sets the selected index for this tabbedpane. |
void |
setTabComponentAt |
Sets the component that is responsible for rendering the title for the specified tab. |
void |
setTabLayoutPolicy |
Sets the policy which the tabbedpane will use in laying out the tabs when all the tabs will not fit within a single run. |
void |
setTabPlacement |
Sets the tab placement for this tabbedpane. |
void |
setTitleAt |
Sets the title at index to title which can be null . |
void |
setToolTipTextAt |
Sets the tooltip text at index to toolTipText which can be null . |
void |
setUI |
Sets the UI object which implements the L&F for this component. |
void |
updateUI() |
Resets the UI property to a value from the current look and feel. |
Methods declared in class javax.swing.JComponent
addAncestorListener, addNotify, addVetoableChangeListener, computeVisibleRect, contains, createToolTip, disable, enable, firePropertyChange, firePropertyChange, fireVetoableChange, getActionForKeyStroke, getActionMap, getAlignmentX, getAlignmentY, getAncestorListeners, getAutoscrolls, getBaseline, getBaselineResizeBehavior, getBorder, getBounds, getClientProperty, getComponentGraphics, getComponentPopupMenu, getConditionForKeyStroke, getDebugGraphicsOptions, getDefaultLocale, getFontMetrics, getGraphics, getHeight, getInheritsPopupMenu, getInputMap, getInputMap, getInputVerifier, getInsets, getInsets, getListeners, getLocation, getMaximumSize, getMinimumSize, getNextFocusableComponent, getPopupLocation, getPreferredSize, getRegisteredKeyStrokes, getRootPane, getSize, getToolTipLocation, getToolTipText, getTopLevelAncestor, getTransferHandler, getVerifyInputWhenFocusTarget, getVetoableChangeListeners, getVisibleRect, getWidth, getX, getY, grabFocus, hide, isDoubleBuffered, isLightweightComponent, isManagingFocus, isOpaque, isOptimizedDrawingEnabled, isPaintingForPrint, isPaintingOrigin, isPaintingTile, isRequestFocusEnabled, isValidateRoot, paint, paintBorder, paintChildren, paintComponent, paintImmediately, paintImmediately, print, printAll, printBorder, printChildren, printComponent, processComponentKeyEvent, processKeyBinding, processKeyEvent, processMouseEvent, processMouseMotionEvent, putClientProperty, registerKeyboardAction, registerKeyboardAction, removeAncestorListener, removeNotify, removeVetoableChangeListener, repaint, repaint, requestDefaultFocus, requestFocus, requestFocus, requestFocusInWindow, requestFocusInWindow, resetKeyboardActions, reshape, revalidate, scrollRectToVisible, setActionMap, setAlignmentX, setAlignmentY, setAutoscrolls, setBackground, setBorder, setComponentPopupMenu, setDebugGraphicsOptions, setDefaultLocale, setDoubleBuffered, setEnabled, setFocusTraversalKeys, setFont, setForeground, setInheritsPopupMenu, setInputMap, setInputVerifier, setMaximumSize, setMinimumSize, setNextFocusableComponent, setOpaque, setPreferredSize, setRequestFocusEnabled, setToolTipText, setTransferHandler, setUI, setVerifyInputWhenFocusTarget, setVisible, unregisterKeyboardAction, update
Methods declared in class java.awt.Container
addContainerListener, addImpl, addPropertyChangeListener, addPropertyChangeListener, applyComponentOrientation, areFocusTraversalKeysSet, countComponents, deliverEvent, doLayout, findComponentAt, findComponentAt, getComponent, getComponentAt, getComponentAt, getComponentCount, getComponents, getComponentZOrder, getContainerListeners, getFocusTraversalKeys, getFocusTraversalPolicy, getLayout, getMousePosition, insets, invalidate, isAncestorOf, isFocusCycleRoot, isFocusCycleRoot, isFocusTraversalPolicyProvider, isFocusTraversalPolicySet, layout, list, list, locate, minimumSize, paintComponents, preferredSize, printComponents, processContainerEvent, processEvent, removeContainerListener, setComponentZOrder, setFocusCycleRoot, setFocusTraversalPolicy, setFocusTraversalPolicyProvider, setLayout, transferFocusDownCycle, validate, validateTree
Methods declared in class java.awt.Component
action, add, addComponentListener, addFocusListener, addHierarchyBoundsListener, addHierarchyListener, addInputMethodListener, addKeyListener, addMouseListener, addMouseMotionListener, addMouseWheelListener, bounds, checkImage, checkImage, coalesceEvents, contains, createImage, createImage, createVolatileImage, createVolatileImage, disableEvents, dispatchEvent, enable, enableEvents, enableInputMethods, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, getBackground, getBounds, getColorModel, getComponentListeners, getComponentOrientation, getCursor, getDropTarget, getFocusCycleRootAncestor, getFocusListeners, getFocusTraversalKeysEnabled, getFont, getForeground, getGraphicsConfiguration, getHierarchyBoundsListeners, getHierarchyListeners, getIgnoreRepaint, getInputContext, getInputMethodListeners, getInputMethodRequests, getKeyListeners, getLocale, getLocation, getLocationOnScreen, getMouseListeners, getMouseMotionListeners, getMousePosition, getMouseWheelListeners, getName, getParent, getPropertyChangeListeners, getPropertyChangeListeners, getSize, getToolkit, getTreeLock, gotFocus, handleEvent, hasFocus, imageUpdate, inside, isBackgroundSet, isCursorSet, isDisplayable, isEnabled, isFocusable, isFocusOwner, isFocusTraversable, isFontSet, isForegroundSet, isLightweight, isMaximumSizeSet, isMinimumSizeSet, isPreferredSizeSet, isShowing, isValid, isVisible, keyDown, keyUp, list, list, list, location, lostFocus, mouseDown, mouseDrag, mouseEnter, mouseExit, mouseMove, mouseUp, move, nextFocus, paintAll, postEvent, prepareImage, prepareImage, processComponentEvent, processFocusEvent, processHierarchyBoundsEvent, processHierarchyEvent, processInputMethodEvent, processMouseWheelEvent, remove, removeComponentListener, removeFocusListener, removeHierarchyBoundsListener, removeHierarchyListener, removeInputMethodListener, removeKeyListener, removeMouseListener, removeMouseMotionListener, removeMouseWheelListener, removePropertyChangeListener, removePropertyChangeListener, repaint, repaint, repaint, requestFocus, requestFocus, requestFocusInWindow, resize, resize, setBounds, setBounds, setComponentOrientation, setCursor, setDropTarget, setFocusable, setFocusTraversalKeysEnabled, setIgnoreRepaint, setLocale, setLocation, setLocation, setMixingCutoutShape, setName, setSize, setSize, show, show, size, toString, transferFocus, transferFocusBackward, transferFocusUpCycle
Field Details
WRAP_TAB_LAYOUT
public static final int WRAP_TAB_LAYOUT
- See Also:
SCROLL_TAB_LAYOUT
public static final int SCROLL_TAB_LAYOUT
- See Also:
tabPlacement
protected int tabPlacement
- See Also:
model
protected SingleSelectionModel model
changeListener
protected ChangeListener changeListener
changeListener
is the listener we add to the model.changeEvent
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 Details
JTabbedPane
public JTabbedPane()
TabbedPane
with a default tab placement of JTabbedPane.TOP
.JTabbedPane
public JTabbedPane(int tabPlacement)
TabbedPane
with the specified tab placement of either: JTabbedPane.TOP
, JTabbedPane.BOTTOM
, JTabbedPane.LEFT
, or JTabbedPane.RIGHT
.- Parameters:
-
tabPlacement
- the placement for the tabs relative to the content - See Also:
JTabbedPane
public JTabbedPane(int tabPlacement, int tabLayoutPolicy)
TabbedPane
with the specified tab placement and tab layout policy. Tab placement may be either: JTabbedPane.TOP
, JTabbedPane.BOTTOM
, JTabbedPane.LEFT
, or JTabbedPane.RIGHT
. Tab layout policy may be either: JTabbedPane.WRAP_TAB_LAYOUT
or JTabbedPane.SCROLL_TAB_LAYOUT
.- Parameters:
-
tabPlacement
- the placement for the tabs relative to the content -
tabLayoutPolicy
- the policy for laying out tabs when all tabs will not fit on one run - Throws:
-
IllegalArgumentException
- if tab placement or tab layout policy are not one of the above supported values - Since:
- 1.4
- See Also:
Method Details
getUI
public TabbedPaneUI getUI()
- Overrides:
-
getUI
in classJComponent
- Returns:
- a
TabbedPaneUI
object - See Also:
setUI
@BeanProperty(hidden=true, visualUpdate=true, description="The UI object that implements the tabbedpane\'s LookAndFeel") public void setUI(TabbedPaneUI ui)
- Parameters:
-
ui
- the new UI object - See Also:
updateUI
public void updateUI()
- Overrides:
-
updateUI
in classJComponent
- See Also:
getUIClassID
@BeanProperty(bound=false) public String getUIClassID()
- Overrides:
-
getUIClassID
in classJComponent
- Returns:
- the string "TabbedPaneUI"
- See Also:
createChangeListener
protected ChangeListener createChangeListener()
ChangeEvents
differently can override this to return a subclass of ModelListener
or another ChangeListener
implementation.- Returns:
- a
ChangeListener
- See Also:
addChangeListener
public void addChangeListener(ChangeListener l)
ChangeListener
to this tabbedpane.- Parameters:
-
l
- theChangeListener
to add - See Also:
removeChangeListener
public void removeChangeListener(ChangeListener l)
ChangeListener
from this tabbedpane.- Parameters:
-
l
- theChangeListener
to remove - See Also:
getChangeListeners
@BeanProperty(bound=false) public ChangeListener[] getChangeListeners()
ChangeListener
s added to this JTabbedPane
with addChangeListener
.- Returns:
- all of the
ChangeListener
s added or an empty array if no listeners have been added - Since:
- 1.4
fireStateChanged
protected void fireStateChanged()
ChangeEvent
, with this JTabbedPane
as the source, to each registered listener. This method is called each time there is a change to either the selected index or the selected tab in the JTabbedPane
. Usually, the selected index and selected tab change together. However, there are some cases, such as tab addition, where the selected index changes and the same tab remains selected. There are other cases, such as deleting the selected tab, where the index remains the same, but a new tab moves to that index. Events are fired for all of these cases.getModel
public SingleSelectionModel getModel()
- Returns:
- the
SingleSelectionModel
associated with this tabbedpane - See Also:
setModel
@BeanProperty(description="The tabbedpane\'s SingleSelectionModel.") public void setModel(SingleSelectionModel model)
- Parameters:
-
model
- the model to be used - See Also:
getTabPlacement
public int getTabPlacement()
- Returns:
- an
int
specifying the placement for the tabs - See Also:
setTabPlacement
@BeanProperty(preferred=true, visualUpdate=true, enumerationValues={"JTabbedPane.TOP","JTabbedPane.LEFT","JTabbedPane.BOTTOM","JTabbedPane.RIGHT"}, description="The tabbedpane\'s tab placement.") public void setTabPlacement(int tabPlacement)
-
JTabbedPane.TOP
-
JTabbedPane.BOTTOM
-
JTabbedPane.LEFT
-
JTabbedPane.RIGHT
SwingConstants.TOP
.- Parameters:
-
tabPlacement
- the placement for the tabs relative to the content - Throws:
-
IllegalArgumentException
- if tab placement value isn't one of the above valid values
getTabLayoutPolicy
public int getTabLayoutPolicy()
- Returns:
- an
int
specifying the policy used to layout the tabs - Since:
- 1.4
- See Also:
setTabLayoutPolicy
@BeanProperty(preferred=true, visualUpdate=true, enumerationValues={"JTabbedPane.WRAP_TAB_LAYOUT","JTabbedPane.SCROLL_TAB_LAYOUT"}, description="The tabbedpane\'s policy for laying out the tabs") public void setTabLayoutPolicy(int tabLayoutPolicy)
-
JTabbedPane.WRAP_TAB_LAYOUT
-
JTabbedPane.SCROLL_TAB_LAYOUT
JTabbedPane.WRAP_TAB_LAYOUT
. Some look and feels might only support a subset of the possible layout policies, in which case the value of this property may be ignored.
- Parameters:
-
tabLayoutPolicy
- the policy used to layout the tabs - Throws:
-
IllegalArgumentException
- if layoutPolicy value isn't one of the above valid values - Since:
- 1.4
- See Also:
getSelectedIndex
public int getSelectedIndex()
- Returns:
- the index of the selected tab
- See Also:
setSelectedIndex
@BeanProperty(bound=false, preferred=true, description="The tabbedpane\'s selected tab index.") public void setSelectedIndex(int index)
- Parameters:
-
index
- the index to be selected - Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < -1 || index >= tab count)
- See Also:
getSelectedComponent
public Component getSelectedComponent()
null
if there is no currently selected tab.- Returns:
- the component corresponding to the selected tab
- See Also:
setSelectedComponent
@BeanProperty(bound=false, preferred=true, description="The tabbedpane\'s selected component.") public void setSelectedComponent(Component c)
selectedIndex
to the index corresponding to the specified component.- Parameters:
-
c
- the selectedComponent
for thisTabbedPane
- Throws:
-
IllegalArgumentException
- if component not found in tabbed pane - See Also:
insertTab
public void insertTab(String title, Icon icon, Component component, String tip, int index)
null
.- Parameters:
-
title
- the title to be displayed on the tab -
icon
- the icon to be displayed on the tab -
component
- the component to be displayed when this tab is clicked. -
tip
- the tooltip to be displayed for this tab -
index
- the position to insert this new tab (> 0 and <= getTabCount()
) - Throws:
-
IndexOutOfBoundsException
- if the index is out of range (< 0 or > getTabCount()
) - See Also:
addTab
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
.- Parameters:
-
title
- the title to be displayed in this tab -
icon
- the icon to be displayed in this tab -
component
- the component to be displayed when this tab is clicked -
tip
- the tooltip to be displayed for this tab - See Also:
addTab
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
.- Parameters:
-
title
- the title to be displayed in this tab -
icon
- the icon to be displayed in this tab -
component
- the component to be displayed when this tab is clicked - See Also:
addTab
public void addTab(String title, Component component)
component
represented by a title
and no icon. Cover method for insertTab
.- Parameters:
-
title
- the title to be displayed in this tab -
component
- the component to be displayed when this tab is clicked - See Also:
add
public Component add(Component component)
component
with a tab title defaulting to the name of the component which is the result of calling component.getName
. Cover method for insertTab
.add
public Component add(String title, Component component)
component
with the specified tab title. Cover method for insertTab
.add
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
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
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
.removeTabAt
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.- Parameters:
-
index
- the index of the tab to be removed - Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
remove
public void remove(Component component)
Component
from the JTabbedPane
. The method does nothing if the component
is null.remove
public void remove(int index)
- Overrides:
-
remove
in classContainer
- Parameters:
-
index
- the index of the component to remove from thetabbedpane
- Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
removeAll
public void removeAll()
tabbedpane
.getTabCount
@BeanProperty(bound=false) public int getTabCount()
tabbedpane
.- Returns:
- an integer specifying the number of tabbed pages
getTabRunCount
@BeanProperty(bound=false) public int getTabRunCount()
- Returns:
- an integer giving the number of rows if the
tabPlacement
isTOP
orBOTTOM
and the number of columns iftabPlacement
isLEFT
orRIGHT
, or 0 if there is no UI set on thistabbedpane
getTitleAt
public String getTitleAt(int index)
index
.- Parameters:
-
index
- the index of the item being queried - Returns:
- the title at
index
- Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
getIconAt
public Icon getIconAt(int index)
index
.- Parameters:
-
index
- the index of the item being queried - Returns:
- the icon at
index
- Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
getDisabledIconAt
public Icon getDisabledIconAt(int index)
index
. If the tab disabled icon doesn't exist at index
this will forward the call to the look and feel to construct an appropriate disabled Icon from the corresponding enabled Icon. Some look and feels might not render the disabled Icon, in which case it won't be created.- Parameters:
-
index
- the index of the item being queried - Returns:
- the icon at
index
- Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
getToolTipTextAt
public String getToolTipTextAt(int index)
index
.- Parameters:
-
index
- the index of the item being queried - Returns:
- a string containing the tool tip text at
index
- Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- Since:
- 1.3
- See Also:
getBackgroundAt
public Color getBackgroundAt(int index)
index
.- Parameters:
-
index
- the index of the item being queried - Returns:
- the
Color
of the tab background atindex
- Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
getForegroundAt
public Color getForegroundAt(int index)
index
.- Parameters:
-
index
- the index of the item being queried - Returns:
- the
Color
of the tab foreground atindex
- Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
isEnabledAt
public boolean isEnabledAt(int index)
index
is currently enabled.- Parameters:
-
index
- the index of the item being queried - Returns:
- true if the tab at
index
is enabled; false otherwise - Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
getComponentAt
public Component getComponentAt(int index)
index
.- Parameters:
-
index
- the index of the item being queried - Returns:
- the
Component
atindex
- Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
getMnemonicAt
public int getMnemonicAt(int tabIndex)
- Parameters:
-
tabIndex
- the index of the tab that the mnemonic refers to - Returns:
- the key code which represents the mnemonic; -1 if a mnemonic is not specified for the tab
- Throws:
-
IndexOutOfBoundsException
- if index is out of range (tabIndex
< 0 ||tabIndex
>= tab count) - Since:
- 1.4
- See Also:
getDisplayedMnemonicIndexAt
public int getDisplayedMnemonicIndexAt(int tabIndex)
- Parameters:
-
tabIndex
- the index of the tab that the mnemonic refers to - Returns:
- index representing mnemonic character if one exists; otherwise returns -1
- Throws:
-
IndexOutOfBoundsException
- if index is out of range (tabIndex
< 0 ||tabIndex
>= tab count) - Since:
- 1.4
- See Also:
getBoundsAt
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
.- Parameters:
-
index
- the index to be queried - Returns:
- a
Rectangle
containing the tab bounds atindex
, ornull
if tab atindex
is not currently visible in the UI, or if there is no UI set on thistabbedpane
- Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
setTitleAt
@BeanProperty(preferred=true, visualUpdate=true, description="The title at the specified tab index.") public void setTitleAt(int index, String title)
index
to title
which can be null
. The title is not shown if a tab component for this tab was specified. An internal exception is raised if there is no tab at that index.- Parameters:
-
index
- the tab index where the title should be set -
title
- the title to be displayed in the tab - Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
setIconAt
@BeanProperty(preferred=true, visualUpdate=true, description="The icon at the specified tab index.") public void setIconAt(int index, Icon icon)
index
to icon
which can be null
. This does not set disabled icon at icon
. If the new Icon is different than the current Icon and disabled icon is not explicitly set, the LookAndFeel will be asked to generate a disabled Icon. To explicitly set disabled icon, use setDisableIconAt()
. The icon is not shown if a tab component for this tab was specified. An internal exception is raised if there is no tab at that index.- Parameters:
-
index
- the tab index where the icon should be set -
icon
- the icon to be displayed in the tab - Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
setDisabledIconAt
@BeanProperty(preferred=true, visualUpdate=true, description="The disabled icon at the specified tab index.") 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.- Parameters:
-
index
- the tab index where the disabled icon should be set -
disabledIcon
- the icon to be displayed in the tab when disabled - Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
setToolTipTextAt
@BeanProperty(preferred=true, description="The tooltip text at the specified tab index.") 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.- Parameters:
-
index
- the tab index where the tooltip text should be set -
toolTipText
- the tooltip text to be displayed for the tab - Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- Since:
- 1.3
- See Also:
setBackgroundAt
@BeanProperty(preferred=true, visualUpdate=true, description="The background color at the specified tab index.") 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. It is up to the look and feel to honor this property, some may choose to ignore it.
- Parameters:
-
index
- the tab index where the background should be set -
background
- the color to be displayed in the tab's background - Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
setForegroundAt
@BeanProperty(preferred=true, visualUpdate=true, description="The foreground color at the specified tab index.") 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. It is up to the look and feel to honor this property, some may choose to ignore it.
- Parameters:
-
index
- the tab index where the foreground should be set -
foreground
- the color to be displayed as the tab's foreground - Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
setEnabledAt
public void setEnabledAt(int index, boolean enabled)
index
is enabled. An internal exception is raised if there is no tab at that index.- Parameters:
-
index
- the tab index which should be enabled/disabled -
enabled
- whether or not the tab should be enabled - Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
setComponentAt
@BeanProperty(visualUpdate=true, description="The component at the specified tab index.") public void setComponentAt(int index, Component component)
index
to component
. An internal exception is raised if there is no tab at that index.- Parameters:
-
index
- the tab index where this component is being placed -
component
- the component for the tab - Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- See Also:
setDisplayedMnemonicIndexAt
@BeanProperty(visualUpdate=true, description="the index into the String to draw the keyboard character mnemonic at") public void setDisplayedMnemonicIndexAt(int tabIndex, int mnemonicIndex)
The value of this is updated as the properties relating to the mnemonic change (such as the mnemonic itself, the text...). You should only ever have to call this if you do not wish the default character to be underlined. For example, if the text at tab index 3 was 'Apple Price', with a mnemonic of 'p', and you wanted the 'P' to be decorated, as 'Apple Price', you would have to invoke setDisplayedMnemonicIndex(3, 6)
after invoking setMnemonicAt(3, KeyEvent.VK_P)
.
Note that it is the programmer's responsibility to ensure that each tab has a unique mnemonic or unpredictable results may occur.
- Parameters:
-
tabIndex
- the index of the tab that the mnemonic refers to -
mnemonicIndex
- index into theString
to underline - Throws:
-
IndexOutOfBoundsException
- iftabIndex
is out of range (tabIndex < 0 || tabIndex >= tab count
) -
IllegalArgumentException
- will be thrown ifmnemonicIndex
is >= length of the tab title , or < -1 - Since:
- 1.4
- See Also:
setMnemonicAt
@BeanProperty(visualUpdate=true, description="The keyboard mnenmonic, as a KeyEvent VK constant, for the specified tab") public void setMnemonicAt(int tabIndex, int mnemonic)
A mnemonic must correspond to a single key on the keyboard and should be specified using one of the VK_XXX
keycodes defined in java.awt.event.KeyEvent
or one of the extended keycodes obtained through java.awt.event.KeyEvent.getExtendedKeyCodeForChar
. Mnemonics are case-insensitive, therefore a key event with the corresponding keycode would cause the button to be activated whether or not the Shift modifier was pressed.
This will update the displayed mnemonic property for the specified tab.
- Parameters:
-
tabIndex
- the index of the tab that the mnemonic refers to -
mnemonic
- the key code which represents the mnemonic - Throws:
-
IndexOutOfBoundsException
- iftabIndex
is out of range (tabIndex < 0 || tabIndex >= tab count
) - Since:
- 1.4
- See Also:
indexOfTab
public int indexOfTab(String title)
title
, or -1 if no tab has this title.- Parameters:
-
title
- the title for the tab - Returns:
- the first tab index which matches
title
, or -1 if no tab has this title
indexOfTab
public int indexOfTab(Icon icon)
icon
, or -1 if no tab has this icon.- Parameters:
-
icon
- the icon for the tab - Returns:
- the first tab index which matches
icon
, or -1 if no tab has this icon
indexOfComponent
public int indexOfComponent(Component component)
- Parameters:
-
component
- the component for the tab - Returns:
- the first tab which matches this component, or -1 if there is no tab for this component
indexAtLocation
public int indexAtLocation(int x, int y)
- Parameters:
-
x
- the x location relative to this tabbedpane -
y
- the y location relative to this tabbedpane - Returns:
- the tab index which intersects the location, or -1 if no tab intersects the location
- Since:
- 1.4
getToolTipText
public String getToolTipText(MouseEvent event)
- Overrides:
-
getToolTipText
in classJComponent
- Parameters:
-
event
- theMouseEvent
that tells where the cursor is lingering - Returns:
- the
String
containing the tooltip text
paramString
protected 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
.- Overrides:
-
paramString
in classJComponent
- Returns:
- a string representation of this JTabbedPane.
getAccessibleContext
@BeanProperty(bound=false) public AccessibleContext getAccessibleContext()
- Specified by:
-
getAccessibleContext
in interfaceAccessible
- Overrides:
-
getAccessibleContext
in classComponent
- Returns:
- an AccessibleJTabbedPane that serves as the AccessibleContext of this JTabbedPane
setTabComponentAt
@BeanProperty(preferred=true, visualUpdate=true, description="The tab component at the specified tab index.") public void setTabComponentAt(int index, Component component)
JTabbedPane
will render the title and/or icon for the specified tab. A non-null value means the component will render the title and JTabbedPane
will not render the title and/or icon. Note: The component must not be one that the developer has already added to the tabbed pane.
- Parameters:
-
index
- the tab index where the component should be set -
component
- the component to render the title for the specified tab - Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
-
IllegalArgumentException
- if component has already been added to thisJTabbedPane
- Since:
- 1.6
- See Also:
getTabComponentAt
public Component getTabComponentAt(int index)
index
.- Parameters:
-
index
- the index of the item being queried - Returns:
- the tab component at
index
- Throws:
-
IndexOutOfBoundsException
- if index is out of range(index < 0 || index >= tab count)
- Since:
- 1.6
- See Also:
indexOfTabComponent
public int indexOfTabComponent(Component tabComponent)
- Parameters:
-
tabComponent
- the tab component for the tab - Returns:
- the first tab which matches this tab component, or -1 if there is no tab for this tab component
- Since:
- 1.6
- See Also:
© 1993, 2021, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/17/docs/api/java.desktop/javax/swing/JTabbedPane.html