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

com.alee.extended.dock.data.DockableFrameElement 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.extended.dock.data;

import com.alee.extended.dock.DockableFrameState;
import com.alee.extended.dock.WebDockableFrame;
import com.alee.extended.dock.WebDockablePane;
import com.alee.utils.CoreSwingUtils;
import com.alee.utils.xml.RectangleConverter;
import com.thoughtworks.xstream.annotations.XStreamAlias;
import com.thoughtworks.xstream.annotations.XStreamAsAttribute;
import com.thoughtworks.xstream.annotations.XStreamConverter;

import java.awt.*;
import java.util.List;

/**
 * {@link DockableElement} representing dockable frame.
 *
 * @author Mikle Garin
 * @see How to use WebDockablePane
 * @see WebDockablePane
 */
@XStreamAlias ( "DockableFrame" )
public class DockableFrameElement extends AbstractDockableElement
{
    /**
     * Saved dockable frame state.
     * It always stores current frame state whatever it could be.
     */
    @XStreamAsAttribute
    protected DockableFrameState state;

    /**
     * State to restore frame into from {@link DockableFrameState#minimized}.
     * It is not exactly previous frame state, but the state which is meaningful in terms of restoration.
     * It can be either {@link DockableFrameState#docked} or {@link DockableFrameState#floating}.
     */
    @XStreamAsAttribute
    protected DockableFrameState restoreState;

    /**
     * Bounds for {@link DockableFrameState#floating} frame state dialog.
     * These bounds contain position of the frame on the screen not including dialog decorations.
     * Initially these bounds are {@code null} and only filled in on the first floating state use.
     */
    @XStreamAsAttribute
    @XStreamConverter ( RectangleConverter.class )
    protected Rectangle floatingBounds;

    /**
     * Constructs new frame element.
     *
     * @param frame dockable frame
     */
    public DockableFrameElement ( final WebDockableFrame frame )
    {
        super ( frame.getId () );
        setState ( frame.getState () );
        setRestoreState ( frame.getRestoreState () );
        setSize ( frame.getPreferredSize () );
        setFloatingBounds ( null );
    }

    /**
     * Returns saved dockable frame state.
     *
     * @return saved dockable frame state
     */
    public DockableFrameState getState ()
    {
        return state;
    }

    /**
     * Sets saved dockable frame state.
     *
     * @param state saved dockable frame state
     */
    public void setState ( final DockableFrameState state )
    {
        this.state = state;
    }

    /**
     * Returns state to restore frame into from {@link DockableFrameState#minimized}.
     *
     * @return state to restore frame into from {@link DockableFrameState#minimized}
     */
    public DockableFrameState getRestoreState ()
    {
        return restoreState;
    }

    /**
     * Sets state to restore frame into from {@link DockableFrameState#minimized}.
     *
     * @param state state to restore frame into from {@link DockableFrameState#minimized}
     */
    public void setRestoreState ( final DockableFrameState state )
    {
        this.restoreState = state;
    }

    /**
     * Returns bounds for {@link DockableFrameState#floating} frame state dialog.
     *
     * @return bounds for {@link DockableFrameState#floating} frame state dialog
     */
    public Rectangle getFloatingBounds ()
    {
        return floatingBounds;
    }

    /**
     * Sets bounds for {@link DockableFrameState#floating} frame state dialog.
     *
     * @param bounds bounds for {@link DockableFrameState#floating} frame state dialog
     */
    public void setFloatingBounds ( final Rectangle bounds )
    {
        this.floatingBounds = bounds;
    }

    /**
     * Saves bounds for {@link DockableFrameState#floating} frame state dialog.
     *
     * @param frame {@link WebDockableFrame}
     */
    public void saveFloatingBounds ( final WebDockableFrame frame )
    {
        final Rectangle bounds = CoreSwingUtils.getBoundsOnScreen ( frame );
        setFloatingBounds ( bounds );
    }

    @Override
    public boolean isContent ()
    {
        return false;
    }

    @Override
    public boolean isVisible ( final WebDockablePane dockablePane )
    {
        final WebDockableFrame frame = dockablePane.getFrame ( getId () );
        return frame != null && frame.isDocked ();
    }

    @Override
    public void layout ( final WebDockablePane dockablePane, final Rectangle bounds, final List resizeableAreas )
    {
        // Saving bounds
        setBounds ( bounds );

        // Placing dockable frame
        dockablePane.getFrame ( getId () ).setBounds ( bounds );
    }

    @Override
    public Dimension getMinimumSize ( final WebDockablePane dockablePane )
    {
        final Dimension min = dockablePane.getMinimumElementSize ();

        // Validating size
        // This is made here to optimize performance
        if ( size.width < min.width || size.height < min.height )
        {
            setSize ( new Dimension ( Math.max ( size.width, min.width ), Math.max ( size.height, min.height ) ) );
        }

        return min;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy