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

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

?? vr.txt

?? 關(guān)于java3D結(jié)合vrml文件開發(fā)虛擬現(xiàn)實的例子及源碼.
?? TXT
?? 第 1 頁 / 共 2 頁
字號:
/**********************************************************
http://www.java2s.com/Code/Java/3D/LoadingaVRMLfile.htm


 Copyright (C) 2001   Daniel Selman

 First distributed with the book "Java 3D Programming"
 by Daniel Selman and published by Manning Publications.
 http://manning.com/selman

 This program is free software; you can redistribute it and/or
 modify it under the terms of the GNU General Public License
 as published by the Free Software Foundation, version 2.

 This program is distributed in the hope that it will be useful,
 but WITHOUT ANY WARRANTY; without even the implied warranty of
 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 GNU General Public License for more details.

 The license can be found on the WWW at:
 http://www.fsf.org/copyleft/gpl.html

 Or by writing to:
 Free Software Foundation, Inc.,
 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.

 Authors can be contacted at:
 Daniel Selman: daniel@selman.org

 If you make changes you think others would like, please 
 contact one of the authors or someone at the 
 www.j3d.org web site.
 **************************************************************/

import java.applet.Applet;
import java.awt.BorderLayout;
import java.awt.Cursor;
import java.awt.GraphicsConfigTemplate;
import java.awt.GraphicsDevice;
import java.awt.GraphicsEnvironment;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.io.File;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.Hashtable;

import javax.media.j3d.AmbientLight;
import javax.media.j3d.AudioDevice;
import javax.media.j3d.Background;
import javax.media.j3d.BoundingSphere;
import javax.media.j3d.Bounds;
import javax.media.j3d.BranchGroup;
import javax.media.j3d.Canvas3D;
import javax.media.j3d.DirectionalLight;
import javax.media.j3d.GraphicsConfigTemplate3D;
import javax.media.j3d.Group;
import javax.media.j3d.Locale;
import javax.media.j3d.Morph;
import javax.media.j3d.Node;
import javax.media.j3d.PhysicalBody;
import javax.media.j3d.PhysicalEnvironment;
import javax.media.j3d.SceneGraphObject;
import javax.media.j3d.Shape3D;
import javax.media.j3d.Transform3D;
import javax.media.j3d.TransformGroup;
import javax.media.j3d.View;
import javax.media.j3d.ViewPlatform;
import javax.media.j3d.VirtualUniverse;
import javax.vecmath.Color3f;
import javax.vecmath.Point3d;
import javax.vecmath.Vector3d;

import com.sun.j3d.audioengines.javasound.JavaSoundMixer;
import com.sun.j3d.loaders.Scene;
import com.sun.j3d.loaders.vrml97.VrmlLoader;
import com.sun.j3d.utils.applet.MainFrame;
import com.sun.j3d.utils.behaviors.mouse.MouseRotate;
import com.sun.j3d.utils.behaviors.mouse.MouseTranslate;
import com.sun.j3d.utils.behaviors.mouse.MouseZoom;
import com.sun.j3d.utils.picking.PickCanvas;
import com.sun.j3d.utils.picking.PickResult;
import com.sun.j3d.utils.picking.PickTool;

/**
 * This example loads a VRML file, automatically computes the view point to view
 * the objects in the file, and then mouse picks. For each pick all the selected
 * components of the scene are reported (by their VRML name). The VRML scene can
 * be rotates, scaled and translated using the mouse.
 */
public class VrmlPickingTest extends Java3dApplet implements MouseListener {
  PickCanvas pickCanvas = null;

  public VrmlPickingTest() {
  }

  public VrmlPickingTest(String[] args) {
    saveCommandLineArguments(args);
    initJava3d();
  }

  public void start() {
    if (pickCanvas == null)
      initJava3d();
  }

  protected void addCanvas3D(Canvas3D c3d) {
    setLayout(new BorderLayout());
    add(c3d, BorderLayout.CENTER);
    doLayout();

    if (m_SceneBranchGroup != null) {
      c3d.addMouseListener(this);

      pickCanvas = new PickCanvas(c3d, m_SceneBranchGroup);
      pickCanvas.setMode(PickTool.GEOMETRY_INTERSECT_INFO);
      pickCanvas.setTolerance(4.0f);
    }

    c3d.setCursor(new Cursor(Cursor.HAND_CURSOR));
  }

