com.alee.painter.decoration.background.AlphaLayerBackground Maven / Gradle / Ivy
The newest version!
/*
* 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.painter.decoration.background;
import com.alee.painter.decoration.IDecoration;
import com.alee.utils.ColorUtils;
import com.alee.utils.ImageUtils;
import com.thoughtworks.xstream.annotations.XStreamAlias;
import com.thoughtworks.xstream.annotations.XStreamAsAttribute;
import javax.swing.*;
import java.awt.*;
import java.awt.image.BufferedImage;
/**
* Alpha layer background.
* Fills component shape with an alpha layer -like background.
*
* @param component type
* @param decoration type
* @param background type
* @author Mikle Garin
*/
@XStreamAlias ( "AlphaLayerBackground" )
public class AlphaLayerBackground, I extends AlphaLayerBackground>
extends AbstractTextureBackground
{
/**
* Cells size.
*/
@XStreamAsAttribute
protected Dimension size;
/**
* Dark cell color.
*/
@XStreamAsAttribute
protected Color darkColor;
/**
* Light cell color.
*/
@XStreamAsAttribute
protected Color lightColor;
/**
* Returns cells size.
*
* @return cells size
*/
public Dimension getSize ()
{
return size != null ? size : new Dimension ( 10, 10 );
}
/**
* Returns dark cell color.
*
* @return dark cell color
*/
public Color getDarkColor ()
{
return darkColor != null ? darkColor : ColorUtils.color ( 204, 204, 204 );
}
/**
* Returns light cell color.
*
* @return light cell color
*/
public Color getLightColor ()
{
return lightColor != null ? lightColor : Color.WHITE;
}
@Override
protected boolean isPaintable ()
{
final Dimension size = getSize ();
return size.width > 0 && size.height > 0;
}
@Override
protected TexturePaint getTexturePaint ( final Rectangle bounds )
{
final BufferedImage image = createTextureImage ();
final Rectangle anchor = new Rectangle ( bounds.x, bounds.y, image.getWidth (), image.getHeight () );
return new TexturePaint ( image, anchor );
}
/**
* Returns texture image.
*
* @return texture image
*/
protected BufferedImage createTextureImage ()
{
final Dimension size = getSize ();
final Color darkColor = getDarkColor ();
final Color lightColor = getLightColor ();
final BufferedImage image = ImageUtils.createCompatibleImage ( size.width * 2, size.height * 2, Transparency.OPAQUE );
final Graphics2D g2d = image.createGraphics ();
if ( darkColor != null )
{
g2d.setPaint ( darkColor );
g2d.fillRect ( 0, 0, size.width, size.height );
g2d.fillRect ( size.width, size.height, size.width, size.height );
}
if ( lightColor != null )
{
g2d.setPaint ( lightColor );
g2d.fillRect ( size.width, 0, size.width, size.height );
g2d.fillRect ( 0, size.height, size.width, size.height );
}
g2d.dispose ();
return image;
}
}