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

📄 lineanim.java

📁 这是ACCP的JAVA ppt课件
💻 JAVA
字号:
/* * Copyright (c) 2003 Sun Microsystems, Inc. All  Rights Reserved. *  * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: *  * -Redistributions of source code must retain the above copyright *  notice, this list of conditions and the following disclaimer. *  * -Redistribution in binary form must reproduct the above copyright *  notice, this list of conditions and the following disclaimer in *  the documentation and/or other materials provided with the distribution. *  * Neither the name of Sun Microsystems, Inc. or the names of contributors * may be used to endorse or promote products derived from this software * without specific prior written permission. *  * 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 OR LIABILITIES SUFFERED BY LICENSEE AS A RESULT * OF OR RELATING TO USE, MODIFICATION OR DISTRIBUTION OF 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. *  * You acknowledge that Software is not designed, licensed or intended for * use in the design, construction, operation or maintenance of any nuclear * facility. *//* * @(#)LineAnim.java	1.20 03/01/23 */package java2d.demos.Lines;import java.awt.*;import java.awt.geom.*;import java.awt.font.TextLayout;import java2d.AnimatingSurface;/** * Lines & Paths animation illustrating BasicStroke attributes. */public class LineAnim extends AnimatingSurface {    private static int caps[] = { BasicStroke.CAP_BUTT,                 BasicStroke.CAP_SQUARE, BasicStroke.CAP_ROUND};    private static int joins[] = { BasicStroke.JOIN_MITER,                 BasicStroke.JOIN_BEVEL, BasicStroke.JOIN_ROUND};    private static Color colors[] = {Color.gray, Color.pink, Color.lightGray};    private static BasicStroke bs1 = new BasicStroke(1.0f);    private static final int CLOCKWISE = 0;    private static final int COUNTERCW = 1;    private Line2D lines[] = new Line2D[3];    private int rAmt[] = new int[lines.length];    private int direction[] = new int[lines.length];    private int speed[] = new int[lines.length];    private BasicStroke strokes[] = new BasicStroke[lines.length];    private GeneralPath path;    private Point2D[] pts;    private float size;    private Ellipse2D ellipse = new Ellipse2D.Double();    public LineAnim() {        setBackground(Color.white);    }    public void reset(int w, int h) {        size = (w > h) ? h/6f : w/6f;        for (int i = 0; i < lines.length; i++) {            lines[i] = new Line2D.Float(0,0,size,0);            strokes[i] = new BasicStroke(size/3, caps[i], joins[i]);            rAmt[i] = i * 360/lines.length;            direction[i] = i%2;            speed[i] = i + 1;        }        path = new GeneralPath();        path.moveTo(size, -size/2);        path.lineTo(size+size/2, 0);        path.lineTo(size, +size/2);        ellipse.setFrame(w/2-size*2-4.5f,h/2-size*2-4.5f,size*4,size*4);        PathIterator pi = ellipse.getPathIterator(null, 0.9);        Point2D[] points = new Point2D[100];        int num_pts = 0;        while ( !pi.isDone() ) {            float[] pt = new float[6];            switch ( pi.currentSegment(pt) ) {                case FlatteningPathIterator.SEG_MOVETO:                case FlatteningPathIterator.SEG_LINETO:                    points[num_pts] = new Point2D.Float(pt[0], pt[1]);                    num_pts++;            }            pi.next();        }        pts = new Point2D[num_pts];        System.arraycopy(points, 0, pts, 0, num_pts);    }    public void step(int w, int h) {        for (int i = 0; i < lines.length; i++) {            if (direction[i] == CLOCKWISE) {                rAmt[i] += speed[i];                if (rAmt[i] == 360) {                    rAmt[i] = 0;                }            } else {                rAmt[i] -= speed[i];                if (rAmt[i] == 0) {                    rAmt[i] = 360;                }            }        }    }    public void render(int w, int h, Graphics2D g2) {        ellipse.setFrame(w/2-size,h/2-size,size*2,size*2);        g2.setColor(Color.black);        g2.draw(ellipse);        for (int i = 0; i < lines.length; i++) {            AffineTransform at = AffineTransform.getTranslateInstance(w/2,h/2);            at.rotate(Math.toRadians(rAmt[i]));            g2.setStroke(strokes[i]);            g2.setColor(colors[i]);            g2.draw(at.createTransformedShape(lines[i]));            g2.draw(at.createTransformedShape(path));            int j = (int) ((double) rAmt[i]/360 * pts.length);            j = (j == pts.length) ? pts.length-1 : j;            ellipse.setFrame(pts[j].getX(), pts[j].getY(), 9, 9);            g2.fill(ellipse);        }        g2.setStroke(bs1);        g2.setColor(Color.black);        for (int i = 0; i < pts.length; i++) {            ellipse.setFrame(pts[i].getX(), pts[i].getY(), 9, 9);            g2.draw(ellipse);        }    }    public static void main(String argv[]) {        createDemoFrame(new LineAnim());    }}

⌨️ 快捷键说明

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