  public TransformGroup[] getViewTransformGroupArray() {
    TransformGroup[] tgArray = new TransformGroup[1];
    tgArray[0] = new TransformGroup();

    Transform3D viewTrans = new Transform3D();
    Transform3D eyeTrans = new Transform3D();

    BoundingSphere sceneBounds = (BoundingSphere) m_SceneBranchGroup
        .getBounds();

    // point the view at the center of the object
    Point3d center = new Point3d();
    sceneBounds.getCenter(center);
    double radius = sceneBounds.getRadius();
    Vector3d temp = new Vector3d(center);
    viewTrans.set(temp);

    // pull the eye back far enough to see the whole object
    double eyeDist = 1.4 * radius / Math.tan(Math.toRadians(40) / 2.0);
    temp.x = 0.0;
    temp.y = 0.0;
    temp.z = eyeDist;
    eyeTrans.set(temp);
    viewTrans.mul(eyeTrans);

    // set the view transform
    tgArray[0].setTransform(viewTrans);

    return tgArray;
  }

  protected BranchGroup createSceneBranchGroup() {
    BranchGroup objRoot = super.createSceneBranchGroup();

    Bounds lightBounds = getApplicationBounds();

    AmbientLight ambLight = new AmbientLight(true, new Color3f(1.0f, 1.0f,
        1.0f));
    ambLight.setInfluencingBounds(lightBounds);
    objRoot.addChild(ambLight);

    DirectionalLight headLight = new DirectionalLight();
    headLight.setInfluencingBounds(lightBounds);
    objRoot.addChild(headLight);

    TransformGroup mouseGroup = createMouseBehaviorsGroup();

    String vrmlFile = null;

    try {
      URL codebase = getWorkingDirectory();
      vrmlFile = codebase.toExternalForm() + "BoxConeSphere.wrl";
    } catch (Exception e) {
      e.printStackTrace();
    }

    if (m_szCommandLineArray != null) {
      switch (m_szCommandLineArray.length) {
      case 0:
        break;

      case 1:
        vrmlFile = m_szCommandLineArray[0];
        break;

      default:
        System.err.println("Usage: VrmlPickingTest [pathname|URL]");
        System.exit(-1);
      }
    }

    BranchGroup sceneRoot = loadVrmlFile(vrmlFile);

    if (sceneRoot != null)
      mouseGroup.addChild(sceneRoot);

    objRoot.addChild(mouseGroup);

    return objRoot;
  }

  private TransformGroup createMouseBehaviorsGroup() {
    TransformGroup examineGroup = new TransformGroup();
    examineGroup.setCapability(TransformGroup.ALLOW_TRANSFORM_READ);
    examineGroup.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);

    Bounds behaviorBounds = getApplicationBounds();

    MouseRotate mr = new MouseRotate(examineGroup);
    mr.setSchedulingBounds(behaviorBounds);
    examineGroup.addChild(mr);

    MouseTranslate mt = new MouseTranslate(examineGroup);
    mt.setSchedulingBounds(behaviorBounds);
    examineGroup.addChild(mt);

    MouseZoom mz = new MouseZoom(examineGroup);
    mz.setSchedulingBounds(behaviorBounds);
    examineGroup.addChild(mz);

