Glassed Pane

Jars top 1% rated

GlassedPane is a simple swing component that facilitates the usage of a glass pane, usually limited to the JRootPane, to any swing container.

This example shows it in action, with a snapshot shown below:

In this snapshot, one component in the frame (a table plus its scroll pane), is blocked behind a grayed, semitransparent glass that shows an animated icon. Under Netbeans' Matisse, this component appears as:

There are two working components in action: the GlassPane, blocking the content, and the GlassedPane, a container for both the normal content and the glass itself. It must be noted that the GlassPane is any JComponent. Although it is intended to be kind of a glass blocking the normal component, it could be any other component to replace the usual one. In this sense, GlassedPane is implementing a subset of the functionality directly provided by the JLayeredPane: indeed, the behaviour provided by GlassedPane can be implemented directly using the standard JLayeredPane; its value is to simplify its usage for the specific glass scenario.

Usage and javadoc

The javadoc information for the library is available here

The following code, extracted from the test included in the distribution, shows how the GlassedPane is implemented in the example above:

//initialization, empty constructor
net.coderazzi.glasspane.GlassedPane glassPane = new net.coderazzi.glasspane.GlassedPane();

//set the layout. It is a normal container
glassPane.getContentPane().setLayout(new java.awt.BorderLayout());

//add the normal component
glassPane.getContentPane().add(jScrollPane2, java.awt.BorderLayout.CENTER);

//add the glasspane itself to a swing container
jSplitPane1.setLeftComponent(glassPane);

Afterwards, the glass pane can be visualized / hidden using code such as:

glassPane.getGlassPane().setVisible(booleanValue);

Default behaviour

By default, the content pane is a JPanel, although the user can setup any other swing container instead.

Also by default, the glass pane is a GlassPane. However, any other component can be instantiated by default, just by overriding the system property "net.coderazzi.glasspane.glassclass", defined as GlassedPane.GLASS_CLASS_PROPERTY. Obviously, it is also possible to use the normal API to set other component, using the method GlassedPane.setGlassPane

The default glass pane merely blocks the user access to the content behind, and is displayed in a grayed semitransparent color. It is possible to define also the default color and degree of transparency, using system properties:

Alternatively, it is possible to just invoke GlassPane.setColor on the GlassPane instance.

The library is provided with a second GlassPane, LabelGlassPane, with adds a JLabel, centered automatically in the GlassPane. It is possible to setup a message or an icon. By default, it will use the icon found on the system property "net.coderazzi.glasspane.labelicon", defined as LabelGlassPane.GLASS_MESSAGE_ICON_PROPERTY.

Similar functionality

Before writting this component, I checked for existing implementations. I liked specially this one in The Rabbit Hole. Although it is not really equivalent on functionality (does not block the user input), it has the advantage that there is no need to create a specific component in order to hide the content behind: it is painted directly over the component to hide. The code and the list of TODOs inside discouraged me, together with the notion to have to implement the paint method -not being able to just using a JLabel, with an icon / animated icon-.

Download

This component is available with the MIT open source license (see below its text).

As of January 2025, this project has been mavenized, and the underlying git repository made public

To build the library, use:

mvn package

To execute the example, use:

mvn exec:java

License

GlassPane is available under the MIT license.

Copyright (c) 2009 Luis M. Pena  - lu@coderazzi.net

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.

The provided GlassedPane component's icon forms part of the WYSIWYG Sapphire set of free icons, available at dryicons

The included example contains an animated gif, generated with the nice ajax loading gif generator