This section discusses problems that you might encounter while using components. If you don't find your problem in this section, consult the following sections:
- Solving Common Problems Using Other Swing Features
- Solving Common Layout Problems
- Solving Common Event-Handling Problems
- Solving Common Painting Problems
Problem: I'm having trouble implementing a model (or some other code that's similar to something already in Java SE Platform, Standard Edition).
Problem: Whenever the text in my text field updates, the text field's size changes.
- Look at the Java SE source code. It's distributed with the JDK, and it's a great resource for finding code examples of implementing models, firing events, and the like.
Problem: Certain areas of the content pane look weird when they're repainted.
- You should specify the preferred width of the text field by specifying the number of columns it should have room to display. To do this, you can use either an
intargument to theJTextFieldconstructor or thesetColumnsmethod.
- If you set the content pane, make sure it's opaque. You can do this by invoking
setOpaque(true)on your content pane. Note that althoughJPanels are opaque in most look and feels, that's not true in the GTK+ look and feel. See Adding Components to the Content Pane for details.- If one or more of your components performs custom painting, make sure you implemented it correctly. See Solving Common Painting Problems for help.
- You might have a thread safety problem. See the next entry.
Problem: My program is exhibiting weird symptoms that sometimes seem to be related to timing.
- Make sure your code is thread-safe. See Concurrency in Swing for details.
Problem: My modal dialog gets lost behind other windows.
- If the dialog has a null parent component, try setting it to a valid frame or component when you create it.
- This bug was fixed in the 6.0 release. For more information, see 4255200.
Problem: The scroll bar policies don't seem to be working as advertised.
Problem: My scroll pane has no scroll bars.
- Some Swing releases contain bugs in the implementations for the
VERTICAL_SCROLLBAR_AS_NEEDEDand theHORIZONTAL_SCROLLBAR_AS_NEEDEDpolicies. If feasible for your project, use the most recent release of Swing.- If the scroll pane's client can change size dynamically, the program should set the client's preferred size and then call
revalidateon the client.- Make sure you specified the policy you intended for the orientation you intended.
Problem: The divider in my split pane don't move!
- If you want a scroll bar to appear all the time, specify either
VERTICAL_SCROLLBAR_ALWAYSorHORIZONTAL_SCROLLBAR_ALWAYSfor the scroll bar policy as appropriate.- If you want the scroll bars to appear as needed, and you want to force the scroll bars to be needed when the scroll pane is created, you have two choices: either set the preferred size of scroll pane or its container, or implement a scroll-savvy class and return a value smaller than the component's standard preferred size from the
getPreferredScrollableViewportSizemethod. Refer to Sizing a Scroll Pane for information.Problem: The
- You need to set the minimum size of at least one of the components in the split pane. Refer to Positioning the Divider and Restricting Its Range for information.
setDividerLocationmethod ofJSplitPanedoesn't work.Problem: The borders on nested split panes look too wide.
- The
setDividerLocation(double)method has no effect if the split pane has no size (typically true if it isn't onscreen yet). You can either usesetDividerLocation(int)or specify the preferred sizes of the split pane's contained components and the split pane's resize weight instead. Refer to Positioning the Divider and Restricting Its Range for information.Problem: The buttons in my tool bar are too big.
- If you nest split panes, the borders accumulate  the border of the inner split panes display next to the border of the outer split pane causing borders that look extra wide. The problem is particularly noticeable when nesting many split panes. The workaround is to set the border to null on any split pane that is placed within another split pane. For information, see bug # 4131528 in the Bug Database at the Sun Developer Network (SDN).
Problem: The components in my layered pane aren't layered correctly. In fact, the layers seem to be inversed  the lower the depth the higher the component.
- Try reducing the margin for the buttons. For example:button.setMargin(new Insets(0,0,0,0));
- This can happen if you use an
intinstead of anIntegerwhen adding components to a layered pane. To see what happens, make the following change toLayeredPaneDemo:
Change this... to this... layeredPane.add(label, new Integer(i));layeredPane.add(label, i);Problem: The method call
colorChooser.setPreviewPanel(null)does not remove the color chooser's preview panel as expected.
- A
nullargument specifies the default preview panel. To remove the preview panel, specify a standard panel with no size, like this:colorChooser.setPreviewPanel(new JPanel());