| /* |
| * Copyright (c) 1998, 2006, Oracle and/or its affiliates. All rights reserved. |
| * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
| * |
| * This code is free software; you can redistribute it and/or modify it |
| * under the terms of the GNU General Public License version 2 only, as |
| * published by the Free Software Foundation. Oracle designates this |
| * particular file as subject to the "Classpath" exception as provided |
| * by Oracle in the LICENSE file that accompanied this code. |
| * |
| * This code is distributed in the hope that it will be useful, but WITHOUT |
| * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
| * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
| * version 2 for more details (a copy is included in the LICENSE file that |
| * accompanied this code). |
| * |
| * You should have received a copy of the GNU General Public License version |
| * 2 along with this work; if not, write to the Free Software Foundation, |
| * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
| * |
| * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
| * or visit www.oracle.com if you need additional information or have any |
| * questions. |
| */ |
| |
| package javax.swing; |
| |
| import java.awt.Component; |
| import java.awt.Container; |
| |
| |
| /** |
| * This interface is implemented by components that have a single |
| * JRootPane child: JDialog, JFrame, JWindow, JApplet, JInternalFrame. |
| * The methods in this interface are just <i>covers</i> for the JRootPane |
| * properties, e.g. <code>getContentPane()</code> is generally implemented |
| * like this:<pre> |
| * public Container getContentPane() { |
| * return getRootPane().getContentPane(); |
| * } |
| * </pre> |
| * This interface serves as a <i>marker</i> for Swing GUI builders |
| * that need to treat components like JFrame, that contain a |
| * single JRootPane, specially. For example in a GUI builder, |
| * dropping a component on a RootPaneContainer would be interpreted |
| * as <code>frame.getContentPane().add(child)</code>. |
| * <p> |
| * For conveniance |
| * <code>JFrame</code>, <code>JDialog</code>, <code>JWindow</code>, |
| * <code>JApplet</code> and <code>JInternalFrame</code>, by default, |
| * forward, by default, all calls to the <code>add</code>, |
| * <code>remove</code> and <code>setLayout</code> methods, to the |
| * <code>contentPane</code>. This means you can call: |
| * <pre> |
| * rootPaneContainer.add(component); |
| * </pre> |
| * instead of: |
| * <pre> |
| * rootPaneContainer.getContentPane().add(component); |
| * </pre> |
| * <p> |
| * The behavior of the <code>add</code> and |
| * <code>setLayout</code> methods for |
| * <code>JFrame</code>, <code>JDialog</code>, <code>JWindow</code>, |
| * <code>JApplet</code> and <code>JInternalFrame</code> is controlled by |
| * the <code>rootPaneCheckingEnabled</code> property. If this property is |
| * true (the default), then calls to these methods are |
| * forwarded to the <code>contentPane</code>; if false, these |
| * methods operate directly on the <code>RootPaneContainer</code>. This |
| * property is only intended for subclasses, and is therefore protected. |
| * |
| * @see JRootPane |
| * @see JFrame |
| * @see JDialog |
| * @see JWindow |
| * @see JApplet |
| * @see JInternalFrame |
| * |
| * @author Hans Muller |
| */ |
| public interface RootPaneContainer |
| { |
| /** |
| * Return this component's single JRootPane child. A conventional |
| * implementation of this interface will have all of the other |
| * methods indirect through this one. The rootPane has two |
| * children: the glassPane and the layeredPane. |
| * |
| * @return this components single JRootPane child. |
| * @see JRootPane |
| */ |
| JRootPane getRootPane(); |
| |
| |
| /** |
| * The "contentPane" is the primary container for application |
| * specific components. Applications should add children to |
| * the contentPane, set its layout manager, and so on. |
| * <p> |
| * The contentPane may not be null. |
| * <p> |
| * Generally implemented with |
| * <code>getRootPane().setContentPane(contentPane);</code> |
| * |
| * @exception java.awt.IllegalComponentStateException (a runtime |
| * exception) if the content pane parameter is null |
| * @param contentPane the Container to use for the contents of this |
| * JRootPane |
| * @see JRootPane#getContentPane |
| * @see #getContentPane |
| */ |
| void setContentPane(Container contentPane); |
| |
| |
| /** |
| * Returns the contentPane. |
| * |
| * @return the value of the contentPane property. |
| * @see #setContentPane |
| */ |
| Container getContentPane(); |
| |
| |
| /** |
| * A Container that manages the contentPane and in some cases a menu bar. |
| * The layeredPane can be used by descendants that want to add a child |
| * to the RootPaneContainer that isn't layout managed. For example |
| * an internal dialog or a drag and drop effect component. |
| * <p> |
| * The layeredPane may not be null. |
| * <p> |
| * Generally implemented with<pre> |
| * getRootPane().setLayeredPane(layeredPane);</pre> |
| * |
| * @exception java.awt.IllegalComponentStateException (a runtime |
| * exception) if the layered pane parameter is null |
| * @see #getLayeredPane |
| * @see JRootPane#getLayeredPane |
| */ |
| void setLayeredPane(JLayeredPane layeredPane); |
| |
| |
| /** |
| * Returns the layeredPane. |
| * |
| * @return the value of the layeredPane property. |
| * @see #setLayeredPane |
| */ |
| JLayeredPane getLayeredPane(); |
| |
| |
| /** |
| * The glassPane is always the first child of the rootPane |
| * and the rootPanes layout manager ensures that it's always |
| * as big as the rootPane. By default it's transparent and |
| * not visible. It can be used to temporarily grab all keyboard |
| * and mouse input by adding listeners and then making it visible. |
| * by default it's not visible. |
| * <p> |
| * The glassPane may not be null. |
| * <p> |
| * Generally implemented with |
| * <code>getRootPane().setGlassPane(glassPane);</code> |
| * |
| * @see #getGlassPane |
| * @see JRootPane#setGlassPane |
| */ |
| void setGlassPane(Component glassPane); |
| |
| |
| /** |
| * Returns the glassPane. |
| * |
| * @return the value of the glassPane property. |
| * @see #setGlassPane |
| */ |
| Component getGlassPane(); |
| |
| } |