com.alee.painter.decoration.background.AbstractTextureBackground 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.painter.decoration.background;
import com.alee.api.clone.behavior.OmitOnClone;
import com.alee.api.jdk.Objects;
import com.alee.api.merge.behavior.OmitOnMerge;
import com.alee.painter.decoration.IDecoration;
import com.alee.utils.GraphicsUtils;
import javax.swing.*;
import java.awt.*;
/**
* Convenient base class for any texture-based {@link IBackground} implementation.
*
* @param component type
* @param decoration type
* @param background type
* @author Mikle Garin
*/
public abstract class AbstractTextureBackground, I extends AbstractTextureBackground>
extends AbstractBackground
{
/**
* Cached texture paint.
* It is cached for performance reasons.
* You can clean the cache at any time in implementation of this abstract class.
*/
@OmitOnClone
@OmitOnMerge
protected transient TexturePaint paint = null;
/**
* Cached texture bounds.
*/
@OmitOnClone
@OmitOnMerge
protected transient Rectangle bounds = null;
/**
* Resets texture cache.
*/
public void clearCache ()
{
paint = null;
bounds = null;
}
@Override
public void paint ( final Graphics2D g2d, final Rectangle bounds, final C c, final D d, final Shape shape )
{
final float opacity = getOpacity ();
if ( opacity > 0 )
{
// Checking texture state
if ( isPaintable () )
{
// Updating cached texture paint
final Rectangle b = shape.getBounds ();
if ( paint == null || Objects.notEquals ( this.bounds, b ) )
{
paint = getTexturePaint ( b );
}
// Do not paint anything if texture paint was not set
if ( paint != null )
{
final Composite oc = GraphicsUtils.setupAlphaComposite ( g2d, opacity, opacity < 1f );
final Paint op = GraphicsUtils.setupPaint ( g2d, paint );
g2d.setPaint ( paint );
g2d.fill ( shape );
GraphicsUtils.restorePaint ( g2d, op );
GraphicsUtils.restoreComposite ( g2d, oc, opacity < 1f );
}
}
}
}
/**
* Returns whether or not texture background is paintable right now.
*
* @return true if texture background is paintable right now, false otherwise
*/
protected abstract boolean isPaintable ();
/**
* Returns texture paint implementation.
*
* @param bounds painting bounds
* @return texture paint implementation
*/
protected abstract TexturePaint getTexturePaint ( Rectangle bounds );
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy