📄 outlierlist.java
字号:
/* =========================================================== * 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.] * * ---------------- * OutlierList.java * ---------------- * (C) Copyright 2003, 2004, by David Browning and Contributors. * * Original Author: David Browning (for Australian Institute of Marine Science); * Contributor(s): David Gilbert (for Object Refinery Limited); * * $Id: OutlierList.java,v 1.7 2004/03/12 14:20:11 mungady Exp $ * * Changes * ------- * 05-Aug-2003 : Version 1, contributed by David Browning (DG); * 28-Aug-2003 : Minor tidy-up including Javadocs (DG); * */package org.jfree.chart.renderer;import java.awt.geom.Point2D;import java.util.ArrayList;import java.util.Iterator;import java.util.List;/** * A collection of outliers for a single entity in a box and whisker plot. * * Outliers are grouped in lists for each entity. Lists contain * one or more outliers, determined by whether overlaps have * occured. Overlapping outliers are grouped in the same list. * * Each list contains an averaged outlier, which is the same as a single * outlier if there is only one outlier in the list, but the average of * all the outliers in the list if there is more than one. * * NB This is simply my scheme for displaying outliers, and might not be * acceptable by the wider community. * * @author David Browning */public class OutlierList { /** Storage for the outliers. */ private List outliers; /** The averaged outlier. */ private Outlier averagedOutlier; /** A flag that indicates whether or not there are multiple outliers in the list. */ private boolean multiple = false; /** * Creates a new list containing a single outlier. * * @param outlier the outlier. */ public OutlierList(Outlier outlier) { this.outliers = new ArrayList(); setAveragedOutlier(outlier); } /** * Adds an outlier to the list. * * @param outlier the outlier. * * @return A boolean. */ public boolean add(Outlier outlier) { return this.outliers.add(outlier); } /** * Returns the number of outliers in the list. * * @return The item count. */ public int getItemCount() { return this.outliers.size(); } /** * Returns the averaged outlier. * * @return The averaged outlier. */ public Outlier getAveragedOutlier() { return this.averagedOutlier; } /** * Sets the averaged outlier. * * @param averagedOutlier the averaged outlier. */ public void setAveragedOutlier(Outlier averagedOutlier) { this.averagedOutlier = averagedOutlier; } /** * Returns <code>true</code> if the list contains multiple outliers, and <code>false</code> * otherwise. * * @return A boolean. */ public boolean isMultiple() { return this.multiple; } /** * Sets the flag that indicates whether or not this list represents multiple outliers. * * @param multiple the flag. */ public void setMultiple(boolean multiple) { this.multiple = multiple; } /** * Returns <code>true</code> if the outlier overlaps, and <code>false</code> otherwise. * * @param other the outlier. * * @return A boolean. */ public boolean isOverlapped(Outlier other) { if (other == null) { return false; } boolean result = other.overlaps(getAveragedOutlier()); return result; } /** * Updates the averaged outlier. * */ public void updateAveragedOutlier() { double totalXCoords = 0.0; double totalYCoords = 0.0; int size = getItemCount(); for (Iterator iterator = this.outliers.iterator(); iterator.hasNext();) { Outlier o = (Outlier) iterator.next(); totalXCoords += o.getX(); totalYCoords += o.getY(); } getAveragedOutlier().getPoint().setLocation(new Point2D.Double(totalXCoords / size, totalYCoords / size)); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -