/*
* JasperReports - Free Java Reporting Library.
* Copyright (C) 2001 - 2009 Jaspersoft Corporation. All rights reserved.
* http://www.jaspersoft.com
*
* Unless you have purchased a commercial license agreement from Jaspersoft,
* the following license terms apply:
*
* This program is part of JasperReports.
*
* JasperReports 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 3 of the License, or
* (at your option) any later version.
*
* JasperReports 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 JasperReports. If not, see <http://www.gnu.org/licenses/>.
*/
package net.sf.jasperreports.engine.base;
import java.awt.Color;
import java.io.IOException;
import java.io.ObjectInputStream;
import net.sf.jasperreports.engine.JRConstants;
import net.sf.jasperreports.engine.JRGraphicElement;
import net.sf.jasperreports.engine.JRPen;
import net.sf.jasperreports.engine.type.FillEnum;
import net.sf.jasperreports.engine.util.JRPenUtil;
import net.sf.jasperreports.engine.util.JRStyleResolver;
/**
* This class provides functionality common to graphic elements. It provides implementation for the methods described
* in <tt>JRTextElement</tt>.
* @author Teodor Danciu (teodord@users.sourceforge.net)
* @version $Id: JRBaseGraphicElement.java 3833 2010-05-27 14:16:59Z teodord $
*/
public abstract class JRBaseGraphicElement extends JRBaseElement implements JRGraphicElement
{
/**
*
*/
private static final long serialVersionUID = JRConstants.SERIAL_VERSION_UID;
/**
*
*/
protected JRPen linePen;
protected FillEnum fillValue;
/**
* Constructs an empty graphic element. By default graphic elements are opaque.
*
protected JRBaseGraphicElement()
{
super();
}
/**
* Initializes properties that are specific to graphic elements. Common properties are initialized by its
* parent constructor.
* @param graphicElement an element whose properties are copied to this element. Usually it is a
* {@link net.sf.jasperreports.engine.design.JRDesignGraphicElement} that must be transformed into an
* <tt>JRBaseGraphicElement</tt> at compile time.
* @param factory a factory used in the compile process
*/
protected JRBaseGraphicElement(JRGraphicElement graphicElement, JRBaseObjectFactory factory)
{
super(graphicElement, factory);
linePen = graphicElement.getLinePen().clone(this);
fillValue = graphicElement.getOwnFillValue();
}
/**
*
*/
public JRPen getLinePen()
{
return linePen;
}
/**
* @deprecated Replaced by {@link #getLinePen()}
*/
public byte getPen()
{
return JRPenUtil.getPenFromLinePen(linePen);
}
/**
* @deprecated Replaced by {@link #getLinePen()}
*/
public Byte getOwnPen()
{
return JRPenUtil.getOwnPenFromLinePen(linePen);
}
/**
* @deprecated Replaced by {@link #getLinePen()}
*/
public void setPen(byte pen)
{
setPen(new Byte(pen));
}
/**
* @deprecated Replaced by {@link #getLinePen()}
*/
public void setPen(Byte pen)
{
JRPenUtil.setLinePenFromPen(pen, linePen);
}
/**
* @deprecated Replaced by {@link #getFillValue()}
*/
public byte getFill()
{
return getFillValue().getValue();
}
/**
* @deprecated Replaced by {@link #getOwnFillValue()}
*/
public Byte getOwnFill()
{
return getOwnFillValue() == null ? null : getOwnFillValue().getValueByte();
}
/**
* @deprecated Replaced by {@link #setFill(FillEnum)}
*/
public void setFill(byte fill)
{
setFill(FillEnum.getByValue(fill));
}
/**
* @deprecated Replaced by {@link #setFill(FillEnum)}
*/
public void setFill(Byte fill)
{
setFill(FillEnum.getByValue(fill));
}
/**
*
*/
public FillEnum getFillValue()
{
return JRStyleResolver.getFillValue(this);
}
public FillEnum getOwnFillValue()
{
return this.fillValue;
}
/**
*
*/
public void setFill(FillEnum fillValue)
{
FillEnum old = this.fillValue;
this.fillValue = fillValue;
getEventSupport().firePropertyChange(JRBaseStyle.PROPERTY_FILL, old, this.fillValue);
}
/**
*
*/
public Float getDefaultLineWidth()
{
return JRPen.LINE_WIDTH_1;
}
/**
*
*/
public Color getDefaultLineColor()
{
return getForecolor();
}
/**
*
*/
public Object clone()
{
JRBaseGraphicElement clone = (JRBaseGraphicElement)super.clone();
clone.linePen = linePen.clone(clone);
return clone;
}
/*
* These fields are only for serialization backward compatibility.
*/
private int PSEUDO_SERIAL_VERSION_UID = JRConstants.PSEUDO_SERIAL_VERSION_UID_3_7_2; //NOPMD
/**
* @deprecated
*/
private Byte pen;
/**
* @deprecated
*/
private Byte fill;
private void readObject(ObjectInputStream in) throws IOException, ClassNotFoundException
{
in.defaultReadObject();
if (PSEUDO_SERIAL_VERSION_UID < JRConstants.PSEUDO_SERIAL_VERSION_UID_3_7_2)
{
fillValue = FillEnum.getByValue(fill);
fill = null;
}
if (linePen == null)
{
linePen = new JRBasePen(this);
JRPenUtil.setLinePenFromPen(pen, linePen);
pen = null;
}
}
}