All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.alee.laf.rootpane.WebWindow Maven / Gradle / Ivy

/*
 * This file is part of WebLookAndFeel library.
 *
 * WebLookAndFeel library is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * WebLookAndFeel library 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 for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with WebLookAndFeel library.  If not, see .
 */

package com.alee.laf.rootpane;

import com.alee.managers.focus.DefaultFocusTracker;
import com.alee.managers.focus.FocusManager;
import com.alee.managers.language.LanguageContainerMethods;
import com.alee.managers.language.LanguageManager;
import com.alee.managers.settings.DefaultValue;
import com.alee.managers.settings.SettingsManager;
import com.alee.managers.settings.SettingsMethods;
import com.alee.managers.settings.SettingsProcessor;
import com.alee.utils.SwingUtils;
import com.alee.utils.WindowUtils;
import com.alee.utils.swing.WindowMethods;

import javax.swing.*;
import java.awt.*;

/**
 * This JWindow extenstion class provides some additional methods and options to manipulate window behavior.
 *
 * @author Mikle Garin
 */

public class WebWindow extends JWindow implements LanguageContainerMethods, SettingsMethods, WindowMethods
{
    /**
     * Whether should close window on focus loss or not.
     */
    protected boolean closeOnFocusLoss = false;

    /**
     * Window focus tracker.
     */
    protected DefaultFocusTracker focusTracker;

