/* Mykeynavbeh.java * Originally based on code from BackgroundApp.java * @(#)BackgroundApp.java 1.1 00/09/22 14:03 * * portions Copyright (c) 1996-2000 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. */
import java.awt.*;
import javax.media.j3d.*;import javax.vecmath.*;
import com.sun.j3d.utils.universe.SimpleUniverse;import com.sun.j3d.utils.universe.PlatformGeometry;import com.sun.j3d.utils.behaviors.keyboard.*;
import com.sun.j3d.loaders.Scene;
import java.awt.event.KeyListener;import java.awt.event.KeyEvent;
import java.util.*;
import com.sun.j3d.loaders.objectfile.ObjectFile;import java.io.*;
import java.awt.event.*;
import com.sun.j3d.utils.image.TextureLoader;
public class Mykeynavbeh extends Frame implements KeyListener {
private SimpleUniverse universe = null; private Canvas3D canvas = null; private TransformGroup viewtrans = null;
private TransformGroup tg = null; private Transform3D t3d = null; private Transform3D t3dstep = new Transform3D();
private Matrix4d matrix = new Matrix4d();
private Switch selector = new Switch(Switch.CHILD_MASK); private BitSet flag_i = new BitSet(2);
private Switch selector_2 = new Switch(Switch.CHILD_MASK); private BitSet flag_i_2 = new BitSet(8);
private int count = 0; private int count_2 = 0;
private Alpha alpha = null;
private TransformGroup tg_2 = null; private Transform3D t3d_2 = null;
private KeyNavigatorBehavior keyNavBeh;
public Mykeynavbeh() { setLayout(new BorderLayout()); GraphicsConfiguration config = SimpleUniverse.getPreferredConfiguration();
canvas = new Canvas3D(config); add("Center", canvas); universe = new SimpleUniverse(canvas);
canvas.addKeyListener(this);
BranchGroup scene = createSceneGraph(); universe.getViewingPlatform().setNominalViewingTransform();
universe.getViewer().getView().setBackClipDistance(100.0); universe.addBranchGraph(scene); }
private BranchGroup createSceneGraph() { BranchGroup objRoot = new BranchGroup();
BoundingSphere bounds = new BoundingSphere(new Point3d(), 10000.0);
viewtrans = universe.getViewingPlatform().getViewPlatformTransform();
keyNavBeh = new KeyNavigatorBehavior(viewtrans); keyNavBeh.setSchedulingBounds(bounds); PlatformGeometry platformGeom = new PlatformGeometry(); platformGeom.addChild(keyNavBeh); universe.getViewingPlatform().setPlatformGeometry(platformGeom);
TextureLoader bgTexture = new TextureLoader("model/clouds-4215608_1920_s.jpg", this);
Background bg = new Background(bgTexture.getImage()); bg.setApplicationBounds(bounds);
objRoot.addChild(bg);
objRoot.addChild(createPenguin1()); objRoot.addChild(createGround());
return objRoot; }
private BranchGroup createPenguin1() {
BranchGroup objRoot = new BranchGroup();
tg = new TransformGroup(); t3d = new Transform3D();
tg.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
t3d.setTranslation(new Vector3d(0.0, -0.4, -3.0)); t3d.setRotation(new AxisAngle4f(0.0f, 0.0f, 0.0f, 0.0f)); t3d.setScale(0.9);
tg.setTransform(t3d);
TransformGroup tg_j = new TransformGroup(); tg_j.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
alpha = new Alpha(1, Alpha.INCREASING_ENABLE | Alpha.DECREASING_ENABLE, 0, 0, 300, 300, 0, 300, 300, 0);
Transform3D axis = new Transform3D(); axis.setRotation(new AxisAngle4f(0.0f, 0.0f, 1.0f, 1.57f));
PositionInterpolator posit = new PositionInterpolator(alpha, tg_j, axis, 0.0f, 0.6f);
BoundingSphere bounds = new BoundingSphere(new Point3d(0.0, 0.0, 0.0), 10000.0); posit.setSchedulingBounds(bounds);
tg_j.addChild(posit); tg_j.addChild(createPenguin2());
tg.addChild(tg_j);
tg_2 = new TransformGroup(); t3d_2 = new Transform3D(); tg_2.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
TransformGroup tg_sh = new TransformGroup(); //Transform3D t3d_sh = new Transform3D(); //Corrected tg_sh.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
Transform3D axis2 = new Transform3D();
PositionInterpolator posit2 = new PositionInterpolator(alpha, tg_sh, axis2, 0.0f, 0.6f); posit2.setSchedulingBounds(bounds);
tg_sh.addChild(posit2); tg_sh.addChild(createPenguinShadow()); tg_2.addChild(tg_sh); tg.addChild(tg_2);
t3d_2.setTranslation(new Vector3d(0.0, -1.0, 0.0)); t3d_2.setScale(2.7); tg_2.setTransform(t3d_2);
objRoot.addChild(tg); objRoot.addChild(createAmbientLight());
objRoot.compile();
return objRoot;
}
private BranchGroup createPenguin2() {
BranchGroup objRoot = new BranchGroup();
selector.setCapability(Switch.ALLOW_SWITCH_WRITE);
flag_i.clear(); flag_i.set(1); selector.setChildMask(flag_i);
selector.addChild(createObjLoad("model/Mesh_Penguin_wings_2_.obj")); selector.addChild(createObjLoad("model/Mesh_Penguin_wings_-2_.obj"));
objRoot.addChild(selector);
objRoot.compile();
return objRoot;
}
private BranchGroup createPenguinShadow() {
BranchGroup objRoot = new BranchGroup();
selector_2.setCapability(Switch.ALLOW_SWITCH_WRITE);
for (int i = 0; i < 8; i++) { selector_2.addChild(createOrientedShape3D(1.0f, "model/penguin_shadow" + i + ".png")); }
System.out.println("count_2_initially: " + count_2 % 8);
flag_i_2.clear(); flag_i_2.set(count_2 % 8); selector_2.setChildMask(flag_i_2);
objRoot.addChild(selector_2);
objRoot.compile();
return objRoot;
}
public BranchGroup createOrientedShape3D(float size, String filename) {
BranchGroup root = new BranchGroup(); TransformGroup tg = new TransformGroup(); tg.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
Appearance ap = new Appearance();
TransparencyAttributes attr = new TransparencyAttributes(TransparencyAttributes.BLENDED, 1.0f); ap.setTransparencyAttributes(attr);
TextureLoader loader = new TextureLoader(filename, this); ap.setTexture(loader.getTexture());
QuadArray plane = new QuadArray(4, GeometryArray.COORDINATES | GeometryArray.TEXTURE_COORDINATE_2);
Point3f[] p = new Point3f[4];
p[0] = new Point3f(size, 0.0f, size); p[1] = new Point3f(size, 0.0f, -size); p[2] = new Point3f(-size, 0.0f, -size); p[3] = new Point3f(-size, 0.0f, size); plane.setCoordinates(0, p);
TexCoord2f[] q = new TexCoord2f[4]; q[0] = new TexCoord2f(1.0f, 1.0f); q[1] = new TexCoord2f(0.0f, 1.0f); q[2] = new TexCoord2f(0.0f, 0.0f); q[3] = new TexCoord2f(1.0f, 0.0f); plane.setTextureCoordinates(0, 0, q);
OrientedShape3D oriShape = new OrientedShape3D(plane, ap, 0, new Point3f(0.0f, 0.0f, 0.0f));
Transform3D t3d = new Transform3D(); t3d.setScale(1.0);
tg.setTransform(t3d);
tg.addChild(oriShape);
root.addChild(tg);
root.compile();
return root; }
private BranchGroup createGround() {
BranchGroup objRoot = new BranchGroup();
TransformGroup tg = new TransformGroup(); Transform3D t3d = new Transform3D();
t3d.setTranslation(new Vector3d(0.0, -1.31, -0.0)); t3d.setScale(50.0); tg.setTransform(t3d);
tg.addChild(createObjLoad("model/textured_ground.obj"));
objRoot.addChild(tg); objRoot.compile();
return objRoot;
}
private BranchGroup createObjLoad(String filename) {
BranchGroup objRoot = new BranchGroup();
TransformGroup tg = new TransformGroup(); Transform3D t3d = new Transform3D(); t3d.setScale(1.0); tg.setTransform(t3d);
ObjectFile loader = new ObjectFile(ObjectFile.RESIZE); Scene s = null;
File file = new java.io.File(filename);
try { s = loader.load(file.toURI().toURL()); } catch (Exception e) { System.err.println(e); System.exit(1); }
tg.addChild(s.getSceneGroup());
objRoot.addChild(tg);
objRoot.compile();
return objRoot;
}
private Light createAmbientLight() { AmbientLight light = new AmbientLight(new Color3f(0.1f, 0.1f, 0.1f));
light.setInfluencingBounds(new BoundingSphere(new Point3d(), 100.0));
return light; }
public static void main(String args[]) {
Mykeynavbeh window = new Mykeynavbeh();
window.setSize(800, 600);
window.addWindowListener(new WindowAdapter() { public void windowClosing(WindowEvent e) { System.exit(0); } });
window.setVisible(true); }
public void keyTyped(KeyEvent e) { char key = e.getKeyChar();
if (key == 'd') { flag_i.clear(); flag_i.set(count % 2); selector.setChildMask(flag_i);
t3dstep.set(new Vector3d(0.0, 0.0, 0.1)); tg.getTransform(t3d); t3d.mul(t3dstep); tg.setTransform(t3d);
count++; }
if (key == 's') {
flag_i.clear(); flag_i.set(count % 2); selector.setChildMask(flag_i);
count_2++; flag_i_2.clear(); flag_i_2.set(count_2 % 8); selector_2.setChildMask(flag_i_2);
System.out.println("count_2 % 8_'s': " + count_2 % 8);
t3dstep.rotY(Math.PI / 4); tg.getTransform(t3d); t3d.get(matrix); t3d.setTranslation(new Vector3d(0.0, 0.0, 0.0)); t3d.mul(t3dstep); t3d.setTranslation(new Vector3d(matrix.m03, matrix.m13, matrix.m23)); tg.setTransform(t3d);
t3dstep.rotY(-Math.PI / 4); tg_2.getTransform(t3d_2); t3d_2.get(matrix); t3d_2.setTranslation(new Vector3d(0.0, 0.0, 0.0)); t3d_2.mul(t3dstep); t3d_2.setTranslation(new Vector3d(matrix.m03, matrix.m13, matrix.m23)); tg_2.setTransform(t3d_2);
count++;
}
if (key == 'f') {
flag_i.clear(); flag_i.set(count % 2); selector.setChildMask(flag_i);
count_2--; if (count_2 < 0) { count_2 = count_2 + 8; } flag_i_2.clear(); flag_i_2.set(count_2 % 8); selector_2.setChildMask(flag_i_2);
System.out.println("count_2 % 8'f': " + count_2 % 8);
t3dstep.rotY(-Math.PI / 4); tg.getTransform(t3d); t3d.get(matrix); t3d.setTranslation(new Vector3d(0.0, 0.0, 0.0)); t3d.mul(t3dstep); t3d.setTranslation(new Vector3d(matrix.m03, matrix.m13, matrix.m23)); tg.setTransform(t3d);
t3dstep.rotY(Math.PI / 4); tg_2.getTransform(t3d_2); t3d_2.get(matrix); t3d_2.setTranslation(new Vector3d(0.0, 0.0, 0.0)); t3d_2.mul(t3dstep); t3d_2.setTranslation(new Vector3d(matrix.m03, matrix.m13, matrix.m23)); tg_2.setTransform(t3d_2);
count++;
}
if (key == 'x') { flag_i.clear(); flag_i.set(1); selector.setChildMask(flag_i); }
}
public void keyReleased(KeyEvent e) { keyNavBeh.setEnable(true); }
public void keyPressed(KeyEvent e) {
switch (e.getKeyCode()) { case KeyEvent.VK_RIGHT: keyNavBeh.setEnable(false); break;
case KeyEvent.VK_LEFT: keyNavBeh.setEnable(false); break;
case KeyEvent.VK_KP_RIGHT: keyNavBeh.setEnable(false); break;
case KeyEvent.VK_KP_LEFT: keyNavBeh.setEnable(false); break;
}
char key = e.getKeyChar();
if (key == 'j') { alpha.setStartTime(System.currentTimeMillis()); } }
}