    return examineGroup;
  }

  private BranchGroup loadVrmlFile(String location) {
    BranchGroup sceneGroup = null;
    Scene scene = null;

    VrmlLoader loader = new VrmlLoader();

    try {
      URL loadUrl = new URL(location);
      try {
        // load the scene
        scene = loader.load(new URL(location));
      } catch (Exception e) {
        System.out.println("Exception loading URL:" + e);
        e.printStackTrace();
      }
    } catch (MalformedURLException badUrl) {
      // location may be a path name
      try {
        // load the scene
        scene = loader.load(location);
      } catch (Exception e) {
        System.out.println("Exception loading file from path:" + e);
        e.printStackTrace();
      }
    }

    if (scene != null) {
      // get the scene group
      sceneGroup = scene.getSceneGroup();

      sceneGroup.setCapability(BranchGroup.ALLOW_BOUNDS_READ);
      sceneGroup.setCapability(BranchGroup.ALLOW_CHILDREN_READ);

      Hashtable namedObjects = scene.getNamedObjects();
      System.out.println("*** Named Objects in VRML file: \n"
          + namedObjects);

      // recursively set the user data here
      // so we can find our objects when they are picked
      java.util.Enumeration enumValues = namedObjects.elements();
      java.util.Enumeration enumKeys = namedObjects.keys();

      if (enumValues != null) {
        while (enumValues.hasMoreElements() != false) {
          Object value = enumValues.nextElement();
          Object key = enumKeys.nextElement();

          recursiveSetUserData(value, key);
        }
      }
    }

    return sceneGroup;
  }

  // method to recursively set the user data for objects in the scenegraph
  // tree
  // we also set the capabilites on Shape3D and Morph objects required by the
  // PickTool
  void recursiveSetUserData(Object value, Object key) {
    if (value instanceof SceneGraphObject != false) {
      // set the user data for the item
      SceneGraphObject sg = (SceneGraphObject) value;
      sg.setUserData(key);

      // recursively process group
      if (sg instanceof Group) {
        Group g = (Group) sg;

        // recurse on child nodes
        java.util.Enumeration enumKids = g.getAllChildren();

        while (enumKids.hasMoreElements() != false)
          recursiveSetUserData(enumKids.nextElement(), key);
      } else if (sg instanceof Shape3D || sg instanceof Morph) {
        PickTool.setCapabilities((Node) sg, PickTool.INTERSECT_FULL);
      }
    }
  }

  // rewritten to check for user data
  public void mouseClicked(MouseEvent e) {
    System.out.println("*** MouseClick ***");

    pickCanvas.setShapeLocation(e);
    PickResult[] results = pickCanvas.pickAllSorted();

    if (results != null) {
      for (int n = 0; n < results.length; n++) {
        PickResult pickResult = results[n];

        System.out
            .println("Sorted PickResult " + n + ": " + pickResult);

        Node actualNode = pickResult.getObject();

        if (actualNode.getUserData() != null) {
          System.out.println("Sorted Object " + n + ": "
              + actualNode.getUserData());
        }
      }
    }

    PickResult pickResult = pickCanvas.pickClosest();

    if (pickResult != null) {
      System.out.println("Closest PickResult: " + pickResult);

      Node actualNode = pickResult.getObject();

      if (actualNode.getUserData() != null) {
        System.out.println("Closest Object: "
            + actualNode.getUserData());
      }
    }

  }

  public void mouseEntered(MouseEvent e) {
  }

  public void mouseExited(MouseEvent e) {
  }

  public void mousePressed(MouseEvent e) {
  }

  public void mouseReleased(MouseEvent e) {
  }

  public static void main(String[] args) {
    System.out.println("Current user.dir: "
        + System.getProperty("user.dir"));

    VrmlPickingTest pickingTest = new VrmlPickingTest(args);

    new MainFrame(pickingTest, 400, 400);
  }
}

