All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jfree.ui.DrawablePanel Maven / Gradle / Ivy

Go to download

jtstand-common is a library derived from jcommon, used by jtstand-chart, which is derived from jfreechart

The newest version!
/*
 * Copyright (c) 2009 Albert Kurucz. 
 *
 * This file, DrawablePanel.java is part of JTStand.
 *
 * JTStand 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.
 *
 * JTStand 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 GTStand.  If not, see .
 */
package org.jfree.ui;

import java.awt.Dimension;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.geom.Rectangle2D;
import javax.swing.JPanel;

/**
 * A component, that accepts a drawable and which draws that drawable.
 *
 * @author Thomas Morgner
 */
public class DrawablePanel extends JPanel
{
  private Drawable drawable;

  /**
   * Creates a new instance.
   */
  public DrawablePanel()
  {
    setOpaque(false);
  }

  /**
   * Returns the drawable item.
   *
   * @return The drawable item.
   */
  public Drawable getDrawable()
  {
    return this.drawable;
  }

  /**
   * Sets the drawable item.
   *
   * @param drawable  the drawable item.
   */
  public void setDrawable(final Drawable drawable)
  {
    this.drawable = drawable;
    revalidate();
    repaint();
  }

  /**
   * If the preferredSize has been set to a non-null
   * value just returns it. If the UI delegate's getPreferredSize
   * method returns a non null value then return that; otherwise
   * defer to the component's layout manager.
   *
   * @return the value of the preferredSize property
   * @see #setPreferredSize
   * @see javax.swing.plaf.ComponentUI
   */
  public Dimension getPreferredSize()
  {
    if (this.drawable instanceof ExtendedDrawable)
    {
      final ExtendedDrawable ed = (ExtendedDrawable) this.drawable;
      return ed.getPreferredSize();
    }
    return super.getPreferredSize();
  }

  /**
   * If the minimum size has been set to a non-null value just
   * returns it.  If the UI delegate's getMinimumSize method
   * returns a non-null value then return that; otherwise defer to
   * the component's layout manager.
   *
   * @return the value of the minimumSize property
   * @see #setMinimumSize
   * @see javax.swing.plaf.ComponentUI
   */
  public Dimension getMinimumSize()
  {
    if (this.drawable instanceof ExtendedDrawable)
    {
      final ExtendedDrawable ed = (ExtendedDrawable) this.drawable;
      return ed.getPreferredSize();
    }
    return super.getMinimumSize();
  }

  /**
   * Returns true if this component is completely opaque.
   * 

* An opaque component paints every pixel within its rectangular bounds. A * non-opaque component paints only a subset of its pixels or none at all, * allowing the pixels underneath it to "show through". Therefore, a * component that does not fully paint its pixels provides a degree of * transparency. *

* Subclasses that guarantee to always completely paint their contents should * override this method and return true. * * @return true if this component is completely opaque * @see #setOpaque */ public boolean isOpaque() { if (this.drawable == null) { return false; } return super.isOpaque(); } /** * Calls the UI delegate's paint method, if the UI delegate is * non-null. We pass the delegate a copy of the * Graphics object to protect the rest of the paint code from * irrevocable changes (for example, Graphics.translate). *

* If you override this in a subclass you should not make permanent changes to * the passed in Graphics. For example, you should not alter the * clip Rectangle or modify the transform. If you need to do * these operations you may find it easier to create a new * Graphics from the passed in Graphics and * manipulate it. Further, if you do not invoker super's implementation you * must honor the opaque property, that is if this component is opaque, you * must completely fill in the background in a non-opaque color. If you do not * honor the opaque property you will likely see visual artifacts. *

* The passed in Graphics object might have a transform other * than the identify transform installed on it. In this case, you might get * unexpected results if you cumulatively apply another transform. * * @param g the Graphics object to protect * @see #paint * @see javax.swing.plaf.ComponentUI */ protected void paintComponent(Graphics g) { super.paintComponent(g); if (this.drawable == null) { return; } final Graphics2D g2 = (Graphics2D) g.create (0, 0, getWidth(), getHeight()); this.drawable.draw(g2, new Rectangle2D.Double(0, 0, getWidth(), getHeight())); g2.dispose(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy