legendgraphic.java

来自「JfreeChart 常用图表例子」· Java 代码 · 共 510 行

JAVA
510
字号
/* =========================================================== * JFreeChart : a free chart library for the Java(tm) platform * =========================================================== * * (C) Copyright 2000-2005, by Object Refinery Limited and Contributors. * * Project Info:  http://www.jfree.org/jfreechart/index.html * * This library 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 2.1 of the License, or  * (at your option) any later version. * * This 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 Lesser General Public  * License for more details. * * You should have received a copy of the GNU Lesser General Public License  * along with this library; if not, write to the Free Software Foundation,  * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA. * * [Java is a trademark or registered trademark of Sun Microsystems, Inc.  * in the United States and other countries.] * * ------------------ * LegendGraphic.java * ------------------ * (C) Copyright 2004, 2005, by Object Refinery Limited. * * Original Author:  David Gilbert (for Object Refinery Limited); * Contributor(s):   -; * * $Id: LegendGraphic.java,v 1.9 2005/06/02 14:08:26 mungady Exp $ * * Changes * ------- * 26-Oct-2004 : Version 1 (DG); * 21-Jan-2005 : Modified return type of RectangleAnchor.coordinates()  *               method (DG); * 20-Apr-2005 : Added new draw() method (DG); * 13-May-2005 : Fixed to respect margin, border and padding settings (DG); *  */package org.jfree.chart.title;import java.awt.Graphics2D;import java.awt.Paint;import java.awt.Shape;import java.awt.Stroke;import java.awt.geom.Point2D;import java.awt.geom.Rectangle2D;import org.jfree.chart.block.AbstractBlock;import org.jfree.chart.block.Block;import org.jfree.chart.block.LengthConstraintType;import org.jfree.chart.block.RectangleConstraint;import org.jfree.ui.RectangleAnchor;import org.jfree.ui.Size2D;import org.jfree.util.ShapeUtilities;/** * The graphical item within a legend item. */public class LegendGraphic extends AbstractBlock implements Block {        /**      * A flag that controls whether or not the shape is visible - see also      * lineVisible.      */    private boolean shapeVisible;        /**      * The shape to display.  To allow for accurate positioning, the center     * of the shape should be at (0, 0).      */    private Shape shape;        /**     * Defines the location within the block to which the shape will be aligned.     */    private RectangleAnchor shapeLocation;        /**      * Defines the point on the shape's bounding rectangle that will be      * aligned to the drawing location when the shape is rendered.     */    private RectangleAnchor shapeAnchor;        /** A flag that controls whether or not the shape is filled. */    private boolean shapeFilled;        /** The fill paint for the shape. */    private Paint fillPaint;        /** A flag that controls whether or not the shape outline is visible. */    private boolean shapeOutlineVisible;        /** The outline paint for the shape. */    private Paint outlinePaint;        /** The outline stroke for the shape. */    private Stroke outlineStroke;        /**      * A flag that controls whether or not the line is visible - see also      * shapeVisible.      */    private boolean lineVisible;        /** The line. */    private Shape line;        /** The line stroke. */    private Stroke lineStroke;        /** The line paint. */    private Paint linePaint;        /**     * Creates a new legend graphic.     *      * @param shape  the shape (<code>null</code> not permitted).     * @param fillPaint  the fill paint (<code>null</code> not permitted).     */    public LegendGraphic(Shape shape, Paint fillPaint) {        if (shape == null) {            throw new IllegalArgumentException("Null 'shape' argument.");        }        if (fillPaint == null) {            throw new IllegalArgumentException("Null 'fillPaint' argument.");        }        this.shapeVisible = true;        this.shape = shape;        this.shapeAnchor = RectangleAnchor.CENTER;        this.shapeLocation = RectangleAnchor.CENTER;        this.shapeFilled = true;        this.fillPaint = fillPaint;        setPadding(2.0, 2.0, 2.0, 2.0);    }        /**     * Sets the shape anchor.  This defines a point on the shapes bounding     * rectangle that will be used to align the shape to a location.     *      * @param anchor  the anchor (<code>null</code> not permitted).     */    public void setShapeAnchor(RectangleAnchor anchor) {        if (anchor == null) {            throw new IllegalArgumentException("Null 'anchor' argument.");        }        this.shapeAnchor = anchor;        }        /**     * Sets the shape location.  This defines a point within the drawing     * area that will be used to align the shape to.     *      * @param location  the location (<code>null</code> not permitted).     */    public void setShapeLocation(RectangleAnchor location) {        if (location == null) {            throw new IllegalArgumentException("Null 'location' argument.");        }        this.shapeLocation = location;    }        /**     * Returns a flag that controls whether or not the shape     * is visible.     *      * @return A boolean.     */    public boolean isShapeVisible() {        return this.shapeVisible;    }        /**     * Sets a flag that controls whether or not the shape is      * visible.     *      * @param visible  the flag.     */    public void setShapeVisible(boolean visible) {        this.shapeVisible = visible;    }        /**     * Returns the shape.     *      * @return The shape.     */    public Shape getShape() {        return this.shape;    }        /**     * Sets the shape.     *      * @param shape  the shape.     */    public void setShape(Shape shape) {        this.shape = shape;    }    /**     * Returns a flag that controls whether or not the shapes     * are filled.     *      * @return A boolean.     */    public boolean isShapeFilled() {        return this.shapeFilled;    }        /**     * Sets a flag that controls whether or not the shape is     * filled.     *      * @param filled  the flag.     */    public void setShapeFilled(boolean filled) {        this.shapeFilled = filled;    }    /**     * Returns the paint used to fill the shape.     *      * @return The fill paint.     */    public Paint getFillPaint() {        return this.fillPaint;    }        /**     * Sets the paint used to fill the shape.     *      * @param paint  the paint.     */    public void setFillPaint(Paint paint) {        this.fillPaint = paint;    }        /**     * Returns a flag that controls whether the shape outline is visible.     *      * @return A boolean.     */    public boolean isShapeOutlineVisible() {        return this.shapeOutlineVisible;    }        /**     * Sets a flag that controls whether or not the shape outline     * is visible.     *      * @param visible  the flag.     */    public void setShapeOutlineVisible(boolean visible) {        this.shapeOutlineVisible = visible;    }        /**     * Returns the outline paint.     *      * @return The paint.     */    public Paint getOutlinePaint() {        return this.outlinePaint;    }        /**     * Sets the outline paint.     *      * @param paint  the paint.     */    public void setOutlinePaint(Paint paint) {        this.outlinePaint = paint;    }    /**     * Returns the outline stroke.     *      * @return The stroke.     */    public Stroke getOutlineStroke() {        return this.outlineStroke;    }        /**     * Sets the outline stroke.     *      * @param stroke  the stroke.     */    public void setOutlineStroke(Stroke stroke) {        this.outlineStroke = stroke;    }    /**     * Returns the flag that controls whether or not the line is visible.     *      * @return A boolean.     */    public boolean isLineVisible() {        return this.lineVisible;    }        /**     * Sets the flag that controls whether or not the line is visible.     *      * @param visible  the flag.     */    public void setLineVisible(boolean visible) {        this.lineVisible = visible;    }    /**     * Returns the line centered about (0, 0).     *      * @return The line.     */    public Shape getLine() {        return this.line;    }        /**     * Sets the line.  A Shape is used here, because then you can use Line2D,      * GeneralPath or any other Shape to represent the line.     *      * @param line  the line.     */    public void setLine(Shape line) {        this.line = line;    }        /**     * Returns the line paint.     *      * @return The paint.     */    public Paint getLinePaint() {        return this.linePaint;    }        /**     * Sets the line paint.     *      * @param paint  the paint.     */    public void setLinePaint(Paint paint) {        this.linePaint = paint;    }        /**     * Returns the line stroke.     *      * @return The stroke.     */    public Stroke getLineStroke() {        return this.lineStroke;    }        /**     * Sets the line stroke.     *      * @param stroke  the stroke.     */    public void setLineStroke(Stroke stroke) {        this.lineStroke = stroke;    }        /**     * Arranges the contents of the block, within the given constraints, and      * returns the block size.     *      * @param g2  the graphics device.     * @param constraint  the constraint (<code>null</code> not permitted).     *      * @return The block size (in Java2D units, never <code>null</code>).     */    public Size2D arrange(Graphics2D g2, RectangleConstraint constraint) {        RectangleConstraint contentConstraint = toContentConstraint(constraint);        LengthConstraintType w = contentConstraint.getWidthConstraintType();        LengthConstraintType h = contentConstraint.getHeightConstraintType();        Size2D contentSize = null;        if (w == LengthConstraintType.NONE) {            if (h == LengthConstraintType.NONE) {                contentSize = arrangeNN(g2);            }            else if (h == LengthConstraintType.RANGE) {                throw new RuntimeException("Not yet implemented.");            }            else if (h == LengthConstraintType.FIXED) {                throw new RuntimeException("Not yet implemented.");            }        }        else if (w == LengthConstraintType.RANGE) {            if (h == LengthConstraintType.NONE) {                throw new RuntimeException("Not yet implemented.");            }            else if (h == LengthConstraintType.RANGE) {                throw new RuntimeException("Not yet implemented.");            }            else if (h == LengthConstraintType.FIXED) {                throw new RuntimeException("Not yet implemented.");            }        }        else if (w == LengthConstraintType.FIXED) {            if (h == LengthConstraintType.NONE) {                throw new RuntimeException("Not yet implemented.");            }            else if (h == LengthConstraintType.RANGE) {                throw new RuntimeException("Not yet implemented.");            }            else if (h == LengthConstraintType.FIXED) {                   contentSize = new Size2D(                    contentConstraint.getWidth(),                    contentConstraint.getHeight()                );            }                    }        return new Size2D(            calculateTotalWidth(contentSize.getWidth()),             calculateTotalHeight(contentSize.getHeight())        );    }        /**     * Performs the layout with no constraint, so the content size is      * determined by the bounds of the shape and/or line drawn to represent      * the series.     *      * @param g2  the graphics device.     *      * @return  The content size.     */    protected Size2D arrangeNN(Graphics2D g2) {        Rectangle2D contentSize = new Rectangle2D.Double();        if (this.line != null) {            contentSize.setRect(this.line.getBounds2D());        }        if (this.shape != null) {            contentSize = contentSize.createUnion(this.shape.getBounds2D());        }        return new Size2D(contentSize.getWidth(), contentSize.getHeight());    }    /**     * Draws the graphic item within the specified area.     *      * @param g2  the graphics device.     * @param area  the area.     */    public void draw(Graphics2D g2, Rectangle2D area) {                area = trimMargin(area);        drawBorder(g2, area);        area = trimBorder(area);        area = trimPadding(area);                if (this.lineVisible) {            Point2D location = RectangleAnchor.coordinates(                area, this.shapeLocation            );            Shape aLine = ShapeUtilities.createTranslatedShape(                getLine(), this.shapeAnchor, location.getX(), location.getY()            );            g2.setPaint(this.linePaint);            g2.setStroke(this.lineStroke);            g2.draw(aLine);        }                if (this.shapeVisible) {            Point2D location = RectangleAnchor.coordinates(                area, this.shapeLocation            );                        Shape s = ShapeUtilities.createTranslatedShape(                this.shape, this.shapeAnchor, location.getX(), location.getY()            );            if (this.shapeFilled) {                g2.setPaint(this.fillPaint);                g2.fill(s);            }            if (this.shapeOutlineVisible) {                g2.setPaint(this.outlinePaint);                g2.setStroke(this.outlineStroke);                g2.draw(s);            }        }            }        /**     * Draws the block within the specified area.     *      * @param g2  the graphics device.     * @param area  the area.     * @param params  ignored (<code>null</code> permitted).     *      * @return Always <code>null</code>.     */    public Object draw(Graphics2D g2, Rectangle2D area, Object params) {        draw(g2, area);        return null;    }}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?