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

bibliothek.gui.dock.util.AWTComponentCaptureStrategy Maven / Gradle / Ivy

/*
 * Bibliothek - DockingFrames
 * Library built on Java/Swing, allows the user to "drag and drop"
 * panels containing any Swing-Component the developer likes to add.
 * 
 * Copyright (C) 2008 Benjamin Sigg
 * 
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This 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
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 * 
 * Benjamin Sigg
 * [email protected]
 * CH - Switzerland
 */
package bibliothek.gui.dock.util;

import java.awt.AWTException;
import java.awt.Component;
import java.awt.Container;
import java.awt.Graphics;
import java.awt.GraphicsConfiguration;
import java.awt.GraphicsDevice;
import java.awt.Point;
import java.awt.Rectangle;
import java.awt.Robot;
import java.awt.image.BufferedImage;

import javax.swing.SwingUtilities;

import bibliothek.gui.DockController;
import bibliothek.gui.dock.util.property.ConstantPropertyFactory;

/**
 * Used to capture an image of a {@link Component} which either is from AWT,
 * or has children from AWT. 
 * @author Benjamin Sigg
 */
public interface AWTComponentCaptureStrategy {
    /**
     * This strategy just takes a real screen capture of the area in which the
     * component is supposed to be.
     */
    public static final AWTComponentCaptureStrategy SCREEN_CAPTURE_STRATEGY = new AWTComponentCaptureStrategy(){
        public BufferedImage createCapture( DockController controller, Component component ){
            try {
                if( !component.isShowing() )
                    return null;

                GraphicsConfiguration configuration = component.getGraphicsConfiguration();
                if( configuration == null )
                    return null;

                GraphicsDevice device = configuration.getDevice();
                if( device == null )
                    return null;

                Robot deviceRobot = new Robot( device );

                Point location = new Point( 0, 0 );
                SwingUtilities.convertPointToScreen( location, component );

                return deviceRobot.createScreenCapture( new Rectangle( location, component.getSize() ) );
            }
            catch( AWTException e ) {
                e.printStackTrace();
                return null;
            }
            catch( SecurityException e ){
                // if in a secure environment...
                return null;
            }
        }
    };
    
    /**
     * This strategy calls {@link Component#paintAll(Graphics)} recursively
     * on all {@link Component}s.
     */
    public static final AWTComponentCaptureStrategy RECURSIVE_PAINT_STRATEGY = new AWTComponentCaptureStrategy(){
        public BufferedImage createCapture( DockController controller,
                Component component ) {
         
            BufferedImage image = new BufferedImage( component.getWidth(), component.getHeight(), BufferedImage.TYPE_INT_ARGB );
            Graphics g = image.createGraphics();
            forcePaint( component, g );
            g.dispose();
            return image;

        }
        
        /**
         * Forces component and each of its children to be painted.
         * @param component the component to paint
         * @param g the graphics context to use
         */
        private void forcePaint( Component component, Graphics g ){
            component.paintAll( g );
            if( component instanceof Container ){
                Container container = (Container)component;
                for( int i = 0, n = container.getComponentCount(); i 0 && height > 0 ){
                        Graphics sub = g.create( next.getX(), next.getY(), width, height );
                        forcePaint( next, sub );
                        sub.dispose();
                    }
                }
            }
        }
    };
    

    /**
     * This strategy calls {@link Component#paintAll(Graphics)} on the given component.
     */
    public static final AWTComponentCaptureStrategy PAINT_ALL_STRATEGY = new AWTComponentCaptureStrategy(){
        public BufferedImage createCapture( DockController controller,
                Component component ) {
         
            BufferedImage image = new BufferedImage( component.getWidth(), component.getHeight(), BufferedImage.TYPE_INT_ARGB );
            Graphics g = image.createGraphics();
            component.paintAll( g );
            g.dispose();
            return image;

        }
    };
    
    /**
     * The {@link PropertyKey} for a {@link AWTComponentCaptureStrategy}.
     */
    public static final PropertyKey STRATEGY = 
        new PropertyKey( "dock.AWTComponentCaptureStrategy",
        		new ConstantPropertyFactory( PAINT_ALL_STRATEGY ), true );
    
    
    /**
     * Creates a new image that has the same size as component and
     * contains all the things painted on component.
     * @param controller the controller for which the image is needed
     * @param component the component to paint, its width and height must be
     * at least 1.
     * @return the new image or null if no image can be created
     */
    public BufferedImage createCapture( DockController controller, Component component );
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy