/* * 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.fill; import java.io.IOException; import java.io.ObjectInputStream; import net.sf.jasperreports.engine.JRConstants; import net.sf.jasperreports.engine.JRDefaultStyleProvider; import net.sf.jasperreports.engine.JRLine; import net.sf.jasperreports.engine.JROrigin; import net.sf.jasperreports.engine.base.JRBasePen; import net.sf.jasperreports.engine.type.LineDirectionEnum; /** * Line element information shared by multiple print line objects. * * @author Teodor Danciu (teodord@users.sourceforge.net) * @version $Id: JRTemplateLine.java 3715 2010-04-08 18:08:49Z teodord $ * @see JRTemplatePrintLine */ public class JRTemplateLine extends JRTemplateGraphicElement { /** * */ private static final long serialVersionUID = JRConstants.SERIAL_VERSION_UID; /** * */ protected LineDirectionEnum directionValue = LineDirectionEnum.TOP_DOWN; /** * */ protected JRTemplateLine(JROrigin origin, JRDefaultStyleProvider defaultStyleProvider, JRLine line) { super(origin, defaultStyleProvider); setLine(line); } /** * Creates a template line. * * @param origin the origin of the elements that will use this template * @param defaultStyleProvider the default style provider to use for * this template */ public JRTemplateLine(JROrigin origin, JRDefaultStyleProvider defaultStyleProvider) { super(origin, defaultStyleProvider); this.linePen = new JRBasePen(this); } /** * */ protected void setLine(JRLine line) { super.setGraphicElement(line); setDirection(line.getDirectionValue()); } /** * @deprecated Replaced by {@link #getDirectionValue()}. */ public byte getDirection() { return getDirectionValue().getValue(); } /** * @deprecated Replaced by {@link #setDirection(LineDirectionEnum)}. */ public void setDirection(byte direction) { setDirection(LineDirectionEnum.getByValue(direction)); } /** * */ public LineDirectionEnum getDirectionValue() { return this.directionValue; } /** * */ public void setDirection(LineDirectionEnum directionValue) { this.directionValue = directionValue; } /* * These fields are only for serialization backward compatibility. */ private int PSEUDO_SERIAL_VERSION_UID = JRConstants.PSEUDO_SERIAL_VERSION_UID; //NOPMD /** * @deprecated */ private byte direction; private void readObject(ObjectInputStream in) throws IOException, ClassNotFoundException { in.defaultReadObject(); if (PSEUDO_SERIAL_VERSION_UID < JRConstants.PSEUDO_SERIAL_VERSION_UID_3_7_2) { directionValue = LineDirectionEnum.getByValue(direction); } } }