jdk/src/share/demo/applets/WireFrame/ThreeD.java
author mrkam
Fri, 25 Mar 2011 17:59:02 +0100
changeset 8973 1f4e90499324
parent 5506 202f599c92aa
child 10292 ed7db6a12c2a
permissions -rw-r--r--
7027692: /applets/WireFrame demo needs to be improved Reviewed-by: alexp
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     1
/*
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
     2
 * Copyright (c) 1995, 2011, Oracle and/or its affiliates. All rights reserved.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     3
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     4
 * Redistribution and use in source and binary forms, with or without
90ce3da70b43 Initial load
duke
parents:
diff changeset
     5
 * modification, are permitted provided that the following conditions
90ce3da70b43 Initial load
duke
parents:
diff changeset
     6
 * are met:
90ce3da70b43 Initial load
duke
parents:
diff changeset
     7
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     8
 *   - Redistributions of source code must retain the above copyright
90ce3da70b43 Initial load
duke
parents:
diff changeset
     9
 *     notice, this list of conditions and the following disclaimer.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    10
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    11
 *   - Redistributions in binary form must reproduce the above copyright
90ce3da70b43 Initial load
duke
parents:
diff changeset
    12
 *     notice, this list of conditions and the following disclaimer in the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    13
 *     documentation and/or other materials provided with the distribution.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    14
 *
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2
diff changeset
    15
 *   - Neither the name of Oracle nor the names of its
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    16
 *     contributors may be used to endorse or promote products derived
90ce3da70b43 Initial load
duke
parents:
diff changeset
    17
 *     from this software without specific prior written permission.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    18
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    19
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
90ce3da70b43 Initial load
duke
parents:
diff changeset
    20
 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    21
 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
90ce3da70b43 Initial load
duke
parents:
diff changeset
    22
 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR
90ce3da70b43 Initial load
duke
parents:
diff changeset
    23
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    24
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    25
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
90ce3da70b43 Initial load
duke
parents:
diff changeset
    26
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
90ce3da70b43 Initial load
duke
parents:
diff changeset
    27
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
90ce3da70b43 Initial load
duke
parents:
diff changeset
    28
 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
90ce3da70b43 Initial load
duke
parents:
diff changeset
    29
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    30
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    31
90ce3da70b43 Initial load
duke
parents:
diff changeset
    32
90ce3da70b43 Initial load
duke
parents:
diff changeset
    33
import java.applet.Applet;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    34
import java.awt.Graphics;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    35
import java.awt.Color;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    36
import java.awt.event.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    37
import java.io.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    38
import java.net.URL;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    39
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    40
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    41
/* A set of classes to parse, represent and display 3D wireframe models
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    42
represented in Wavefront .obj format. */
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    43
@SuppressWarnings("serial")
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    44
class FileFormatException extends Exception {
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    45
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    46
    public FileFormatException(String s) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    47
        super(s);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    48
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    49
}
90ce3da70b43 Initial load
duke
parents:
diff changeset
    50
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    51
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    52
/** The representation of a 3D model */
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    53
final class Model3D {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    54
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    55
    float vert[];
90ce3da70b43 Initial load
duke
parents:
diff changeset
    56
    int tvert[];
90ce3da70b43 Initial load
duke
parents:
diff changeset
    57
    int nvert, maxvert;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    58
    int con[];
90ce3da70b43 Initial load
duke
parents:
diff changeset
    59
    int ncon, maxcon;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    60
    boolean transformed;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    61
    Matrix3D mat;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    62
    float xmin, xmax, ymin, ymax, zmin, zmax;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    63
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    64
    Model3D() {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    65
        mat = new Matrix3D();
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    66
        mat.xrot(20);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    67
        mat.yrot(30);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    68
    }
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    69
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    70
    /** Create a 3D model by parsing an input stream */
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    71
    Model3D(InputStream is) throws IOException, FileFormatException {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    72
        this();
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    73
        StreamTokenizer st = new StreamTokenizer(
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    74
                new BufferedReader(new InputStreamReader(is, "UTF-8")));
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    75
        st.eolIsSignificant(true);
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    76
        st.commentChar('#');
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    77
        scan:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    78
        while (true) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    79
            switch (st.nextToken()) {
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    80
                default:
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    81
                    break scan;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    82
                case StreamTokenizer.TT_EOL:
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    83
                    break;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    84
                case StreamTokenizer.TT_WORD:
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    85
                    if ("v".equals(st.sval)) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    86
                        double x = 0, y = 0, z = 0;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    87
                        if (st.nextToken() == StreamTokenizer.TT_NUMBER) {
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    88
                            x = st.nval;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    89
                            if (st.nextToken() == StreamTokenizer.TT_NUMBER) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    90
                                y = st.nval;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    91
                                if (st.nextToken() == StreamTokenizer.TT_NUMBER) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    92
                                    z = st.nval;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    93
                                }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    94
                            }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    95
                        }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    96
                        addVert((float) x, (float) y, (float) z);
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    97
                        while (st.ttype != StreamTokenizer.TT_EOL && st.ttype
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    98
                                != StreamTokenizer.TT_EOF) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
    99
                            st.nextToken();
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   100
                        }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   101
                    } else if ("f".equals(st.sval) || "fo".equals(st.sval) || "l".
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   102
                            equals(st.sval)) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   103
                        int start = -1;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   104
                        int prev = -1;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   105
                        int n = -1;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   106
                        while (true) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   107
                            if (st.nextToken() == StreamTokenizer.TT_NUMBER) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   108
                                n = (int) st.nval;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   109
                                if (prev >= 0) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   110
                                    add(prev - 1, n - 1);
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   111
                                }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   112
                                if (start < 0) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   113
                                    start = n;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   114
                                }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   115
                                prev = n;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   116
                            } else if (st.ttype == '/') {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   117
                                st.nextToken();
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   118
                            } else {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   119
                                break;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   120
                            }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   121
                        }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   122
                        if (start >= 0) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   123
                            add(start - 1, prev - 1);
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   124
                        }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   125
                        if (st.ttype != StreamTokenizer.TT_EOL) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   126
                            break scan;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   127
                        }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   128
                    } else {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   129
                        while (st.nextToken() != StreamTokenizer.TT_EOL
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   130
                                && st.ttype != StreamTokenizer.TT_EOF) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   131
                            // no-op
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   132
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   133
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   134
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   135
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   136
        is.close();
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   137
        if (st.ttype != StreamTokenizer.TT_EOF) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   138
            throw new FileFormatException(st.toString());
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   139
        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   140
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   141
90ce3da70b43 Initial load
duke
parents:
diff changeset
   142
    /** Add a vertex to this model */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   143
    int addVert(float x, float y, float z) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   144
        int i = nvert;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   145
        if (i >= maxvert) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   146
            if (vert == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   147
                maxvert = 100;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   148
                vert = new float[maxvert * 3];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   149
            } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   150
                maxvert *= 2;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   151
                float nv[] = new float[maxvert * 3];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   152
                System.arraycopy(vert, 0, nv, 0, vert.length);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   153
                vert = nv;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   154
            }
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   155
        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   156
        i *= 3;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   157
        vert[i] = x;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   158
        vert[i + 1] = y;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   159
        vert[i + 2] = z;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   160
        return nvert++;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   161
    }
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   162
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   163
    /** Add a line from vertex p1 to vertex p2 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   164
    void add(int p1, int p2) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   165
        int i = ncon;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   166
        if (p1 >= nvert || p2 >= nvert) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   167
            return;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   168
        }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   169
        if (i >= maxcon) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   170
            if (con == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   171
                maxcon = 100;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   172
                con = new int[maxcon];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   173
            } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   174
                maxcon *= 2;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   175
                int nv[] = new int[maxcon];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   176
                System.arraycopy(con, 0, nv, 0, con.length);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   177
                con = nv;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   178
            }
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   179
        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   180
        if (p1 > p2) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   181
            int t = p1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   182
            p1 = p2;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   183
            p2 = t;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   184
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   185
        con[i] = (p1 << 16) | p2;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   186
        ncon = i + 1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   187
    }
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   188
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   189
    /** Transform all the points in this model */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   190
    void transform() {
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   191
        if (transformed || nvert <= 0) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   192
            return;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   193
        }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   194
        if (tvert == null || tvert.length < nvert * 3) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   195
            tvert = new int[nvert * 3];
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   196
        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   197
        mat.transform(vert, tvert, nvert);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   198
        transformed = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   199
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   200
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   201
    /* Quick Sort implementation
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   202
     */
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   203
    private void quickSort(int a[], int left, int right) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   204
        int leftIndex = left;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   205
        int rightIndex = right;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   206
        int partionElement;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   207
        if (right > left) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   208
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   209
            /* Arbitrarily establishing partition element as the midpoint of
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   210
             * the array.
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   211
             */
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   212
            partionElement = a[(left + right) / 2];
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   213
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   214
            // loop through the array until indices cross
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   215
            while (leftIndex <= rightIndex) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   216
                /* find the first element that is greater than or equal to
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   217
                 * the partionElement starting from the leftIndex.
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   218
                 */
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   219
                while ((leftIndex < right) && (a[leftIndex] < partionElement)) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   220
                    ++leftIndex;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   221
                }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   222
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   223
                /* find an element that is smaller than or equal to
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   224
                 * the partionElement starting from the rightIndex.
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   225
                 */
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   226
                while ((rightIndex > left) && (a[rightIndex] > partionElement)) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   227
                    --rightIndex;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   228
                }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   229
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   230
                // if the indexes have not crossed, swap
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   231
                if (leftIndex <= rightIndex) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   232
                    swap(a, leftIndex, rightIndex);
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   233
                    ++leftIndex;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   234
                    --rightIndex;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   235
                }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   236
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   237
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   238
            /* If the right index has not reached the left side of array
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   239
             * must now sort the left partition.
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   240
             */
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   241
            if (left < rightIndex) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   242
                quickSort(a, left, rightIndex);
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   243
            }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   244
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   245
            /* If the left index has not reached the right side of array
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   246
             * must now sort the right partition.
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   247
             */
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   248
            if (leftIndex < right) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   249
                quickSort(a, leftIndex, right);
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   250
            }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   251
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   252
        }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   253
    }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   254
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   255
    private void swap(int a[], int i, int j) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   256
        int T;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   257
        T = a[i];
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   258
        a[i] = a[j];
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   259
        a[j] = T;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   260
    }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   261
