com.alee.painter.decoration.AbstractDecoration Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of weblaf-ui Show documentation
Show all versions of weblaf-ui Show documentation
WebLaf is a Java Swing Look and Feel and extended components library for cross-platform applications
/*
* 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;
import com.alee.utils.MergeUtils;
import com.alee.utils.ReflectUtils;
import com.alee.utils.TextUtils;
import com.alee.utils.xml.ListToStringConverter;
import com.thoughtworks.xstream.annotations.XStreamAsAttribute;
import com.thoughtworks.xstream.annotations.XStreamConverter;
import javax.swing.*;
import java.awt.*;
import java.util.List;
/**
* Abstract component state decoration providing basic settings.
*
* @param component type
* @param decoration type
* @author Mikle Garin
*/
public abstract class AbstractDecoration> implements IDecoration
{
/**
* Default component state ID.
* Added to avoid default state ID being null.
*/
public static final String defaultStateId = "default";
/**
* Component states this decoration is describing separated by comma.
* Various components might use multiple states to describe their decoration.
*/
@XStreamAsAttribute
@XStreamConverter ( ListToStringConverter.class )
protected List states;
/**
* Whether or not decoration should be displayed.
* This doesn't affect anything painted outside, for example by any {@link com.alee.painter.SpecificPainter}.
* In case this decoration is used by {@link com.alee.painter.SectionPainter} this only affects section visibility.
*/
@XStreamAsAttribute
protected Boolean visible = true;
/**
* Decoration size.
* It can be specified to provide fixed decoration size.
*/
@XStreamAsAttribute
protected Dimension size;
/**
* Decoration opacity.
* This doesn't affect anything painted outside, for example by any {@link com.alee.painter.SpecificPainter}.
* In case this decoration is used by {@link com.alee.painter.SectionPainter} this opacity is only applied to the section.
*/
@XStreamAsAttribute
protected Float opacity;
/**
* Whether or not this decoration is applied only to a section of the component.
* Provided explicitely by the painted using this decoration.
*/
protected transient Boolean section;
@Override
public String getId ()
{
return states != null ? TextUtils.listToString ( states, STATES_SEPARATOR ) : defaultStateId;
}
@Override
public List getStates ()
{
return states;
}
@Override
public boolean isVisible ()
{
return visible == null || visible;
}
@Override
public boolean isSection ()
{
return section != null && section;
}
@Override
public void setSection ( final boolean section )
{
this.section = section;
}
/**
* Returns decoration opacity.
*
* @return decoration opacity
*/
public float getOpacity ()
{
return opacity != null ? opacity : 1f;
}
@Override
public Dimension getPreferredSize ()
{
return size != null ? size : null;
}
@Override
public I merge ( final I state )
{
if ( state.visible != null )
{
visible = state.visible;
}
if ( state.size != null )
{
size = state.size;
}
if ( state.opacity != null )
{
opacity = state.opacity;
}
return ( I ) this;
}
@Override
public I clone ()
{
return ( I ) MergeUtils.cloneByFieldsSafely ( this );
}
@Override
public String toString ()
{
return ReflectUtils.getClassName ( this ) + " [ id=" + getId () + "; visible=" + isVisible () + " ]";
}
}