JRTemplateElement.java :  » Report » jasperreports-3.7.2 » net » sf » jasperreports » engine » fill » Java Open Source

Java Open Source » Report » jasperreports 3.7.2 
jasperreports 3.7.2 » net » sf » jasperreports » engine » fill » JRTemplateElement.java
/*
 * 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.awt.Color;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.Serializable;
import java.util.Random;

import net.sf.jasperreports.engine.JRCommonElement;
import net.sf.jasperreports.engine.JRConstants;
import net.sf.jasperreports.engine.JRDefaultStyleProvider;
import net.sf.jasperreports.engine.JRElement;
import net.sf.jasperreports.engine.JROrigin;
import net.sf.jasperreports.engine.JRPropertiesHolder;
import net.sf.jasperreports.engine.JRPropertiesMap;
import net.sf.jasperreports.engine.JRStyle;
import net.sf.jasperreports.engine.type.ModeEnum;
import net.sf.jasperreports.engine.util.JRStyleResolver;


/**
 * Base class consisting of print element information shared by multiple
 * print elements.
 * 
 * @author Teodor Danciu (teodord@users.sourceforge.net)
 * @version $Id: JRTemplateElement.java 3715 2010-04-08 18:08:49Z teodord $
 */
public abstract class JRTemplateElement implements JRCommonElement, Serializable, JRPropertiesHolder
{


  /**
   *
   */
  private static final long serialVersionUID = JRConstants.SERIAL_VERSION_UID;
  
  private static final Random randomId = new Random();

  /**
   *
   */
  private String key;
  private ModeEnum modeValue = null;
  private Color forecolor = null;
  private Color backcolor = null;

  protected JROrigin origin = null;

  protected JRDefaultStyleProvider defaultStyleProvider;
  protected JRStyle parentStyle = null;

  private final String id;
  
  private JRPropertiesMap propertiesMap;
  
  /**
   *
   */
  protected JRTemplateElement(JROrigin origin, JRDefaultStyleProvider defaultStyleProvider)
  {
    this.origin = origin;
    this.defaultStyleProvider = defaultStyleProvider;
    id = createId();
  }

  /**
   *
   */
  protected JRTemplateElement(JROrigin origin, JRElement element)
  {
    this.origin = origin;
    setElement(element);
    id = createId();
  }

  protected JRTemplateElement(String id)
  {
    this.id = id;
  }
  
  private String createId()
  {
    return System.identityHashCode(this) + "_" + System.currentTimeMillis() + "_" + randomId.nextInt();
  }


  /**
   * Copies basic element attributes: the element style, key,
   * mode, forecolor and backcolor.
   * 
   * @param element the element to copy attributes from
   */
  public void setElement(JRElement element)
  {
    parentStyle = element.getStyle();
    
    setKey(element.getKey());
    
    modeValue = element.getOwnModeValue();
    forecolor = element.getOwnForecolor();
    backcolor = element.getOwnBackcolor();
  }
  
  /**
   *
   */
  public JROrigin getOrigin()
  {
    return origin;
  }

  /**
   *
   */
  public JRDefaultStyleProvider getDefaultStyleProvider()
  {
    return defaultStyleProvider;
  }

  /**
   *
   */
  public JRStyle getStyle()
  {
    return parentStyle;
  }

  /**
   *
   */
  protected JRStyle getBaseStyle()
  {
    if (parentStyle != null)
    {
      return parentStyle;
    }
    if (defaultStyleProvider != null)
    {
      return defaultStyleProvider.getDefaultStyle();
    }
    return null;
  }

  /**
   *
   */
  public int getWidth()
  {
    throw new UnsupportedOperationException();
  }
    
  /**
   *
   */
  public int getHeight()
  {
    throw new UnsupportedOperationException();
  }
    
  /**
   * @deprecated Replaced by {@link #getModeValue()}.
   */
  public byte getMode()
  {
    return getModeValue().getValue();
  }

  /**
   * @deprecated Replaced by {@link #getOwnModeValue()}.
   */
  public Byte getOwnMode()
  {
    return getOwnModeValue() == null ? null : getOwnModeValue().getValueByte();
  }

  /**
   *
   */
  public ModeEnum getModeValue()
  {
    return JRStyleResolver.getMode(this, ModeEnum.OPAQUE);
  }

  /**
   *
   */
  public ModeEnum getOwnModeValue()
  {
    return modeValue;
  }

  /**
   * @deprecated Replaced by {@link #setMode(ModeEnum)}.
   */
  public void setMode(byte mode)
  {
    setMode(ModeEnum.getByValue(mode));
  }

  /**
   * @deprecated Replaced by {@link #setMode(ModeEnum)}.
   */
  public void setMode(Byte mode)
  {
    setMode(ModeEnum.getByValue(mode));
  }

  /**
   *
   */
  public void setMode(ModeEnum modeValue)
  {
    this.modeValue = modeValue;
  }

  /**
   *
   */
  public Color getForecolor()
  {
    return JRStyleResolver.getForecolor(this);
  }
  
  /**
   *
   */
  public Color getOwnForecolor()
  {
    return this.forecolor;
  }
  
  /**
   *
   */
  public void setForecolor(Color forecolor)
  {
    this.forecolor = forecolor;
  }
  
  /**
   *
   */
  public Color getBackcolor()
  {
    return JRStyleResolver.getBackcolor(this);
  }
  
  /**
   *
   */
  public Color getOwnBackcolor()
  {
    return this.backcolor;
  }
  
  /**
   *
   */
  public void setBackcolor(Color backcolor)
  {
    this.backcolor = backcolor;
  }
  
  /**
   *
   */
  public String getId()
  {
    return id;
  }

  
  public String getKey()
  {
    return key;
  }

  
  public void setKey(String key)
  {
    this.key = key;
  }


  /**
   * Returns null as external style references are not allowed for print objects.
   */
  public String getStyleNameReference()
  {
    return null;
  }

  
  public synchronized boolean hasProperties()
  {
    return propertiesMap != null && propertiesMap.hasProperties();
  }

  public synchronized JRPropertiesMap getPropertiesMap()
  {
    if (propertiesMap == null)
    {
      propertiesMap = new JRPropertiesMap();
    }
    return propertiesMap;
  }

  public JRPropertiesHolder getParentProperties()
  {
    return null;
  }

  /**
   * Sets the template element style.
   * 
   * @param style the style
   */
  public void setStyle(JRStyle style)
  {
    this.parentStyle = style;
  }

  /*
   * These fields are only for serialization backward compatibility.
   */
  private int PSEUDO_SERIAL_VERSION_UID = JRConstants.PSEUDO_SERIAL_VERSION_UID; //NOPMD
  /**
   * @deprecated
   */
  private Byte mode;
  
  private void readObject(ObjectInputStream in) throws IOException, ClassNotFoundException
  {
    in.defaultReadObject();
    
    if (PSEUDO_SERIAL_VERSION_UID < JRConstants.PSEUDO_SERIAL_VERSION_UID_3_7_2)
    {
      modeValue = ModeEnum.getByValue(mode);
      
      mode = null;
    }
  }

}
java2s.com  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.