亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? stackedxyarearenderer2.java

?? jfreechart1.0.1 jsp繪制圖表的開發包
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
/* ===========================================================
 * 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., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, 
 * USA.  
 *
 * [Java is a trademark or registered trademark of Sun Microsystems, Inc. 
 * in the United States and other countries.]
 *
 * ---------------------------
 * StackedXYAreaRenderer2.java
 * ---------------------------
 * (C) Copyright 2004, 2005, by Object Refinery Limited and Contributors.
 *
 * Original Author:  David Gilbert (for Object Refinery Limited), based on 
 *                   the StackedXYAreaRenderer class by Richard Atkinson;
 * Contributor(s):   -;
 *
 * $Id: StackedXYAreaRenderer2.java,v 1.6.2.2 2005/10/25 20:56:21 mungady Exp $
 *
 * Changes:
 * --------
 * 30-Apr-2004 : Version 1 (DG);
 * 15-Jul-2004 : Switched getX() with getXValue() and getY() with 
 *               getYValue() (DG);
 * 10-Sep-2004 : Removed getRangeType() method (DG);
 * 06-Jan-2004 : Renamed getRangeExtent() --> findRangeBounds (DG);
 * 28-Mar-2005 : Use getXValue() and getYValue() from dataset (DG);
 * 03-Oct-2005 : Add entity generation to drawItem() method (DG);
 * 
 */

package org.jfree.chart.renderer.xy;

import java.awt.Graphics2D;
import java.awt.Paint;
import java.awt.Shape;
import java.awt.geom.GeneralPath;
import java.awt.geom.Rectangle2D;
import java.io.Serializable;

import org.jfree.chart.axis.ValueAxis;
import org.jfree.chart.entity.EntityCollection;
import org.jfree.chart.labels.XYToolTipGenerator;
import org.jfree.chart.plot.CrosshairState;
import org.jfree.chart.plot.PlotRenderingInfo;
import org.jfree.chart.plot.XYPlot;
import org.jfree.chart.urls.XYURLGenerator;
import org.jfree.data.Range;
import org.jfree.data.xy.TableXYDataset;
import org.jfree.data.xy.XYDataset;
import org.jfree.ui.RectangleEdge;
import org.jfree.util.PublicCloneable;

/**
 * A stacked area renderer for the {@link XYPlot} class.
 */