90ce3da70b43 Initial load
duke
parents:
diff changeset
   262
    /** eliminate duplicate lines */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   263
    void compress() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   264
        int limit = ncon;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   265
        int c[] = con;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   266
        quickSort(con, 0, ncon - 1);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   267
        int d = 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   268
        int pp1 = -1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   269
        for (int i = 0; i < limit; i++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   270
            int p1 = c[i];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   271
            if (pp1 != p1) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   272
                c[d] = p1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   273
                d++;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   274
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   275
            pp1 = p1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   276
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   277
        ncon = d;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   278
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   279
    static Color gr[];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   280
90ce3da70b43 Initial load
duke
parents:
diff changeset
   281
    /** Paint this model to a graphics context.  It uses the matrix associated
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   282
    with this model to map from model space to screen space.
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   283
    The next version of the browser should have double buffering,
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   284
    which will make this *much* nicer */
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   285
    void paint(Graphics g) {
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   286
        if (vert == null || nvert <= 0) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   287
            return;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   288
        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   289
        transform();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   290
        if (gr == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   291
            gr = new Color[16];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   292
            for (int i = 0; i < 16; i++) {
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   293
                int grey = (int) (170 * (1 - Math.pow(i / 15.0, 2.3)));
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   294
                gr[i] = new Color(grey, grey, grey);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   295
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   296
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   297
        int lg = 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   298
        int lim = ncon;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   299
        int c[] = con;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   300
        int v[] = tvert;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   301
        if (lim <= 0 || nvert <= 0) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   302
            return;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   303
        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   304
        for (int i = 0; i < lim; i++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   305
            int T = c[i];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   306
            int p1 = ((T >> 16) & 0xFFFF) * 3;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   307
            int p2 = (T & 0xFFFF) * 3;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   308
            int grey = v[p1 + 2] + v[p2 + 2];
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   309
            if (grey < 0) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   310
                grey = 0;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   311
            }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   312
            if (grey > 15) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   313
                grey = 15;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   314
            }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   315
            if (grey != lg) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   316
                lg = grey;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   317
                g.setColor(gr[grey]);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   318
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   319
            g.drawLine(v[p1], v[p1 + 1],
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   320
                    v[p2], v[p2 + 1]);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   321
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   322
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   323
90ce3da70b43 Initial load
duke
parents:
diff changeset
   324
    /** Find the bounding box of this model */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   325
    void findBB() {
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   326
        if (nvert <= 0) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   327
            return;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   328
        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   329
        float v[] = vert;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   330
        float _xmin = v[0], _xmax = _xmin;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   331
        float _ymin = v[1], _ymax = _ymin;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   332
        float _zmin = v[2], _zmax = _zmin;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   333
        for (int i = nvert * 3; (i -= 3) > 0;) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   334
            float x = v[i];
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   335
            if (x < _xmin) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   336
                _xmin = x;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   337
            }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   338
            if (x > _xmax) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   339
                _xmax = x;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   340
            }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   341
            float y = v[i + 1];
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   342
            if (y < _ymin) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   343
                _ymin = y;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   344
            }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   345
            if (y > _ymax) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   346
                _ymax = y;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   347
            }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   348
            float z = v[i + 2];
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   349
            if (z < _zmin) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   350
                _zmin = z;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   351
            }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   352
            if (z > _zmax) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   353
                _zmax = z;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   354
            }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   355
        }
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   356
        this.xmax = _xmax;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   357
        this.xmin = _xmin;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   358
        this.ymax = _ymax;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   359
        this.ymin = _ymin;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   360
        this.zmax = _zmax;
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   361
        this.zmin = _zmin;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   362
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   363
}
90ce3da70b43 Initial load
duke
parents:
diff changeset
   364
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   365
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   366
/** An applet to put a 3D model into a page */
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   367
@SuppressWarnings("serial")
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   368
public class ThreeD extends Applet
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   369
        implements Runnable, MouseListener, MouseMotionListener {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   370
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   371
    Model3D md;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   372
    boolean painted = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   373
    float xfac;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   374
    int prevx, prevy;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   375
    float scalefudge = 1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   376
    Matrix3D amat = new Matrix3D(), tmat = new Matrix3D();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   377
    String mdname = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   378
    String message = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   379
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   380
    @Override
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   381
    public void init() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   382
        mdname = getParameter("model");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   383
        try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   384
            scalefudge = Float.valueOf(getParameter("scale")).floatValue();
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   385
        } catch (Exception ignored) {
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   386
            // fall back to default scalefudge = 1
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   387
        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   388
        amat.yrot(20);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   389
        amat.xrot(20);
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   390
        if (mdname == null) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   391
            mdname = "model.obj";
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   392
        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   393
        resize(getSize().width <= 20 ? 400 : getSize().width,
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   394
                getSize().height <= 20 ? 400 : getSize().height);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   395
        addMouseListener(this);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   396
        addMouseMotionListener(this);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   397
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   398
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   399
    @Override
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   400
    public void destroy() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   401
        removeMouseListener(this);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   402
        removeMouseMotionListener(this);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   403
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   404
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   405
    @Override
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   406
    public void run() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   407
        InputStream is = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   408
        try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   409
            Thread.currentThread().setPriority(Thread.MIN_PRIORITY);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   410
            is = new URL(getDocumentBase(), mdname).openStream();
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   411
            Model3D m = new Model3D(is);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   412
            md = m;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   413
            m.findBB();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   414
            m.compress();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   415
            float xw = m.xmax - m.xmin;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   416
            float yw = m.ymax - m.ymin;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   417
            float zw = m.zmax - m.zmin;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   418
            if (yw > xw) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   419
                xw = yw;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   420
            }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   421
            if (zw > xw) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   422
                xw = zw;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   423
            }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   424
            float f1 = getSize().width / xw;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   425
            float f2 = getSize().height / xw;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   426
            xfac = 0.7f * (f1 < f2 ? f1 : f2) * scalefudge;
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   427
        } catch (Exception e) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   428
            md = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   429
            message = e.toString();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   430
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   431
        try {
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   432
            if (is != null) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   433
                is.close();
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   434
            }
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   435
        } catch (Exception e) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   436
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   437
        repaint();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   438
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   439
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   440
    @Override
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   441
    public void start() {
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   442
        if (md == null && message == null) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   443
            new Thread(this).start();
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   444
        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   445
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   446
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   447
    @Override
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   448
    public void stop() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   449
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   450
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   451
    @Override
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   452
    public void mouseClicked(MouseEvent e) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   453
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   454
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   455
    @Override
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   456
    public void mousePressed(MouseEvent e) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   457
        prevx = e.getX();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   458
        prevy = e.getY();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   459
        e.consume();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   460
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   461
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   462
    @Override
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   463
    public void mouseReleased(MouseEvent e) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   464
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   465
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   466
    @Override
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   467
    public void mouseEntered(MouseEvent e) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   468
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   469
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   470
    @Override
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   471
    public void mouseExited(MouseEvent e) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   472
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   473
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   474
    @Override
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   475
    public void mouseDragged(MouseEvent e) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   476
        int x = e.getX();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   477
        int y = e.getY();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   478
90ce3da70b43 Initial load
duke
parents:
diff changeset
   479
        tmat.unit();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   480
        float xtheta = (prevy - y) * 360.0f / getSize().width;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   481
        float ytheta = (x - prevx) * 360.0f / getSize().height;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   482
        tmat.xrot(xtheta);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   483
        tmat.yrot(ytheta);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   484
        amat.mult(tmat);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   485
        if (painted) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   486
            painted = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   487
            repaint();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   488
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   489
        prevx = x;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   490
        prevy = y;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   491
        e.consume();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   492
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   493
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   494
    @Override
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   495
    public void mouseMoved(MouseEvent e) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   496
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   497
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   498
    @Override
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   499
    public void paint(Graphics g) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   500
        if (md != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   501
            md.mat.unit();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   502
            md.mat.translate(-(md.xmin + md.xmax) / 2,
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   503
                    -(md.ymin + md.ymax) / 2,
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   504
                    -(md.zmin + md.zmax) / 2);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   505
            md.mat.mult(amat);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   506
            md.mat.scale(xfac, -xfac, 16 * xfac / getSize().width);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   507
            md.mat.translate(getSize().width / 2, getSize().height / 2, 8);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   508
            md.transformed = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   509
            md.paint(g);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   510
            setPainted();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   511
        } else if (message != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   512
            g.drawString("Error in model:", 3, 20);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   513
            g.drawString(message, 10, 40);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   514
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   515
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   516
90ce3da70b43 Initial load
duke
parents:
diff changeset
   517
    private synchronized void setPainted() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   518
        painted = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   519
        notifyAll();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   520
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   521
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   522
    @Override
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   523
    public String getAppletInfo() {
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   524
        return "Title: ThreeD \nAuthor: James Gosling? \n"
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   525
                + "An applet to put a 3D model into a page.";
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   526
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   527
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   528
    @Override
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   529
    public String[][] getParameterInfo() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   530
        String[][] info = {
8973
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   531
            { "model", "path string", "The path to the model to be displayed." },
1f4e90499324 7027692: /applets/WireFrame demo needs to be improved
mrkam
parents: 5506
diff changeset
   532
            { "scale", "float", "The scale of the model.  Default is 1." }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   533
        };
90ce3da70b43 Initial load
duke
parents:
diff changeset
   534
        return info;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   535
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   536
}