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

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

?? stars3d.java

?? java2d的源碼分析
?? JAVA
字號:
/* * @(#)Stars3D.java	1.17 99/04/23 * * Copyright (c) 1998, 1999 by Sun Microsystems, Inc. All Rights Reserved. *  * Sun grants you ("Licensee") a non-exclusive, royalty free, license to use, * modify and redistribute this software in source and binary code form, * provided that i) this copyright notice and license appear on all copies of * the software; and ii) Licensee does not utilize the software in a manner * which is disparaging to Sun. *  * This software is provided "AS IS," without a warranty of any kind. ALL * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING ANY * IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR * NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN AND ITS LICENSORS SHALL NOT BE * LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING * OR DISTRIBUTING THE SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN OR ITS * LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR FOR DIRECT, * INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER * CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF THE USE OF * OR INABILITY TO USE SOFTWARE, EVEN IF SUN HAS BEEN ADVISED OF THE * POSSIBILITY OF SUCH DAMAGES. *  * This software is not designed or intended for use in on-line control of * aircraft, air traffic, aircraft navigation or aircraft communications; or in * the design, construction, operation or maintenance of any nuclear * facility. Licensee represents and warrants that it will not use or * redistribute the Software for such purposes. */package demos.Mix;import java.awt.*;import java.awt.event.*;import java.awt.geom.*;import java.awt.font.FontRenderContext;import javax.swing.*;import DemoSurface;import DemoPanel;import CustomControls;/** * Generate a 3D text shape with GeneralPath, render a number of small * multi-colored rectangles and then render the 3D text shape. */public class Stars3D extends DemoSurface implements CustomControls {    private static Color colors[] = { Color.red, Color.green, Color.white };    private static AffineTransform at = AffineTransform.getTranslateInstance(-5, -5);    private Shape shape, tshape;    private Shape ribbon;    protected int fontSize = 72;    protected String text = "J2D";    protected int numStars = 300;    private DemoControls controls;    public Stars3D() {        setBackground(Color.black);        controls = new DemoControls(this);    }    public String[] getCustomControlsConstraints() {        return new String[] { BorderLayout.NORTH };    }    public Component[] getCustomControls() {        return new Component[] { (Component) controls };    }    public void customControlsThread(int state) {        if (state == CustomControls.START) {            controls.start();        } else if (state == CustomControls.STOP) {            controls.stop();        }    }    public void drawDemo(int w, int h, Graphics2D g2) {        Rectangle2D rect = new Rectangle2D.Double();        for (int i = 0; i < numStars; i++) {            g2.setColor(colors[i%3]);            g2.setComposite(AlphaComposite.getInstance(                         AlphaComposite.SRC_OVER, (float) Math.random()));            rect.setRect(w*Math.random(), h*Math.random(),2,2);            g2.fill(rect);        }        FontRenderContext frc = g2.getFontRenderContext();        Font font = new Font("serif.bolditalic", Font.PLAIN, fontSize);        shape = font.createGlyphVector(frc, text).getOutline();        tshape = at.createTransformedShape(shape);        PathIterator pi = shape.getPathIterator(null);                float seg[] = new float[6];        float tseg[] = new float[6];                GeneralPath working = new GeneralPath(GeneralPath.WIND_NON_ZERO);        float x=0, y=0; // Current point on the path        float tx=0, ty=0; // Transformed path point        float cx=0, cy=0; // Last moveTo point, for SEG_CLOSE        float tcx=0, tcy=0; // Transformed last moveTo point                //        // Iterate through the Shape and build the ribbon        // by adding general path objects.        //        while(!pi.isDone()) {            int segType = pi.currentSegment(seg);            switch(segType) {                case PathIterator.SEG_MOVETO:                        at.transform(seg, 0, tseg, 0, 1);                        x = seg[0];                        y = seg[1];                        tx = tseg[0];                        ty = tseg[1];                        cx = x;                        cy = y;                        tcx = tx;                        tcy = ty;                        break;                case PathIterator.SEG_LINETO:                        at.transform(seg, 0, tseg, 0, 1);                        if (Line2D.relativeCCW(x, y, tx, ty,                                               seg[0], seg[1]) < 0) {                            working.moveTo(x, y);                            working.lineTo(seg[0], seg[1]);                            working.lineTo(tseg[0], tseg[1]);                            working.lineTo(tx, ty);                            working.lineTo(x, y);                        } else {                            working.moveTo(x, y);                            working.lineTo(tx, ty);                            working.lineTo(tseg[0], tseg[1]);                            working.lineTo(seg[0], seg[1]);                            working.lineTo(x, y);                        }                                                x = seg[0];                        y = seg[1];                        tx = tseg[0];                        ty = tseg[1];                        break;                                        case PathIterator.SEG_QUADTO:                        at.transform(seg, 0, tseg, 0, 2);                        if (Line2D.relativeCCW(x, y, tx, ty,                                               seg[2], seg[3]) < 0) {                            working.moveTo(x, y);                            working.quadTo(seg[0], seg[1],                                           seg[2], seg[3]);                            working.lineTo(tseg[2], tseg[3]);                            working.quadTo(tseg[0], tseg[1],                                           tx, ty);                            working.lineTo(x, y);                        } else {                            working.moveTo(x, y);                            working.lineTo(tx, ty);                            working.quadTo(tseg[0], tseg[1],                                           tseg[2], tseg[3]);                            working.lineTo(seg[2], seg[3]);                            working.quadTo(seg[0], seg[1],                                           x, y);                        }                                        x = seg[2];                        y = seg[3];                        tx = tseg[2];                        ty = tseg[3];                        break;                        case PathIterator.SEG_CUBICTO:                        at.transform(seg, 0, tseg, 0, 3);                        if (Line2D.relativeCCW(x, y, tx, ty,                                               seg[4], seg[5]) < 0) {                            working.moveTo(x, y);                            working.curveTo(seg[0], seg[1],                                            seg[2], seg[3],                                            seg[4], seg[5]);                            working.lineTo(tseg[4], tseg[5]);                            working.curveTo(tseg[2], tseg[3],                                            tseg[0], tseg[1],                                            tx, ty);                            working.lineTo(x, y);                        } else {                            working.moveTo(x, y);                            working.lineTo(tx, ty);                            working.curveTo(tseg[0], tseg[1],                                            tseg[2], tseg[3],                                            tseg[4], tseg[5]);                            working.lineTo(seg[4], seg[5]);                            working.curveTo(seg[2], seg[3],                                            seg[0], seg[1],                                            x, y);                        }                                        x = seg[4];                        y = seg[5];                        tx = tseg[4];                        ty = tseg[5];                        break;                        case PathIterator.SEG_CLOSE:                        if (Line2D.relativeCCW(x, y, tx, ty,                                               cx, cy) < 0) {                            working.moveTo(x, y);                            working.lineTo(cx, cy);                            working.lineTo(tcx, tcy);                            working.lineTo(tx, ty);                            working.lineTo(x, y);                        } else {                            working.moveTo(x, y);                            working.lineTo(tx, ty);                            working.lineTo(tcx, tcy);                            working.lineTo(cx, cy);                            working.lineTo(x, y);                        }                        x = cx;                         y = cy;                        tx = tcx;                        ty = tcy;            }            pi.next();        } // while        ribbon = working;        g2.setComposite(AlphaComposite.SrcOver);        Rectangle r = shape.getBounds();        g2.translate(w*.5-r.width*.5,h*.5+r.height*.5);        g2.setColor(Color.blue);        g2.fill(tshape);        g2.setColor(new Color(255, 255, 255, 200));        g2.fill(ribbon);        g2.setColor(Color.white);        g2.fill(shape);        g2.setColor(Color.blue);        g2.draw(shape);    }    public static void main(String argv[]) {        Frame f = new Frame("Java2D Demo - Stars3D");        f.addWindowListener(new WindowAdapter() {            public void windowClosing(WindowEvent e) {System.exit(0);}        });        f.add("Center", new DemoPanel(new Stars3D()));        f.pack();        f.setSize(new Dimension(400,300));        f.show();    }    static class DemoControls extends JPanel implements ActionListener, Runnable {        Stars3D demo;        JTextField tf1, tf2;        Thread thread;        public DemoControls(Stars3D demo) {            this.demo = demo;            setBackground(Color.gray);            JLabel l = new JLabel("  Text:");            l.setForeground(Color.black);            add(l);            add(tf1 = new JTextField(demo.text));            tf1.setPreferredSize(new Dimension(60,20));            tf1.addActionListener(this);            l = new JLabel("  Size:");            l.setForeground(Color.black);            add(l);            add(tf2 = new JTextField(String.valueOf(demo.fontSize)));            tf2.setPreferredSize(new Dimension(30,20));            tf2.addActionListener(this);            addMouseListener(new MouseAdapter() {                public void mouseClicked(MouseEvent e) {                    if (thread == null) start(); else stop();                }            });        }        public void actionPerformed(ActionEvent e) {            try {                 if (e.getSource().equals(tf1)) {                    demo.text = tf1.getText().trim();                } else if (e.getSource().equals(tf2)) {                    demo.fontSize = Integer.parseInt(tf2.getText().trim());                    if (demo.fontSize < 10) {                        demo.fontSize = 10;                    }                }                demo.repaint();            } catch (Exception ex) {}        }        public Dimension getPreferredSize() {            return new Dimension(200,32);        }        public void start() {            if (thread != null) {                return;            }            thread = new Thread(this);            thread.setPriority(Thread.MIN_PRIORITY);            thread.setName("Mix.Stars3D DemoControls Thread");            thread.start();        }        public synchronized void stop() {            if (thread != null) {                thread.interrupt();            }            thread = null;            notifyAll();        }        public void run() {            Thread me = Thread.currentThread();            try { thread.sleep(999); } catch (Exception e) { return; }            int width = getSize().width;            int size[] = { (int)(width*.25), (int)(width*.35)};            String str[] = { "JAVA", "J2D" };            while (thread == me) {                for (int i = 0; i < 2; i++) {                    demo.fontSize = size[i];                    tf2.setText(String.valueOf(demo.fontSize));                    tf1.setText(demo.text = str[i]);                    demo.repaint();                    try {                        thread.sleep(5555);                    } catch (InterruptedException e) { return; }                }            }            thread = null;        }    } // End DemoControls} // End Stars3D

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91麻豆国产精品久久| 日韩精品专区在线影院观看| 欧美在线免费观看视频| 欧美大度的电影原声| 亚洲婷婷综合色高清在线| 蜜臀99久久精品久久久久久软件| 不卡av在线网| 久久精品网站免费观看| 另类小说色综合网站| 欧美日韩免费在线视频| |精品福利一区二区三区| 国产真实乱偷精品视频免| 欧美日韩五月天| 亚洲乱码国产乱码精品精98午夜 | 亚洲一区二区3| 成人av在线一区二区三区| 日韩欧美视频在线| 日本欧美在线观看| 欧美性色黄大片| 亚洲欧美日韩国产综合| 成人av一区二区三区| 久久人人97超碰com| 久久99热这里只有精品| 日韩欧美久久久| 日韩电影免费在线| 91精品国产一区二区三区香蕉| 亚洲电影第三页| 欧美另类高清zo欧美| 午夜激情久久久| 欧美精品久久久久久久多人混战| 国产一区二区三区日韩| 亚洲色图制服丝袜| 中文字幕一区二区三区av| 日本不卡视频在线| 91黄视频在线| 亚洲最色的网站| 欧美最猛黑人xxxxx猛交| 国产欧美日韩另类一区| 国产美女在线精品| 中文字幕欧美三区| proumb性欧美在线观看| 中文字幕亚洲在| 欧美色电影在线| 国产精品欧美一级免费| 国产精品青草久久| 粉嫩久久99精品久久久久久夜| 精品国产免费一区二区三区四区| 麻豆精品在线观看| 欧美国产日韩亚洲一区| 色婷婷久久久综合中文字幕| 亚洲一区二区视频在线观看| 欧美日韩二区三区| 激情小说欧美图片| 国产精品国产精品国产专区不片| 一本久久综合亚洲鲁鲁五月天 | 蜜桃视频免费观看一区| 久久久青草青青国产亚洲免观| 高清在线观看日韩| 亚洲动漫第一页| 精品国产一区二区三区四区四 | 久久精品视频在线免费观看| 99re成人精品视频| 喷白浆一区二区| 中文字幕一区二区三区精华液| 欧美视频完全免费看| 韩国欧美国产1区| 一区二区三区精品在线| 精品成人a区在线观看| 99re免费视频精品全部| 久久99久久久欧美国产| ...av二区三区久久精品| 欧美日韩国产123区| 成人激情免费视频| 久久精品国产精品亚洲综合| 综合婷婷亚洲小说| www一区二区| 欧美日韩国产三级| 99视频在线精品| 韩国中文字幕2020精品| 亚洲在线观看免费| 中文字幕一区二区不卡 | 91蜜桃视频在线| 亚洲一区在线免费观看| 欧美成人乱码一区二区三区| 国产成人精品一区二区三区网站观看| 亚洲精选视频免费看| 日韩午夜激情电影| 91亚洲精品一区二区乱码| 蜜臀精品一区二区三区在线观看| 亚洲欧洲日产国产综合网| 日韩美女在线视频| 欧美裸体bbwbbwbbw| 99久久777色| 成人毛片老司机大片| 精品亚洲成a人在线观看| 亚洲在线观看免费| 玉足女爽爽91| 日韩毛片精品高清免费| 久久精品视频一区二区三区| 日韩午夜精品视频| 日韩精品一区二区三区老鸭窝 | 老司机午夜精品| 日本亚洲免费观看| 石原莉奈在线亚洲三区| 亚洲一二三四久久| 亚洲一区二区三区免费视频| 综合久久久久久| 亚洲日本一区二区| |精品福利一区二区三区| 国产精品三级av| 亚洲欧洲精品一区二区三区 | av亚洲精华国产精华精| 国产91精品久久久久久久网曝门 | 九九视频精品免费| 久久精品国产澳门| 久久不见久久见免费视频7 | 亚洲第一激情av| 一区二区三区欧美| 亚洲福利视频三区| 日韩极品在线观看| 久久国产日韩欧美精品| 美日韩一区二区| 国产精品资源在线| 成人激情小说乱人伦| 91女人视频在线观看| 欧美亚洲一区三区| 宅男噜噜噜66一区二区66| 欧美二区在线观看| 欧美v日韩v国产v| 国产亚洲欧美在线| 亚洲乱码中文字幕| 亚洲成年人网站在线观看| 热久久久久久久| 国产不卡在线播放| 色哟哟国产精品免费观看| 欧美日韩一区二区在线观看视频| 777午夜精品免费视频| www一区二区| 亚洲欧美日韩中文播放| 性做久久久久久免费观看欧美| 日本色综合中文字幕| 国产二区国产一区在线观看| 色婷婷一区二区三区四区| 欧美一级一区二区| 国产精品久久三| 亚洲成人av一区二区| 国产电影精品久久禁18| 欧美性色综合网| 久久五月婷婷丁香社区| 亚洲黄色av一区| 国产精品一区一区| 欧美狂野另类xxxxoooo| 久久精品亚洲乱码伦伦中文| 亚洲一区自拍偷拍| 国产v日产∨综合v精品视频| 欧美日韩精品系列| 国产女同互慰高潮91漫画| 天堂午夜影视日韩欧美一区二区| 国产一区福利在线| 欧美天天综合网| 国产精品丝袜一区| 老司机免费视频一区二区三区| 91色.com| 国产精品久久久久影院亚瑟| 日韩av电影免费观看高清完整版| 99国产精品久| 国产欧美日韩视频在线观看| 天天色综合天天| 一本到不卡精品视频在线观看| 精品少妇一区二区三区免费观看| 17c精品麻豆一区二区免费| 日本一道高清亚洲日美韩| 91黄色免费网站| 成人免费在线视频| 国产美女精品在线| 欧美一级高清大全免费观看| 亚洲日本护士毛茸茸| 国产精一品亚洲二区在线视频| 91精品国产色综合久久久蜜香臀| 一区二区三区四区五区视频在线观看| 国产激情一区二区三区桃花岛亚洲| 欧美日韩一级二级| 一区二区视频免费在线观看| 国产91精品入口| 国产欧美精品一区| 久久99这里只有精品| 日韩欧美在线观看一区二区三区| 一区二区激情小说| 91蜜桃在线观看| 最新国产成人在线观看| 成人高清免费在线播放| 久久午夜色播影院免费高清| 久久99这里只有精品| 精品国产乱码久久| 国产伦精品一区二区三区视频青涩 | 精品国产一区久久| 麻豆精品在线播放| 精品av综合导航| 国产美女在线观看一区| 国产欧美一二三区|