/* * Copyright (c) 1998, 2008, Oracle and/or its affiliates. All rights reserved. * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. * * * * * * * * * * * * * * * * * * * * */ package com.sun.java.swing.plaf.windows; import javax.swing.DefaultDesktopManager; import javax.swing.JInternalFrame; import javax.swing.JLayeredPane; import java.awt.Component; import java.awt.Container; import java.awt.Dimension; import java.beans.PropertyVetoException; import java.util.Vector; import java.lang.ref.WeakReference; /** * This class implements a DesktopManager which more closely follows * the MDI model than the DefaultDesktopManager. Unlike the * DefaultDesktopManager policy, MDI requires that the selected * and activated child frames are the same, and that that frame * always be the top-most window. *
* The maximized state is managed by the DesktopManager with MDI,
* instead of just being a property of the individual child frame.
* This means that if the currently selected window is maximized
* and another window is selected, that new window will be maximized.
*
* @see javax.swing.DefaultDesktopManager
* @author Thomas Ball
*/
public class WindowsDesktopManager extends DefaultDesktopManager
implements java.io.Serializable, javax.swing.plaf.UIResource {
/* The frame which is currently selected/activated.
* We store this value to enforce MDI's single-selection model.
*/
private WeakReference