    /**
     * Creates a window with no specified owner. This window will not be focusable.
     * 

* This constructor sets the component's locale property to the value returned by {@code JComponent.getDefaultLocale}. */ public WebWindow () { super (); initialize (); } /** * Creates a window with the specified {@code GraphicsConfiguration} of a screen device. This window will not be focusable. *

* This constructor sets the component's locale property to the value returned by {@code JComponent.getDefaultLocale}. * * @param gc the {@code GraphicsConfiguration} that is used to construct the new window with; if gc is {@code null}, * the system default {@code GraphicsConfiguration} is assumed */ public WebWindow ( final GraphicsConfiguration gc ) { super ( gc ); initialize (); } /** * Creates a window with the specified owner frame. * If {@code owner} is {@code null}, the shared owner will be used and this window will not be focusable. * Also, this window will not be focusable unless its owner is showing on the screen. *

* This constructor sets the component's locale property to the value returned by {@code JComponent.getDefaultLocale}. * * @param owner the frame from which the window is displayed */ public WebWindow ( final Frame owner ) { super ( owner ); initialize (); } /** * Creates a window with the owner window from the specified component. * This window will not be focusable unless its owner is showing on the screen. * If {@code owner} is {@code null}, the shared owner will be used and this window will not be focusable. *

* This constructor sets the component's locale property to the value returned by {@code JComponent.getDefaultLocale}. * * @param owner the componnt from which parent window this window is displayed */ public WebWindow ( final Component owner ) { super ( SwingUtils.getWindowAncestor ( owner ) ); initialize (); } /** * Creates a window with the specified owner window. This window will not be focusable unless its owner is showing on the screen. * If {@code owner} is {@code null}, the shared owner will be used and this window will not be focusable. *

* This constructor sets the component's locale property to the value returned by {@code JComponent.getDefaultLocale}. * * @param owner the window from which the window is displayed */ public WebWindow ( final Window owner ) { super ( owner ); initialize (); } /** * Creates a window with the specified owner window and {@code GraphicsConfiguration} of a screen device. * If {@code owner} is {@code null}, the shared owner will be used and this window will not be focusable. *

* This constructor sets the component's locale property to the value returned by {@code JComponent.getDefaultLocale}. * * @param owner the window from which the window is displayed * @param gc the {@code GraphicsConfiguration} that is used to construct the new window with; if gc is {@code null}, * the system default {@code GraphicsConfiguration} is assumed, unless {@code owner} is also null, in which * case the {@code GraphicsConfiguration} from the shared owner frame will be used */ public WebWindow ( final Window owner, final GraphicsConfiguration gc ) { super ( owner, gc ); initialize (); } /** * Additional initializtion of WebWindow settings. */ protected void initialize () { setFocusable ( true ); SwingUtils.setOrientation ( this ); // Adding focus tracker for this window // It is stored into a separate field to avoid its disposal from memory focusTracker = new DefaultFocusTracker ( true ) { @Override public boolean isTrackingEnabled () { return closeOnFocusLoss; } @Override public void focusChanged ( final boolean focused ) { if ( closeOnFocusLoss && WebWindow.this.isShowing () && !focused ) { setVisible ( false ); } } }; FocusManager.addFocusTracker ( this, focusTracker ); } /** * Returns whether should close window on focus loss or not. * * @return true if should close window on focus loss, false otherwise */ public boolean isCloseOnFocusLoss () { return closeOnFocusLoss; } /** * Sets whether should close window on focus loss or not. * * @param closeOnFocusLoss whether should close window on focus loss or not */ public void setCloseOnFocusLoss ( final boolean closeOnFocusLoss ) { this.closeOnFocusLoss = closeOnFocusLoss; } /** * {@inheritDoc} */ @Override public void setLanguageContainerKey ( final String key ) { LanguageManager.registerLanguageContainer ( this, key ); } /** * {@inheritDoc} */ @Override public void removeLanguageContainerKey () { LanguageManager.unregisterLanguageContainer ( this ); } /** * {@inheritDoc} */ @Override public String getLanguageContainerKey () { return LanguageManager.getLanguageContainerKey ( this ); } /** * {@inheritDoc} */ @Override public void registerSettings ( final String key ) { SettingsManager.registerComponent ( this, key ); } /** * {@inheritDoc} */ @Override public void registerSettings ( final String key, final Class defaultValueClass ) { SettingsManager.registerComponent ( this, key, defaultValueClass ); } /** * {@inheritDoc} */ @Override public void registerSettings ( final String key, final Object defaultValue ) { SettingsManager.registerComponent ( this, key, defaultValue ); } /** * {@inheritDoc} */ @Override public void registerSettings ( final String group, final String key ) { SettingsManager.registerComponent ( this, group, key ); } /** * {@inheritDoc} */ @Override public void registerSettings ( final String group, final String key, final Class defaultValueClass ) { SettingsManager.registerComponent ( this, group, key, defaultValueClass ); } /** * {@inheritDoc} */ @Override public void registerSettings ( final String group, final String key, final Object defaultValue ) { SettingsManager.registerComponent ( this, group, key, defaultValue ); } /** * {@inheritDoc} */ @Override public void registerSettings ( final String key, final boolean loadInitialSettings, final boolean applySettingsChanges ) { SettingsManager.registerComponent ( this, key, loadInitialSettings, applySettingsChanges ); } /** * {@inheritDoc} */ @Override public void registerSettings ( final String key, final Class defaultValueClass, final boolean loadInitialSettings, final boolean applySettingsChanges ) { SettingsManager.registerComponent ( this, key, defaultValueClass, loadInitialSettings, applySettingsChanges ); } /** * {@inheritDoc} */ @Override public void registerSettings ( final String key, final Object defaultValue, final boolean loadInitialSettings, final boolean applySettingsChanges ) { SettingsManager.registerComponent ( this, key, defaultValue, loadInitialSettings, applySettingsChanges ); } /** * {@inheritDoc} */ @Override public void registerSettings ( final String group, final String key, final Class defaultValueClass, final boolean loadInitialSettings, final boolean applySettingsChanges ) { SettingsManager.registerComponent ( this, group, key, defaultValueClass, loadInitialSettings, applySettingsChanges ); } /** * {@inheritDoc} */ @Override public void registerSettings ( final String group, final String key, final Object defaultValue, final boolean loadInitialSettings, final boolean applySettingsChanges ) { SettingsManager.registerComponent ( this, group, key, defaultValue, loadInitialSettings, applySettingsChanges ); } /** * {@inheritDoc} */ @Override public void registerSettings ( final SettingsProcessor settingsProcessor ) { SettingsManager.registerComponent ( this, settingsProcessor ); } /** * {@inheritDoc} */ @Override public void unregisterSettings () { SettingsManager.unregisterComponent ( this ); } /** * {@inheritDoc} */ @Override public void loadSettings () { SettingsManager.loadComponentSettings ( this ); } /** * {@inheritDoc} */ @Override public void saveSettings () { SettingsManager.saveComponentSettings ( this ); } /** * {@inheritDoc} */ @Override public WebWindow setWindowOpaque ( final boolean opaque ) { return WindowUtils.setWindowOpaque ( this, opaque ); } /** * {@inheritDoc} */ @Override public boolean isWindowOpaque () { return WindowUtils.isWindowOpaque ( this ); } /** * {@inheritDoc} */ @Override public WebWindow setWindowOpacity ( final float opacity ) { return WindowUtils.setWindowOpacity ( this, opacity ); } /** * {@inheritDoc} */ @Override public float getWindowOpacity () { return WindowUtils.getWindowOpacity ( this ); } /** * {@inheritDoc} */ @Override public WebWindow center () { return WindowUtils.center ( this ); } /** * {@inheritDoc} */ @Override public WebWindow center ( final Component relativeTo ) { return WindowUtils.center ( this, relativeTo ); } /** * {@inheritDoc} */ @Override public WebWindow center ( final int width, final int height ) { return WindowUtils.center ( this, width, height ); } /** * {@inheritDoc} */ @Override public WebWindow center ( final Component relativeTo, final int width, final int height ) { return WindowUtils.center ( this, relativeTo, width, height ); } /** * {@inheritDoc} */ @Override public WebWindow packToWidth ( final int width ) { return WindowUtils.packToWidth ( this, width ); } /** * {@inheritDoc} */ @Override public WebWindow packToHeight ( final int height ) { return WindowUtils.packToHeight ( this, height ); } /** * {@inheritDoc} */ @Override public WebWindow packAndCenter () { return WindowUtils.packAndCenter ( this ); } /** * {@inheritDoc} */ @Override public WebWindow packAndCenter ( final boolean animate ) { return WindowUtils.packAndCenter ( this, animate ); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy