public class ScrollPaneLayout extends Object implements LayoutManager, ScrollPaneConstants, Serializable
JScrollPane.
 JScrollPaneLayout is
 responsible for nine components: a viewport, two scrollbars,
 a row header, a column header, and four "corner" components.
 
 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.
JScrollPane, 
JViewport| Modifier and Type | Class and Description | 
|---|---|
| static class  | ScrollPaneLayout.UIResourceThe UI resource version of  ScrollPaneLayout. | 
| Modifier and Type | Field and Description | 
|---|---|
| protected JViewport | colHeadThe column header child. | 
| protected JScrollBar | hsbThe scrollpane's horizontal scrollbar child. | 
| protected int | hsbPolicyThe display policy for the horizontal scrollbar. | 
| protected Component | lowerLeftThe component to display in the lower left corner. | 
| protected Component | lowerRightThe component to display in the lower right corner. | 
| protected JViewport | rowHeadThe row header child. | 
| protected Component | upperLeftThe component to display in the upper left corner. | 
| protected Component | upperRightThe component to display in the upper right corner. | 
| protected JViewport | viewportThe scrollpane's viewport child. | 
| protected JScrollBar | vsbThe scrollpane's vertical scrollbar child. | 
| protected int | vsbPolicyThe display policy for the vertical scrollbar. | 
COLUMN_HEADER, HORIZONTAL_SCROLLBAR, HORIZONTAL_SCROLLBAR_ALWAYS, HORIZONTAL_SCROLLBAR_AS_NEEDED, HORIZONTAL_SCROLLBAR_NEVER, HORIZONTAL_SCROLLBAR_POLICY, LOWER_LEADING_CORNER, LOWER_LEFT_CORNER, LOWER_RIGHT_CORNER, LOWER_TRAILING_CORNER, ROW_HEADER, UPPER_LEADING_CORNER, UPPER_LEFT_CORNER, UPPER_RIGHT_CORNER, UPPER_TRAILING_CORNER, VERTICAL_SCROLLBAR, VERTICAL_SCROLLBAR_ALWAYS, VERTICAL_SCROLLBAR_AS_NEEDED, VERTICAL_SCROLLBAR_NEVER, VERTICAL_SCROLLBAR_POLICY, VIEWPORT| Constructor and Description | 
|---|
| ScrollPaneLayout() | 
| Modifier and Type | Method and Description | 
|---|---|
| void | addLayoutComponent(String s,
                  Component c)Adds the specified component to the layout. | 
| protected Component | addSingletonComponent(Component oldC,
                     Component newC)Removes an existing component. | 
| JViewport | getColumnHeader()Returns the  JViewportobject that is the column header. | 
| Component | getCorner(String key)Returns the  Componentat the specified corner. | 
| JScrollBar | getHorizontalScrollBar()Returns the  JScrollBarobject that handles horizontal scrolling. | 
| int | getHorizontalScrollBarPolicy()Returns the horizontal scrollbar-display policy. | 
| JViewport | getRowHeader()Returns the  JViewportobject that is the row header. | 
| JScrollBar | getVerticalScrollBar()Returns the  JScrollBarobject that handles vertical scrolling. | 
| int | getVerticalScrollBarPolicy()Returns the vertical scrollbar-display policy. | 
| JViewport | getViewport()Returns the  JViewportobject that displays the
 scrollable contents. | 
| Rectangle | getViewportBorderBounds(JScrollPane scrollpane)Deprecated. 
 As of JDK version Swing1.1
    replaced by  JScrollPane.getViewportBorderBounds(). | 
| void | layoutContainer(Container parent)Lays out the scrollpane. | 
| Dimension | minimumLayoutSize(Container parent)The minimum size of a  ScrollPaneis the size of the insets
 plus minimum size of the viewport, plus the scrollpane's
 viewportBorder insets, plus the minimum size
 of the visible headers, plus the minimum size of the
 scrollbars whose displayPolicy isn't NEVER. | 
| Dimension | preferredLayoutSize(Container parent)The preferred size of a  ScrollPaneis the size of the insets,
 plus the preferred size of the viewport, plus the preferred size of
 the visible headers, plus the preferred size of the scrollbars
 that will appear given the current view and the current
 scrollbar displayPolicies. | 
| void | removeLayoutComponent(Component c)Removes the specified component from the layout. | 
| void | setHorizontalScrollBarPolicy(int x)Sets the horizontal scrollbar-display policy. | 
| void | setVerticalScrollBarPolicy(int x)Sets the vertical scrollbar-display policy. | 
| void | syncWithScrollPane(JScrollPane sp)This method is invoked after the ScrollPaneLayout is set as the
 LayoutManager of a  JScrollPane. | 