/*******************************************************************************
 * Copyright (C) 2001 Daniel Selman
 * 
 * First distributed with the book "Java 3D Programming" by Daniel Selman and
 * published by Manning Publications. http://manning.com/selman
 * 
 * This program is free software; you can redistribute it and/or modify it under
 * the terms of the GNU General Public License as published by the Free Software
 * Foundation, version 2.
 * 
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
 * details.
 * 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲1区2区3区4区| 一区二区三区在线免费观看| 激情综合网天天干| 欧美v国产在线一区二区三区| 精品一区二区久久久| 国产日韩欧美a| 一本久久精品一区二区| 亚洲bt欧美bt精品| 欧美成人福利视频| 春色校园综合激情亚洲| 一区二区三区鲁丝不卡| 欧美日韩精品专区| 国内成人免费视频| 亚洲柠檬福利资源导航| 欧美一区二区三区人| 精品写真视频在线观看| 中文字幕欧美一区| 91精品国产手机| 成人性生交大片免费看视频在线| 一区二区三区欧美日| 欧美一区永久视频免费观看| 成人三级在线视频| 石原莉奈在线亚洲三区| 久久久99久久| 欧美日韩一区二区三区视频| 国产在线乱码一区二区三区| 亚洲激情校园春色| 久久久99精品免费观看不卡| 在线观看av一区二区| 国产麻豆欧美日韩一区| 亚洲国产毛片aaaaa无费看| xfplay精品久久| 欧美在线一二三| 国产精品原创巨作av| 亚洲丶国产丶欧美一区二区三区| 精品国产一区二区三区av性色| 色哟哟一区二区| 国产一区二区三区免费看| 一区二区三区四区高清精品免费观看| 精品国产伦一区二区三区观看方式| 日本高清视频一区二区| 国产麻豆精品视频| 日韩专区欧美专区| 亚洲色图在线播放| 久久久久亚洲综合| 91麻豆精品国产自产在线| 婷婷开心久久网| 亚洲人快播电影网| 国产精品美日韩| 久久久久久久av麻豆果冻| 91精品久久久久久久91蜜桃| 在线观看免费亚洲| 色婷婷av一区| av在线播放不卡| 大尺度一区二区| 国产九九视频一区二区三区| 久久99精品国产麻豆婷婷洗澡| 亚洲第一激情av| 亚洲一区二区三区自拍| 亚洲色图视频网站| 国产精品久线在线观看| 国产欧美一区二区精品性色 | 日产精品久久久久久久性色| 综合自拍亚洲综合图不卡区| 久久久亚洲精华液精华液精华液| 欧美成人一区二区三区在线观看| 欧美日韩国产首页| 欧美日韩国产另类一区| 欧美三级三级三级爽爽爽| 欧美亚洲国产怡红院影院| 99精品国产91久久久久久| www.性欧美| 色婷婷综合在线| 在线一区二区三区做爰视频网站| 99久久精品费精品国产一区二区| 成人午夜视频网站| av成人老司机| 欧美在线看片a免费观看| 色婷婷综合久久久中文字幕| 日本精品免费观看高清观看| 日本精品一区二区三区高清| 欧美在线啊v一区| 欧美亚洲一区二区在线观看| 欧美日韩中文字幕一区二区| 在线播放/欧美激情| 日韩三级在线免费观看| 精品捆绑美女sm三区| 精品美女在线观看| 国产亚洲一区二区三区四区| 欧美国产成人在线| 一区二区不卡在线视频 午夜欧美不卡在| 亚洲视频一二区| 首页国产欧美久久| 精品一区二区在线视频| 国产成人免费av在线| 99这里只有久久精品视频| 91免费看片在线观看| 欧美日韩视频在线观看一区二区三区 | 欧美三片在线视频观看| 欧美精品1区2区3区| 欧美精品一区二区三区蜜臀| 国产精品高清亚洲| 亚洲bt欧美bt精品| 国产成人精品亚洲777人妖| 91麻豆精品在线观看| 欧美日韩在线直播| 久久精品亚洲精品国产欧美kt∨| 国产精品国产三级国产a| 亚洲成人精品在线观看| 国产在线播放一区| 在线影院国内精品| 久久久久久久久久久久久夜| 亚洲免费看黄网站| 伦理电影国产精品| 色老头久久综合| 久久奇米777| 亚洲已满18点击进入久久| 国产一区二区三区黄视频 | 亚洲综合视频网| 国产一区二区日韩精品| 在线中文字幕一区| 国产日产欧美精品一区二区三区| 亚洲午夜免费视频| 国产69精品一区二区亚洲孕妇| 欧美精品久久一区二区三区| 国产日韩av一区| 免费在线看一区| 日本韩国欧美一区二区三区| 久久一区二区三区四区| 午夜影院久久久| av亚洲精华国产精华| 日韩欧美国产综合| 亚洲资源在线观看| 成人美女视频在线看| 欧美一区二区国产| 一区二区三区四区在线播放 | 免费一区二区视频| 91高清视频免费看| 中文字幕免费不卡| 日本亚洲三级在线| 欧美日韩精品高清| 一区二区三区久久久| 99久久精品99国产精品 | 日韩一区在线免费观看| 国产一区二区免费在线| 日韩亚洲欧美一区| 午夜久久久影院| 91捆绑美女网站| 国产精品白丝在线| 国产成人av福利| 精品动漫一区二区三区在线观看| 亚洲大片免费看| 欧美无砖专区一中文字| 亚洲资源中文字幕| 91久久精品一区二区三| 亚洲欧美日韩一区| 91在线看国产| 亚洲少妇屁股交4| 9i在线看片成人免费| 国产精品素人视频| 成人激情综合网站| 中文字幕一区二区三区精华液 | 久久久久国产精品厨房| 日韩电影一区二区三区四区| 欧美日韩免费观看一区二区三区| 一区二区视频免费在线观看| 99精品国产91久久久久久| 亚洲日本中文字幕区| 不卡的电影网站| 亚洲欧洲色图综合| 91黄色小视频| 亚洲国产精品一区二区尤物区| 色呦呦一区二区三区| 亚洲一区二区三区在线播放| 欧美三级电影一区| 蜜桃久久久久久久| 欧美精品一区二区三区蜜臀| 国产成人精品亚洲日本在线桃色| 亚洲国产成人午夜在线一区| 本田岬高潮一区二区三区| 亚洲欧洲日产国码二区| 在线免费观看视频一区| 日韩精品电影一区亚洲| 日韩精品自拍偷拍| 丰满少妇在线播放bd日韩电影| 中文字幕av资源一区| 色伊人久久综合中文字幕| 亚洲午夜电影在线观看| 日韩精品一区二区三区四区| 国产精品亚洲成人| 亚洲免费观看高清完整版在线观看熊 | 中文字幕乱码日本亚洲一区二区 | 欧美一区二区在线观看| 久久99精品视频| 中文字幕一区av| 欧美久久久久中文字幕| 国产精品一区在线观看乱码| 国产精品久久夜| 欧美一区二视频| 岛国一区二区在线观看|