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

📄 timeseriescollection.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.] * * ------------------------- * TimeSeriesCollection.java * ------------------------- * (C) Copyright 2001-2003, by Object Refinery Limited. * * Original Author:  David Gilbert (for Object Refinery Limited); * Contributor(s):   -; * * $Id: TimeSeriesCollection.java,v 1.22 2004/05/24 15:50:25 mungady Exp $ * * Changes * ------- * 11-Oct-2001 : Version 1 (DG); * 18-Oct-2001 : Added implementation of IntervalXYDataSource so that bar plots (using numerical *               axes) can be plotted from time series data (DG); * 22-Oct-2001 : Renamed DataSource.java --> Dataset.java etc. (DG); * 15-Nov-2001 : Added getSeries(...) method (DG); *               Changed name from TimeSeriesDataset to TimeSeriesCollection (DG); * 07-Dec-2001 : TimeSeries --> BasicTimeSeries (DG); * 01-Mar-2002 : Added a time zone offset attribute, to enable fast calculation of the time period *               start and end values (DG); * 29-Mar-2002 : The collection now registers itself with all the time series objects as a *               SeriesChangeListener.  Removed redundant calculateZoneOffset method (DG); * 06-Jun-2002 : Added a setting to control whether the x-value supplied in the getXValue(...) *               method comes from the START, MIDDLE, or END of the time period.  This is a *               workaround for JFreeChart, where the current date axis always labels the start *               of a time period (DG); * 24-Jun-2002 : Removed unnecessary import (DG); * 24-Aug-2002 : Implemented DomainInfo interface, and added the DomainIsPointsInTime flag (DG); * 07-Oct-2002 : Fixed errors reported by Checkstyle (DG); * 16-Oct-2002 : Added remove methods (DG); * 10-Jan-2003 : Changed method names in RegularTimePeriod class (DG); * 13-Mar-2003 : Moved to com.jrefinery.data.time package and implemented Serializable (DG); * 04-Sep-2003 : Added getSeries(String) method (DG); * 15-Sep-2003 : Added a removeAllSeries() method to match XYSeriesCollection (DG); * 05-May-2004 : Now extends AbstractIntervalXYDataset (DG); *  */package org.jfree.data.time;import java.io.Serializable;import java.util.ArrayList;import java.util.Calendar;import java.util.Collections;import java.util.Iterator;import java.util.List;import java.util.TimeZone;import org.jfree.data.AbstractIntervalXYDataset;import org.jfree.data.DatasetChangeEvent;import org.jfree.data.DomainInfo;import org.jfree.data.IntervalXYDataset;import org.jfree.data.Range;import org.jfree.util.ObjectUtils;/** * A collection of time series objects. * <P> * This class implements the {@link org.jfree.data.XYDataset} interface, as well as the * extended {@link IntervalXYDataset} interface.  This makes it a convenient dataset for use with * the {@link org.jfree.chart.plot.XYPlot} class. * */public class TimeSeriesCollection extends AbstractIntervalXYDataset                                  implements IntervalXYDataset,                                             DomainInfo,                                             Serializable {    /** Useful constant for controlling the x-value returned for a time period. */    public static final int START = 0;    /** Useful constant for controlling the x-value returned for a time period. */    public static final int MIDDLE = 1;    /** Useful constant for controlling the x-value returned for a time period. */    public static final int END = 2;    /** Storage for the time series. */    private List data;    /** A working calendar (to recycle) */    private Calendar workingCalendar;        /**      * The point within each time period that is used for the X value when this collection is used     * as an {@link org.jfree.data.XYDataset}.  This can be the start, middle or end of the      * time period.        */    private TimePeriodAnchor xPosition;    /**     * A flag that indicates that the domain is 'points in time'.  If this flag is true, only     * the x-value is used to determine the range of values in the domain, the start and end     * x-values are ignored.     */    private boolean domainIsPointsInTime;    /**     * Constructs an empty dataset, tied to the default timezone.     */    public TimeSeriesCollection() {        this(null, TimeZone.getDefault());    }    /**     * Constructs an empty dataset, tied to a specific timezone.     *     * @param zone the timezone.     */    public TimeSeriesCollection(final TimeZone zone) {        this(null, zone);    }    /**     * Constructs a dataset containing a single series (more can be added),     * tied to the default timezone.     *     * @param series the series.     */    public TimeSeriesCollection(final TimeSeries series) {        this(series, TimeZone.getDefault());    }    /**     * Constructs a dataset containing a single series (more can be added),     * tied to a specific timezone.     *     * @param series the series.     * @param zone the timezone.     */    public TimeSeriesCollection(final TimeSeries series, final TimeZone zone) {        this.data = new ArrayList();        this.workingCalendar = Calendar.getInstance(zone);        this.xPosition = TimePeriodAnchor.START;        this.domainIsPointsInTime = true;        if (series != null) {            this.data.add(series);            series.addChangeListener(this);        }    }    /**     * Returns the position of the x-value returned for a time period (START,     * MIDDLE, or END).     *     * @return The position.     * @deprecated Use getXPosition().     */    public int getPosition() {        int result = MIDDLE;        final TimePeriodAnchor anchor = getXPosition();        if (anchor == TimePeriodAnchor.START) {            result = START;        }        else if (anchor == TimePeriodAnchor.MIDDLE) {            result = MIDDLE;        }        else if (anchor == TimePeriodAnchor.END) {            result = END;        }        return result;    }        /**     * Sets the position - this controls the x-value that is returned for a     * particular time period.     * <P>     * Use the constants <code>START</code>, <code>MIDDLE</code> and <code>END</code>.     *     * @param position the position.     * @deprecated Use setXPosition(...).     */    public void setPosition(final int position) {        if (position == START) {            setXPosition(TimePeriodAnchor.START);        }        else if (position == MIDDLE) {            setXPosition(TimePeriodAnchor.MIDDLE);        }         else if (position == END) {            setXPosition(TimePeriodAnchor.END);        }    }    /**     * Returns the position within each time period that is used for the X value when the collection     * is used as an {@link org.jfree.data.XYDataset}.     *      * @return The anchor position.     */    public TimePeriodAnchor getXPosition() {        return this.xPosition;    }    /**     * Sets the position within each time period that is used for the X values when the collection     * is used as an {@link org.jfree.data.XYDataset}.  A {@link DatasetChangeEvent} is sent to      * all registered listeners.     *      * @param anchor  the anchor position.     */    public void setXPosition(final TimePeriodAnchor anchor) {        this.xPosition = anchor;        notifyListeners(new DatasetChangeEvent(this, this));        }        /**     * Returns a flag that controls whether the domain is treated as 'points in time'.     * <P>     * This flag is used when determining the max and min values for the domain.  If true, then     * only the x-values are considered for the max and min values.  If false, then the start and     * end x-values will also be taken into consideration     *     * @return the flag.     */    public boolean getDomainIsPointsInTime() {        return this.domainIsPointsInTime;    }    /**     * Sets a flag that controls whether the domain is treated as 'points in time', or time     * periods.     *     * @param flag The new value of the flag.     */    public void setDomainIsPointsInTime(final boolean flag) {        this.domainIsPointsInTime = flag;    }        /**     * Returns a list of all the series in the collection.       *      * @return The list (which is unmodifiable).     */    public List getSeries() {        return Collections.unmodifiableList(this.data);    }    /**     * Returns the number of series in the collection.     *     * @return the series count.     */    public int getSeriesCount() {        return this.data.size();    }    /**     * Returns a series.     *     * @param series The index of the series (zero-based).     *     * @return the series.     */    public TimeSeries getSeries(final int series) {        // check arguments...        if ((series < 0) || (series > getSeriesCount())) {            throw new IllegalArgumentException(                "TimeSeriesDataset.getSeries(...): index outside valid range.");        }        // fetch the series...        final TimeSeries ts = (TimeSeries) this.data.get(series);        return ts;    }        /**     * Returns the series with the specified name, or <code>null</code> if there is no such series.     *      * @param name  the series name.     *      * @return The series with the given name.     */    public TimeSeries getSeries(final String name) {                TimeSeries result = null;        final Iterator iterator = this.data.iterator();        while (iterator.hasNext()) {            final TimeSeries series = (TimeSeries) iterator.next();            final String n = series.getName();            if (n != null && n.equals(name)) {                result = series;            }        }        return result;            }    /**     * Returns the name of a series.     * <P>     * This method is provided for convenience.     *     * @param series The index of the series (zero-based).     *     * @return the name of a series.     */    public String getSeriesName(final int series) {        // check arguments...delegated        // fetch the series name...        return getSeries(series).getName();    }    /**

⌨️ 快捷键说明

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