protected JViewport viewport
JViewport.protected JScrollBar vsb
JScrollBar.protected JScrollBar hsb
JScrollBar.protected JViewport rowHead
null.protected JViewport colHead
null.protected Component lowerLeft
null.protected Component lowerRight
null.protected Component upperLeft
null.protected Component upperRight
null.protected int vsbPolicy
ScrollPaneConstants.VERTICAL_SCROLLBAR_AS_NEEDED.
 
 This field is obsolete, please use the JScrollPane field instead.
protected int hsbPolicy
ScrollPaneConstants.HORIZONTAL_SCROLLBAR_AS_NEEDED.
 
 This field is obsolete, please use the JScrollPane field instead.
public void syncWithScrollPane(JScrollPane sp)
JScrollPane.
 It initializes all of the internal fields that
 are ordinarily set by addLayoutComponent.  For example:
 
 ScrollPaneLayout mySPLayout = new ScrollPanelLayout() {
     public void layoutContainer(Container p) {
         super.layoutContainer(p);
         // do some extra work here ...
     }
 };
 scrollpane.setLayout(mySPLayout):
 protected Component addSingletonComponent(Component oldC, Component newC)
 This method returns newC. If oldC is
 not equal to newC and is non-null,
 it will be removed from its parent.
oldC - the Component to replacenewC - the Component to addnewCpublic void addLayoutComponent(String s, Component c)
addLayoutComponent in interface LayoutManagers - the component identifierc - the the component to be addedIllegalArgumentException - if s is an invalid keypublic void removeLayoutComponent(Component c)
removeLayoutComponent in interface LayoutManagerc - the component to removepublic int getVerticalScrollBarPolicy()
setVerticalScrollBarPolicy(int)public void setVerticalScrollBarPolicy(int x)
JScrollPane version
 of this method.  It only exists for backwards compatibility
 with the Swing 1.0.2 (and earlier) versions of this class.x - an integer giving the display policyIllegalArgumentException - if x is an invalid
          vertical scroll bar policy, as listed abovepublic int getHorizontalScrollBarPolicy()
setHorizontalScrollBarPolicy(int)public void setHorizontalScrollBarPolicy(int x)
JScrollPane version
 of this method.  It only exists for backwards compatibility
 with the Swing 1.0.2 (and earlier) versions of this class.x - an int giving the display policyIllegalArgumentException - if x is not a valid
          horizontal scrollbar policy, as listed abovepublic JViewport getViewport()
JViewport object that displays the
 scrollable contents.JViewport object that displays the scrollable contentsJScrollPane.getViewport()public JScrollBar getHorizontalScrollBar()
JScrollBar object that handles horizontal scrolling.JScrollBar object that handles horizontal scrollingJScrollPane.getHorizontalScrollBar()public JScrollBar getVerticalScrollBar()
JScrollBar object that handles vertical scrolling.JScrollBar object that handles vertical scrollingJScrollPane.getVerticalScrollBar()public JViewport getRowHeader()
JViewport object that is the row header.JViewport object that is the row headerJScrollPane.getRowHeader()public JViewport getColumnHeader()
JViewport object that is the column header.JViewport object that is the column headerJScrollPane.getColumnHeader()public Component getCorner(String key)
Component at the specified corner.key - the String specifying the cornerComponent at the specified corner, as defined in
         ScrollPaneConstants; if key is not one of the
          four corners, null is returnedJScrollPane.getCorner(java.lang.String)public Dimension preferredLayoutSize(Container parent)
ScrollPane is the size of the insets,
 plus the preferred size of the viewport, plus the preferred size of
 the visible headers, plus the preferred size of the scrollbars
 that will appear given the current view and the current
 scrollbar displayPolicies.
 Note that the rowHeader is calculated as part of the preferred width and the colHeader is calculated as part of the preferred size.
preferredLayoutSize in interface LayoutManagerparent - the Container that will be laid outDimension object specifying the preferred size of the
         viewport and any scrollbarsViewportLayout, 
LayoutManagerpublic Dimension minimumLayoutSize(Container parent)
ScrollPane is the size of the insets
 plus minimum size of the viewport, plus the scrollpane's
 viewportBorder insets, plus the minimum size
 of the visible headers, plus the minimum size of the
 scrollbars whose displayPolicy isn't NEVER.minimumLayoutSize in interface LayoutManagerparent - the Container that will be laid outDimension object specifying the minimum sizeLayoutManager.preferredLayoutSize(java.awt.Container)public void layoutContainer(Container parent)
displayPolicy
 is ALWAYS, it's treated like the row header with respect to its
 dimensions and is made visible.
 null
 viewportBorder, then space is allocated for that.
 layoutContainer in interface LayoutManagerparent - the Container to lay out@Deprecated public Rectangle getViewportBorderBounds(JScrollPane scrollpane)
JScrollPane.getViewportBorderBounds(). Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2025, Oracle and/or its affiliates.  All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.