public class StackedXYAreaRenderer2 extends XYAreaRenderer2 
                                    implements Cloneable, 
                                               PublicCloneable,
                                               Serializable {

    /** For serialization. */
    private static final long serialVersionUID = 7752676509764539182L;
    
    /**
     * Creates a new renderer.
     */
    public StackedXYAreaRenderer2() {
        this(null, null);
    }

    /**
     * Constructs a new renderer.
     *
     * @param labelGenerator  the tool tip generator to use.  <code>null</code>
     *                        is none.
     * @param urlGenerator  the URL generator (<code>null</code> permitted).
     */
    public StackedXYAreaRenderer2(XYToolTipGenerator labelGenerator, 
                                  XYURLGenerator urlGenerator) {
        super(labelGenerator, urlGenerator);
    }

    /**
     * Returns the range of values the renderer requires to display all the 
     * items from the specified dataset.
     * 
     * @param dataset  the dataset (<code>null</code> permitted).
     * 
     * @return The range (or <code>null</code> if the dataset is 
     *         <code>null</code> or empty).
     */
    public Range findRangeBounds(XYDataset dataset) {
        double min = Double.POSITIVE_INFINITY;
        double max = Double.NEGATIVE_INFINITY;
        TableXYDataset d = (TableXYDataset) dataset;
        int itemCount = d.getItemCount();
        for (int i = 0; i < itemCount; i++) {
            double[] stackValues = getStackValues(
                (TableXYDataset) dataset, d.getSeriesCount(), i
            );
            min = Math.min(min, stackValues[0]);
            max = Math.max(max, stackValues[1]);
        }
        return new Range(min, max);
    }

    /**
     * Returns the number of passes required by the renderer.
     * 
     * @return 1.
     */
    public int getPassCount() {
        return 1;
    }

    /**
     * Draws the visual representation of a single data item.
     *
     * @param g2  the graphics device.
     * @param state  the renderer state.
     * @param dataArea  the area within which the data is being drawn.
     * @param info  collects information about the drawing.
     * @param plot  the plot (can be used to obtain standard color information 
     *              etc).
     * @param domainAxis  the domain axis.
     * @param rangeAxis  the range axis.
     * @param dataset  the dataset.
     * @param series  the series index (zero-based).
     * @param item  the item index (zero-based).
     * @param crosshairState  information about crosshairs on a plot.
     * @param pass  the pass index.
     */
    public void drawItem(Graphics2D g2,
                         XYItemRendererState state,
                         Rectangle2D dataArea,
                         PlotRenderingInfo info,
                         XYPlot plot,
                         ValueAxis domainAxis,
                         ValueAxis rangeAxis,
                         XYDataset dataset,
                         int series,
                         int item,
                         CrosshairState crosshairState,
                         int pass) {

        // setup for collecting optional entity info...
        Shape entityArea = null;
        EntityCollection entities = null;
        if (info != null) {
            entities = info.getOwner().getEntityCollection();
        }

        TableXYDataset tdataset = (TableXYDataset) dataset;
        
        // get the data point...
        double x1 = dataset.getXValue(series, item);
        double y1 = dataset.getYValue(series, item);
        if (Double.isNaN(y1)) {
            y1 = 0.0;
        }        
        double[] stack1 = getStackValues(tdataset, series, item);
        
        // get the previous point and the next point so we can calculate a 
        // "hot spot" for the area (used by the chart entity)...
        double x0 = dataset.getXValue(series, Math.max(item - 1, 0));
        double y0 = dataset.getYValue(series, Math.max(item - 1, 0));
        if (Double.isNaN(y0)) {
            y0 = 0.0;
        }
        double[] stack0 = getStackValues(
            tdataset, series, Math.max(item - 1, 0)
        );
        
        int itemCount = dataset.getItemCount(series);
        double x2 = dataset.getXValue(
            series, Math.min(item + 1, itemCount - 1)
        );
        double y2 = dataset.getYValue(
            series, Math.min(item + 1, itemCount - 1)
        );
        if (Double.isNaN(y2)) {
            y2 = 0.0;
        }
        double[] stack2 = getStackValues(
            tdataset, series, Math.min(item + 1, itemCount - 1)
        );

        double xleft = (x0 + x1) / 2.0;
        double xright = (x1 + x2) / 2.0;
        double[] stackLeft = averageStackValues(stack0, stack1);
        double[] stackRight = averageStackValues(stack1, stack2);
        double[] adjStackLeft = adjustedStackValues(stack0, stack1);
        double[] adjStackRight = adjustedStackValues(stack1, stack2);
        
        RectangleEdge edge0 = plot.getDomainAxisEdge();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久99久久精品| 欧美国产综合一区二区| 成人av动漫网站| 美女爽到高潮91| 男女男精品视频网| 日本免费新一区视频| 天天综合天天做天天综合| 亚洲电影视频在线| 日韩电影免费在线观看网站| 婷婷中文字幕一区三区| 日韩电影一区二区三区| 久久草av在线| 成人黄页在线观看| 99久久国产综合色|国产精品| 色综合久久中文综合久久97| 色老汉一区二区三区| 欧美日韩精品欧美日韩精品| 91精品国产综合久久小美女| 欧美精品一区二区在线播放| 欧美经典三级视频一区二区三区| 国产精品乱人伦| 亚洲最色的网站| 日本亚洲视频在线| 国产成人高清在线| 在线观看91视频| 日韩美女视频一区二区在线观看| 精品国产成人系列| 亚洲欧洲美洲综合色网| 亚洲综合在线视频| 青草av.久久免费一区| 国产成人精品影视| 欧美在线你懂得| 久久色中文字幕| 一区二区三区四区视频精品免费| 免费视频最近日韩| 99久久99久久精品国产片果冻| 欧美私模裸体表演在线观看| xfplay精品久久| 亚洲精品欧美综合四区| 久久99久久99| 欧美色窝79yyyycom| 久久久久久久久蜜桃| 一区二区三区四区蜜桃| 国产福利一区二区三区视频在线| 欧美在线看片a免费观看| wwwwxxxxx欧美| 视频一区视频二区在线观看| 成人av网址在线| 日韩美女主播在线视频一区二区三区| 亚洲免费观看视频| 国产一区二区精品在线观看| 欧美老年两性高潮| 国产精品二三区| 国产高清无密码一区二区三区| 91精品国产综合久久精品| 亚洲人成亚洲人成在线观看图片| 国产真实乱子伦精品视频| 欧美日韩一本到| 亚洲乱码精品一二三四区日韩在线| 国产在线一区观看| 精品日韩欧美在线| 免费成人深夜小野草| 欧美日韩国产天堂| 亚洲精品国产精品乱码不99| 成人精品视频一区二区三区尤物| 欧美tickling网站挠脚心| 亚洲第一会所有码转帖| 日本电影欧美片| 亚洲色图一区二区| 成人免费高清在线观看| 久久久99久久| 国产盗摄女厕一区二区三区| 精品少妇一区二区| 韩国精品久久久| 久久久久国产免费免费| 国产精品一区二区在线播放| 久久中文字幕电影| 国产一区二区精品久久91| www激情久久| 国产成人精品免费视频网站| 中文字幕欧美国产| av中文字幕一区| 一区二区高清视频在线观看| 日本韩国精品一区二区在线观看| 亚洲人成电影网站色mp4| 91小宝寻花一区二区三区| 亚洲摸摸操操av| 欧美色精品天天在线观看视频| 亚洲香肠在线观看| 欧美精品国产精品| 激情都市一区二区| 中文字幕精品一区| 91久久精品国产91性色tv | 日韩国产精品久久久久久亚洲| 欧美日韩精品一区二区| 奇米一区二区三区| 久久精品视频一区二区三区| 懂色av中文字幕一区二区三区 | 午夜天堂影视香蕉久久| 91精品在线免费| 国产精品白丝jk黑袜喷水| 国产精品久久久久久久岛一牛影视 | 日韩高清一区二区| 欧美videos中文字幕| 不卡av免费在线观看| 亚洲在线视频一区| 久久在线观看免费| 欧美日韩一区二区三区四区 | 亚洲国产欧美在线| 精品日韩一区二区| 91精品国产综合久久精品| 国产毛片精品一区| 一区二区三区在线视频免费观看| 日韩视频一区在线观看| 丁香五精品蜜臀久久久久99网站 | 91麻豆精品国产综合久久久久久 | 欧美丝袜自拍制服另类| 韩国v欧美v日本v亚洲v| 亚洲电影在线播放| 中文字幕欧美日韩一区| 日韩精品专区在线影院重磅| 波多野结衣亚洲| 久久激情五月激情| 亚洲国产综合视频在线观看| 国产欧美一区二区在线观看| 在线播放中文一区| 99久久精品国产导航| 国产成人免费视频| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲综合色网站| 中文字幕一区二区在线播放 | 国产成人99久久亚洲综合精品| 亚洲成人av福利| 亚洲乱码国产乱码精品精可以看 | 国产欧美一区在线| 欧美成人伊人久久综合网| 欧美三级电影在线观看| 99久久久久久99| 丰满少妇久久久久久久| 国产永久精品大片wwwapp | 成人综合在线视频| 国产一区视频导航| 国产一区二区在线影院| 久久精品国产亚洲a| 免费成人av资源网| 久久 天天综合| 久久综合综合久久综合| 水野朝阳av一区二区三区| 亚洲一区二区三区三| 樱花草国产18久久久久| 亚洲日本乱码在线观看| 国产精品久久久久久久久免费相片| 久久久91精品国产一区二区三区| 久久香蕉国产线看观看99| 久久亚洲精华国产精华液 | 久久av中文字幕片| 韩国精品免费视频| 国产高清精品久久久久| 白白色 亚洲乱淫| 97久久精品人人澡人人爽| 91麻豆自制传媒国产之光| 色综合一个色综合亚洲| 欧美三级视频在线播放| 91精品国产色综合久久不卡电影| 69p69国产精品| 欧美r级电影在线观看| 久久精品一区二区三区av| 亚洲国产精华液网站w| 亚洲精品成人少妇| 婷婷综合久久一区二区三区| 久久精品国产一区二区三| 国产一区二区精品久久91| 丁香六月久久综合狠狠色| 色综合久久久久综合| 51精品秘密在线观看| 久久久久综合网| 一区二区三区四区在线免费观看 | 色综合天天综合在线视频| 在线成人av网站| 国产亚洲成年网址在线观看| 亚洲女女做受ⅹxx高潮| 日本成人在线看| 国产精品91xxx| 欧美羞羞免费网站| 精品动漫一区二区三区在线观看| 国产欧美日韩视频一区二区| 亚洲蜜桃精久久久久久久| 日韩国产欧美视频| 99精品视频中文字幕| 日韩视频免费直播| 国产精品久久久久三级| 日本vs亚洲vs韩国一区三区 | 国产精品国产成人国产三级| 亚洲成人动漫av| 福利视频网站一区二区三区| 欧美视频你懂的| 中文字幕av不卡| 美脚の诱脚舐め脚责91| 99免费精品在线观看| 日韩欧美一级二级|