⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 symbolicaxis.java

📁 这是一个segy数据显示程序
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
/* =========================================================== * JFreeChart : a free chart library for the Java(tm) platform * =========================================================== * * (C) Copyright 2000-2004, 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.] * * ----------------- * SymbolicAxis.java * ----------------- * (C) Copyright 2002-2004, by Object Refinery Limited and Contributors. * * Original Author:  Anthony Boulestreau; * Contributor(s):   David Gilbert (for Object Refinery Limited); * * * Changes (from 23-Jun-2001) * -------------------------- * 29-Mar-2002 : First version (AB); * 19-Apr-2002 : Updated formatting and import statements (DG); * 21-Jun-2002 : Make change to use the class TickUnit - remove valueToString(...) method and *               add SymbolicTickUnit (AB); * 25-Jun-2002 : Removed redundant code (DG); * 25-Jul-2002 : Changed order of parameters in ValueAxis constructor (DG); * 05-Sep-2002 : Updated constructor to reflect changes in the Axis class (DG); * 08-Nov-2002 : Moved to new package com.jrefinery.chart.axis (DG); * 14-Feb-2003 : Added back missing constructor code (DG); * 26-Mar-2003 : Implemented Serializable (DG); * 14-May-2003 : Renamed HorizontalSymbolicAxis --> SymbolicAxis and merged in *               VerticalSymbolicAxis (DG); * 12-Aug-2003 : Fixed bug where refreshTicks(...) method has different signature to super  *               class (DG); * 29-Oct-2003 : Added workaround for font alignment in PDF output (DG); * 02-Nov-2003 : Added code to avoid overlapping labels (MR); * 07-Nov-2003 : Modified to use new tick classes (DG); * 18-Nov-2003 : Fixed bug where symbols are not being displayed on the axis (DG); * 24-Nov-2003 : Added fix for gridlines on zooming (bug id 834643) (DG); * 21-Jan-2004 : Update for renamed method in ValueAxis (DG); * 11-Mar-2004 : Modified the way the background grid color is being drawn, see this thread: *               http://www.jfree.org/phpBB2/viewtopic.php?p=22973 (DG); * 16-Mar-2004 : Added plotState to draw() method (DG); * 07-Apr-2004 : Modified string bounds calculation (DG); * */package org.jfree.chart.axis;import java.awt.BasicStroke;import java.awt.Color;import java.awt.Font;import java.awt.Graphics2D;import java.awt.Paint;import java.awt.Shape;import java.awt.geom.Rectangle2D;import java.io.Serializable;import java.text.NumberFormat;import java.util.Arrays;import java.util.Iterator;import java.util.List;import java.util.Vector;import org.jfree.chart.event.AxisChangeEvent;import org.jfree.chart.plot.Plot;import org.jfree.chart.plot.PlotRenderingInfo;import org.jfree.chart.plot.ValueAxisPlot;import org.jfree.data.Range;import org.jfree.text.TextUtilities;import org.jfree.ui.RectangleEdge;import org.jfree.ui.TextAnchor;/** * A standard linear value axis, for SYMBOLIC values. * * @author Anthony Boulestreau */public class SymbolicAxis extends NumberAxis implements Serializable {    /** The default symbolic grid line paint. */    public static final Paint DEFAULT_SYMBOLIC_GRID_LINE_PAINT = new Color(232, 234, 232, 128);    /** The list of symbolic value to display instead of the numeric values. */    private List symbolicValue;    /** List of the symbolic grid lines shapes. */    private List symbolicGridLineList = null;    /** Color of the dark part of the symbolic grid line. **/    private transient Paint symbolicGridPaint;    /** Flag that indicates whether or not symbolic grid lines are visible. */    private boolean symbolicGridLinesVisible;    /**     * Constructs a symbolic axis, using default attribute values where necessary.     *     * @param label  the axis label (null permitted).     * @param sv  the list of symbolic values to display instead of the numeric value.     */    public SymbolicAxis(String label, String[] sv) {        super(label);        //initialization of symbolic value        this.symbolicValue = Arrays.asList(sv);        this.symbolicGridLinesVisible = true;        this.symbolicGridPaint = DEFAULT_SYMBOLIC_GRID_LINE_PAINT;        setAutoTickUnitSelection(false, false);        setAutoRangeStickyZero(false);    }    /**     * Returns the list of the symbolic values to display.     *     * @return list of symbolic values.     */    public String[] getSymbolicValue() {        String[] strToReturn = new String[this.symbolicValue.size()];        strToReturn = (String[]) this.symbolicValue.toArray(strToReturn);        return strToReturn;    }    /**     * Returns the symbolic grid line color.     *     * @return the grid line color.     */    public Paint getSymbolicGridPaint() {        return this.symbolicGridPaint;    }    /**     * Returns <CODE>true</CODE> if the symbolic grid lines are showing, and     * false otherwise.     *     * @return true if the symbolic grid lines are showing, and false otherwise.     */    public boolean isGridLinesVisible() {        return this.symbolicGridLinesVisible;    }    /**     * Sets the visibility of the symbolic grid lines and notifies registered     * listeners that the axis has been modified.     *     * @param flag  the new setting.     */    public void setSymbolicGridLinesVisible(boolean flag) {        if (this.symbolicGridLinesVisible != flag) {            this.symbolicGridLinesVisible = flag;            notifyListeners(new AxisChangeEvent(this));        }    }    /**     * This operation is not supported by the symbolic values.     *     * @param g2  the graphics device.     * @param drawArea  the area in which the plot and axes should be drawn.     * @param plotArea  the area in which the plot should be drawn.     */    protected void selectAutoTickUnit(Graphics2D g2, Rectangle2D drawArea, Rectangle2D plotArea) {        throw new UnsupportedOperationException();    }    /**     * Draws the axis on a Java 2D graphics device (such as the screen or a printer).     *     * @param g2  the graphics device (<code>null</code> not permitted).     * @param cursor  the cursor location.     * @param plotArea  the area within which the plot and axes should be drawn (<code>null</code>      *                  not permitted).     * @param dataArea  the area within which the data should be drawn (<code>null</code> not      *                  permitted).     * @param edge  the axis location (<code>null</code> not permitted).     * @param plotState  collects information about the plot (<code>null</code> permitted).     *      * @return the axis state (never <code>null</code>).     */    public AxisState draw(Graphics2D g2,                           double cursor,                          Rectangle2D plotArea,                           Rectangle2D dataArea,                           RectangleEdge edge,                          PlotRenderingInfo plotState) {        AxisState info = new AxisState(cursor);        if (isVisible()) {            info = super.draw(g2, cursor, plotArea, dataArea, edge, plotState);        }        if (this.symbolicGridLinesVisible) {            drawSymbolicGridLines(g2, plotArea, dataArea, edge, info.getTicks());        }        return info;    }    /**     * Draws the symbolic grid lines.     * <P>     * The colors are consecutively the color specified by     * <CODE>symbolicGridPaint<CODE>     * (<CODE>DEFAULT_SYMBOLIC_GRID_LINE_PAINT</CODE> by default) and white.     *     * @param g2  the graphics device.     * @param plotArea  the area within which the chart should be drawn.     * @param dataArea  the area within which the plot should be drawn (a subset of the drawArea).     * @param edge  the axis location.     * @param ticks  the ticks.     */    public void drawSymbolicGridLines(Graphics2D g2,                                      Rectangle2D plotArea,                                       Rectangle2D dataArea,                                      RectangleEdge edge,                                       List ticks) {        Shape savedClip = g2.getClip();        g2.clip(dataArea);        if (RectangleEdge.isTopOrBottom(edge)) {            drawSymbolicGridLinesHorizontal(g2, plotArea, dataArea, true, ticks);        }        else if (RectangleEdge.isLeftOrRight(edge)) {            drawSymbolicGridLinesVertical(g2, plotArea, dataArea, true, ticks);        }        g2.setClip(savedClip);    }    /**     * Draws the symbolic grid lines.     * <P>     * The colors are consecutively the color specified by     * <CODE>symbolicGridPaint<CODE>     * (<CODE>DEFAULT_SYMBOLIC_GRID_LINE_PAINT</CODE> by default) and white.     * or if <CODE>firstGridLineIsDark</CODE> is <CODE>true</CODE> white and     * the color specified by <CODE>symbolicGridPaint<CODE>.     *     * @param g2  the graphics device.     * @param plotArea  the area within which the chart should be drawn.     * @param dataArea  the area within which the plot should be drawn     *                  (a subset of the drawArea).     * @param firstGridLineIsDark  True: the first symbolic grid line take the     *                             color of <CODE>symbolicGridPaint<CODE>.     *                             False: the first symbolic grid line is white.     * @param ticks  the ticks.     */    public void drawSymbolicGridLinesHorizontal(Graphics2D g2,                                                Rectangle2D plotArea,                                                 Rectangle2D dataArea,                                                boolean firstGridLineIsDark,                                                 List ticks) {        this.symbolicGridLineList = new Vector(ticks.size());        boolean currentGridLineIsDark = firstGridLineIsDark;        double yy = dataArea.getY();        double xx1, xx2;        //gets the outline stroke width of the plot        double outlineStrokeWidth;        if (getPlot().getOutlineStroke() !=  null) {            outlineStrokeWidth = ((BasicStroke) getPlot().getOutlineStroke()).getLineWidth();        }        else {            outlineStrokeWidth = 1d;        }        Iterator iterator = ticks.iterator();        ValueTick tick;        Rectangle2D symbolicGridLine;        while (iterator.hasNext()) {            tick = (ValueTick) iterator.next();            xx1 = valueToJava2D(tick.getValue() - 0.5d, dataArea, RectangleEdge.BOTTOM);            xx2 = valueToJava2D(tick.getValue() + 0.5d, dataArea, RectangleEdge.BOTTOM);            if (currentGridLineIsDark) {                g2.setPaint(this.symbolicGridPaint);                //g2.setXORMode((Color) this.symbolicGridPaint);            }            else {                g2.setPaint(Color.white);                //g2.setXORMode(Color.white);            }            symbolicGridLine =                new Rectangle2D.Double(xx1,                                       yy + outlineStrokeWidth, xx2 - xx1,                                       dataArea.getMaxY() - yy - outlineStrokeWidth);            g2.fill(symbolicGridLine);            this.symbolicGridLineList.add(symbolicGridLine);            currentGridLineIsDark = !currentGridLineIsDark;        }        g2.setPaintMode();    }    /**     * Get the symbolic grid line corresponding to the specified position.     *     * @param position  position of the grid line, startinf from 0.     *     * @return the symbolic grid line corresponding to the specified position.     */    public Rectangle2D.Double getSymbolicGridLine(int position) {        if (this.symbolicGridLineList != null) {            return (Rectangle2D.Double) this.symbolicGridLineList.get(position);        }        else {            return null;        }    }    /**     * Rescales the axis to ensure that all data is visible.     */    protected void autoAdjustRange() {        Plot plot = getPlot();        if (plot == null) {            return;  // no plot, no data        }        if (plot instanceof ValueAxisPlot) {            //ensure that all the symbolic value are displayed            double upper = this.symbolicValue.size() - 1;            double lower = 0;            double range = upper - lower;            // ensure the autorange is at least <minRange> in size...            double minRange = getAutoRangeMinimumSize();            if (range < minRange) {                upper = (upper + lower + minRange) / 2;                lower = (upper + lower - minRange) / 2;            }            //this ensure that the symbolic grid lines will be displayed            //correctly.

⌨️ 快捷键说明

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