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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? compassplot.java

?? Web圖形化的Java庫(kù)
?? JAVA
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
                setSeriesNeedle(index, new ArrowNeedle(true));
                break;
            default:
                String message = "CompassPlot.setSeriesNeedle(...): unrecognised type.";
                throw new IllegalArgumentException(message);
        }
        
    }

    /**
     * Sets the needle for a series.
     *
     * @param index  the series index.
     * @param needle  the needle.
     */
    public void setSeriesNeedle(int index, MeterNeedle needle) {

        if ((needle != null) && (index < seriesNeedle.length)) {
            seriesNeedle[index] = needle;
        }
        notifyListeners(new PlotChangeEvent(this));

    }

    /**
     * Returns the dataset.
     * <P>
     * Provided for convenience.
     *
     * @return    The dataset for the plot, cast as a ValueDataset.
     */
    public ValueDataset[] getData() {
        return this.datasets;
    }

    /**
     * Adds a dataset to the compass.
     *
     * @param data  the new dataset.
     */
    public void addData(ValueDataset data) {
        addData(data, null);
    }

    /**
     * Adds a dataset to the compass.
     *
     * @param data  the new dataset.
     * @param needle  the needle.
     */
    public void addData(ValueDataset data, MeterNeedle needle) {

        if (data != null) {
            int i = datasets.length + 1;
            ValueDataset[] t = new ValueDataset[i];
            MeterNeedle[] p = new MeterNeedle[i];
            i = i - 2;
            for (; i >= 0; --i) {
                t[i] = datasets[i];
                p[i] = seriesNeedle[i];
            }
            i = datasets.length;
            t[i] = data;
            p[i] = ((needle != null) ? needle : p[i - 1]);

            ValueDataset[] a = datasets;
            MeterNeedle[] b = seriesNeedle;
            datasets = t;
            seriesNeedle = p;

            for (--i; i >= 0; --i) {
                a[i] = null;
                b[i] = null;
            }
            data.addChangeListener(this);
        }
    }

    /**
     * Draws the plot on a Java 2D graphics device (such as the screen or a printer).
     *
     * @param g2  the graphics device.
     * @param plotArea  the area within which the plot should be drawn.
     * @param info  collects info about the drawing.
     */
    public void draw(Graphics2D g2, Rectangle2D plotArea, ChartRenderingInfo info) {

        int outerRadius = 0;
        int innerRadius = 0;
        int x1, y1, x2, y2;
        double a;

        if (info != null) {
            info.setPlotArea(plotArea);
        }

        // adjust for insets...
        Insets insets = getInsets();
        if (insets != null) {
            plotArea.setRect(plotArea.getX() + insets.left,
                             plotArea.getY() + insets.top,
                             plotArea.getWidth() - insets.left - insets.right,
                             plotArea.getHeight() - insets.top - insets.bottom);
        }

        // draw the background
        if (drawBorder) {
            drawBackground(g2, plotArea);
        }

        int midX = (int) (plotArea.getWidth() / 2);
        int midY = (int) (plotArea.getHeight() / 2);
        int radius = midX;
        if (midY < midX) {
            radius = midY;
        }
        --radius;
        int diameter = 2 * radius;

        midX += (int) plotArea.getMinX();
        midY += (int) plotArea.getMinY();

        circle1.setFrame(midX - radius, midY - radius, diameter, diameter);
        circle2.setFrame(midX - radius + 15, midY - radius + 15, diameter - 30, diameter - 30);
        g2.setPaint(this.rosePaint);
        a1 = new Area(circle1);
        a2 = new Area(circle2);
        a1.subtract(a2);
        g2.fill(a1);

        g2.setPaint(this.roseCenterPaint);
        x1 = diameter - 30;
        g2.fillOval(midX - radius + 15, midY - radius + 15, x1, x1);
        g2.setPaint(this.roseHighlightPaint);
        g2.drawOval(midX - radius, midY - radius, diameter, diameter);
        x1 = diameter - 20;
        g2.drawOval(midX - radius + 10, midY - radius + 10, x1, x1);
        x1 = diameter - 30;
        g2.drawOval(midX - radius + 15, midY - radius + 15, x1, x1);
        x1 = diameter - 80;
        g2.drawOval(midX - radius + 40, midY - radius + 40, x1, x1);

        outerRadius = radius - 20;
        innerRadius = radius - 32;
        for (int w = 0; w < 360; w += 15) {
            a = Math.toRadians(w);
            x1 = midX - ((int) (Math.sin(a) * innerRadius));
            x2 = midX - ((int) (Math.sin(a) * outerRadius));
            y1 = midY - ((int) (Math.cos(a) * innerRadius));
            y2 = midY - ((int) (Math.cos(a) * outerRadius));
            g2.drawLine(x1, y1, x2, y2);
        }

        g2.setPaint(this.roseHighlightPaint);
        innerRadius = radius - 26;
        outerRadius = 7;
        for (int w = 45; w < 360; w += 90) {
            a = Math.toRadians(w);
            x1 = midX - ((int) (Math.sin(a) * innerRadius));
            y1 = midY - ((int) (Math.cos(a) * innerRadius));
            g2.fillOval(x1 - outerRadius, y1 - outerRadius, 2 * outerRadius, 2 * outerRadius);
        }

        /// Squares
        for (int w = 0; w < 360; w += 90) {
            a = Math.toRadians(w);
            x1 = midX - ((int) (Math.sin(a) * innerRadius));
            y1 = midY - ((int) (Math.cos(a) * innerRadius));

            Polygon p = new Polygon();
            p.addPoint(x1 - outerRadius, y1);
            p.addPoint(x1, y1 + outerRadius);
            p.addPoint(x1 + outerRadius, y1);
            p.addPoint(x1, y1 - outerRadius);
            g2.fillPolygon(p);
        }

        /// Draw N, S, E, W
        innerRadius = radius - 42;
        Font f = getCompassFont(radius);
        g2.setFont(f);
        g2.drawString("N", midX - 5, midY - innerRadius + f.getSize());
        g2.drawString("S", midX - 5, midY + innerRadius - 5);
        g2.drawString("W", midX - innerRadius + 5, midY + 5);
        g2.drawString("E", midX + innerRadius - f.getSize(), midY + 5);

        // plot the data (unless the dataset is null)...
        y1 = radius / 2;
        x1 = radius / 6;
        Rectangle2D needleArea = new Rectangle2D.Double((midX - x1), (midY - y1),
                                                        (2 * x1), (2 * y1));
        int x = seriesNeedle.length;
        int current = 0;
        double value = 0;
        int i = (datasets.length - 1);
        for (; i >= 0; --i) {
            ValueDataset data = datasets[i];

            if (data != null) {
                value = (data.getValue().doubleValue()) % 360;
                current = i % x;
                seriesNeedle[current].draw(g2, needleArea, value);
            }
        }

        if (drawBorder) {
            drawOutline(g2, plotArea);
        }

    }

    /**
     * Returns a short string describing the type of plot.
     *
     * @return a string describing the plot.
     */
    public String getPlotType() {
        return localizationResources.getString("Compass_Plot");
    }

    /**
     * Returns the legend items for the plot.  For now, no legend is available - this method
     * returns null.
     *
     * @return the legend items.
     */
    public LegendItemCollection getLegendItems() {
        return null;
    }

    /**
     * No zooming is implemented for compass plot, so this method is empty.
     *
     * @param percent  the zoom amount.
     */
    public void zoom(double percent) {
    }

    /**
     * Returns the font for the compass.
     *
     * @param radius the radius.
     *
     * @return the font.
     */
    protected Font getCompassFont(int radius) {

        float fontSize = radius / 10;
        if (fontSize < 8) {
            fontSize = 8;
        }

        Font newFont = compassFont.deriveFont(fontSize);
        return newFont;

    }

    /**
     * Returns a list of legend item labels.
     *
     * @return a list of legend item labels.
     *
     * @deprecated use getLegendItems().
     */
    public java.util.List getLegendItemLabels() {
        return null;
    }
    
    
    /**
     * Tests an object for equality with this plot.
     * 
     * @param object  the object.
     * 
     * @return A boolean.
     */
    public boolean equals(Object object) {
    
        if (object == null) {
            return false;    
        }
        
        if (object == this) {
            return true;
        }
        
        if (object instanceof CompassPlot && super.equals(object)) {
            CompassPlot p = (CompassPlot) object;
            
            boolean b0 = (this.labelType == p.labelType);
            boolean b1 = ObjectUtils.equal(this.labelFont, p.labelFont);
            boolean b2 = (this.drawBorder == p.drawBorder);
            boolean b3 = ObjectUtils.equal(this.roseHighlightPaint, p.roseHighlightPaint);
            boolean b4 = ObjectUtils.equal(this.rosePaint, p.rosePaint);
            boolean b5 = ObjectUtils.equal(this.roseCenterPaint, p.roseCenterPaint);
            boolean b6 = ObjectUtils.equal(this.compassFont, p.compassFont);
            boolean b7 = Arrays.equals(this.seriesNeedle, p.seriesNeedle);
            
            return b0 && b1 && b2 && b3 && b4 && b5 && b6 && b7;
            
        }
        return false;
        
    }
    
    /**
     * Returns a clone of the annotation.
     * 
     * @return A clone.
     * 
     * @throws CloneNotSupportedException  this class will not throw this exception, but subclasses
     *         (if any) might.
     */
    public Object clone() throws CloneNotSupportedException {

        CompassPlot clone = (CompassPlot) super.clone();
        //private int labelType <-- primitive
        //private Font labelFont <-- immutable
        //private boolean drawBorder = false <-- primitive
        //private Color roseHighlightColour <-- immutable
        //private Color roseColour <-- immutable
        //private Color roseCenterColour <-- immutable
        //private Font compassFont <-- immutable
        clone.circle1 = (Ellipse2D) this.circle1.clone();
        clone.circle2 = (Ellipse2D) this.circle2.clone();
        clone.a1 = (Area) this.a1.clone();
        clone.a2 = (Area) this.a2.clone();
        clone.rect1 = (Rectangle2D) this.rect1.clone();
        clone.datasets = (ValueDataset[]) this.datasets.clone();
        clone.seriesNeedle = (MeterNeedle[]) this.seriesNeedle.clone();
        
        return clone();

    }


}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本一区二区三区四区在线视频 | 777xxx欧美| 极品美女销魂一区二区三区 | 91麻豆精品国产自产在线观看一区 | 国产91丝袜在线观看| 视频在线在亚洲| 亚洲美女一区二区三区| 久久综合精品国产一区二区三区| 欧美探花视频资源| av电影一区二区| 国产精品一区二区果冻传媒| 亚洲成a天堂v人片| 亚洲美女在线一区| 国产精品盗摄一区二区三区| 久久久久久一二三区| 91精品国产综合久久蜜臀| 色综合中文字幕| 成人精品视频一区二区三区| 国产一区二区调教| 免费看黄色91| 亚洲成av人影院在线观看网| 亚洲丝袜自拍清纯另类| 久久精品视频免费| 国产日韩精品一区二区三区在线| 欧美精品乱码久久久久久按摩| 色婷婷综合视频在线观看| 波多野结衣精品在线| 狠狠色丁香婷综合久久| 久久国产免费看| 久久精品国产一区二区三区免费看| 香蕉久久夜色精品国产使用方法 | 1024成人网| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 视频一区视频二区中文字幕| 尤物在线观看一区| 亚洲综合一区在线| 一区二区成人在线观看| 一区二区在线观看不卡| 一区二区三区91| 亚洲成人免费av| 日韩电影在线免费| 精品一区二区影视| 国产美女av一区二区三区| 国产真实乱偷精品视频免| 国产乱子伦视频一区二区三区| 国产一区中文字幕| 国产1区2区3区精品美女| 成人性生交大片| 99久久国产综合精品色伊| 日本道在线观看一区二区| 欧美在线一二三| 欧美高清你懂得| 久久亚洲影视婷婷| 国产日韩欧美不卡| 亚洲欧美偷拍另类a∨色屁股| 一区二区在线免费| 日韩国产一二三区| 国产美女一区二区三区| 大美女一区二区三区| 色94色欧美sute亚洲线路一ni | 99精品视频在线观看免费| 欧洲av在线精品| 欧美变态tickling挠脚心| 久久精品免视看| 亚洲免费观看在线观看| 性做久久久久久免费观看| 国精产品一区一区三区mba桃花 | 亚洲激情在线激情| 美女一区二区视频| 懂色av中文字幕一区二区三区 | 久久久亚洲国产美女国产盗摄| 中文字幕一区二区三中文字幕| 亚洲午夜私人影院| 国产精品一区在线| 日本高清不卡aⅴ免费网站| 欧美一级日韩不卡播放免费| 国产清纯美女被跳蛋高潮一区二区久久w| 中文字幕在线一区| 美腿丝袜在线亚洲一区 | 91丨九色丨蝌蚪富婆spa| 欧美疯狂性受xxxxx喷水图片| 久久久久久久一区| 一区二区三区成人| 国产iv一区二区三区| 欧美理论在线播放| 国产精品网站在线播放| 日韩va亚洲va欧美va久久| www.欧美色图| 日韩一卡二卡三卡| 一区二区三区不卡视频在线观看 | 欧美在线视频你懂得| 久久久精品天堂| 爽爽淫人综合网网站| av在线播放一区二区三区| 日韩精品一区二区三区中文不卡| 自拍偷在线精品自拍偷无码专区| 免费在线看一区| 色婷婷综合久久久久中文| 久久这里只精品最新地址| 亚洲成人免费视| 99精品欧美一区二区三区小说| 欧美精品一区二| 午夜精品123| 91丨九色porny丨蝌蚪| 亚洲精品一区二区在线观看| 偷拍亚洲欧洲综合| 91浏览器在线视频| 中文字幕精品综合| 国产一区免费电影| 欧美videossexotv100| 亚洲一区二区三区四区在线免费观看| 成人中文字幕合集| 久久网这里都是精品| 蜜臀av性久久久久蜜臀aⅴ| 欧美少妇xxx| 亚洲综合免费观看高清完整版在线 | 日韩电影在线看| 欧美精品电影在线播放| 亚洲激情在线播放| 色婷婷精品久久二区二区蜜臀av| 国产日韩欧美制服另类| 国产精品自拍网站| 久久婷婷国产综合国色天香 | 91美女在线看| 国产精品久久久久7777按摩 | 日韩三级免费观看| 日韩在线播放一区二区| 欧美日本一区二区三区四区| 一级女性全黄久久生活片免费| 91在线观看视频| 国产精品二区一区二区aⅴ污介绍| 国产福利视频一区二区三区| 国产日产精品1区| 国产99久久久国产精品| 国产精品久久午夜| 99精品视频在线观看免费| 亚洲欧美激情在线| 欧美写真视频网站| 欧美美女网站色| 精品久久人人做人人爽| 久久亚洲私人国产精品va媚药| 午夜精品久久久| 欧美一二三区在线| 久久av资源站| 欧美激情中文不卡| a级精品国产片在线观看| 成人免费在线观看入口| 欧美性大战久久久久久久蜜臀| 午夜精品一区二区三区免费视频| 欧美福利电影网| 国产一区二区三区观看| 国产精品久久久久久久久图文区| 成人av在线播放网址| 亚洲黄色性网站| 91精品国产乱码久久蜜臀| 极品瑜伽女神91| 中文字幕av资源一区| 欧美性大战久久久久久久蜜臀| 日本欧美一区二区| 久久久国产精品不卡| 99久久国产免费看| 五月天欧美精品| 国产亚洲成aⅴ人片在线观看 | 国产一区二区影院| 亚洲欧洲日产国码二区| 欧美男男青年gay1069videost| 蜜桃av噜噜一区二区三区小说| 欧美经典一区二区| 欧美性三三影院| 精品一区二区三区久久| 一区视频在线播放| 日韩一区二区三| av成人免费在线| 免费观看一级特黄欧美大片| 欧美极品少妇xxxxⅹ高跟鞋 | 亚洲欧美视频一区| 日韩欧美一区在线| 色综合亚洲欧洲| 久久66热re国产| 一区二区在线免费| 久久久久国产一区二区三区四区| 色婷婷激情一区二区三区| 免费观看在线综合色| 中文字幕在线观看不卡视频| 91精品欧美久久久久久动漫| 国产成都精品91一区二区三| 婷婷综合五月天| 国产精品伦理一区二区| 欧美一二区视频| 日本电影亚洲天堂一区| 国产福利一区二区三区| 日韩av不卡在线观看| 亚洲人成7777| 欧美激情综合在线| 日韩三级电影网址| 欧美亚洲另类激情小说| 成人激情图片网| 麻豆成人91精品二区三区| 亚洲一二三级电影| 亚洲免费观看高清完整版在线|