package ConformanceNist.Sensors.ProximitySensor;
/*
Copyright (c) 1995-2023 held by the author(s). 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.
* Redistributions in binary form must reproduce 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 the Web3D Consortium (https://www.web3d.org)
nor the names of its contributors may be used to endorse or
promote products derived from this software without specific
prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.
*/
import org.web3d.x3d.jsail.Core.*;
import org.web3d.x3d.jsail.EnvironmentalSensor.*;
import org.web3d.x3d.jsail.fields.*;
import org.web3d.x3d.jsail.Geometry3D.*;
import org.web3d.x3d.jsail.Grouping.*;
import org.web3d.x3d.jsail.Lighting.*;
import org.web3d.x3d.jsail.Navigation.*;
import org.web3d.x3d.jsail.Rendering.*;
import org.web3d.x3d.jsail.Shape.*;
// Javadoc metadata annotations follow, see below for X3DJSAIL Java source code.
/**
*
A ProximitySensor bounding box of size 10 by 10 by 10 surrounds a Sphere geometry. An avatar shaped like a pointing device receives both the position_changed and orientation_changed events generated by the ProximitySensor when the users pointing device enters its bounding box. The result is: when the user sequentially moves through the Viewpoint stack, the avatar will follow the cursor in both position (X, Y and Z) as well as orientation. When the viewer enters the bounding box, the avatar should always appear as a symmetric diamond with both a horizontal and vertical axis. Regardless of the avatar position inside the ProximitySensor bounding box, the avatar should always appear the same size and have the same orientation, stay positioned at the center of the viewing screen. When viewed from outside the bounding box, the avatar should appear at the perimeter of the bounding box, at its last exit point. The small end portion of the avatar should always intersect the perimeter of the bounding box when viewed from outside the bounding box.
Related links: orientation_changed.java source, orientation_changed catalog page, X3D Resources, X3D Scene Authoring Hints, and X3D Tooltips.
Scene Meta Information
meta tags |
Document Metadata |
title |
orientation_changed.x3d |
MovingImage |
orientation_changed-movie.mpg |
reference |
http://www.nist.gov/vrml.html |
reference |
http://www.itl.nist.gov/div897/ctg/vrml/vrml.html |
creator |
http://www.itl.nist.gov/div897/ctg/vrml/members.html |
disclaimer |
This file was provided by the National Institute of Standards and Technology, and is part of the X3D Conformance Test Suite, available at http://www.nist.gov/vrml.html The information contained within this file is provided for use in establishing conformance to the ISO VRML97 Specification. Conformance to this test does not imply recommendation or endorsement by the National Institute of Standards and Technology (NIST). This software can be redistributed and/or modified freely provided that any derivative works bear some notice that they are derived from it, and any modified versions bear some notice that they have been modified. |
reference |
Interactive Conformance Testing for VRML, Mary Brady and Lynn Rosenthal, NIST, created 8 September 2010 and updated 25 August 2016, https://www.nist.gov/itl/ssd/information-systems-group/interactive-conformance-testing-vrml |
info |
Correct definition and compliance of this conformance scene is maintained by the X3D Working Group, https://www.web3d.org/working-groups/x3d |
translator |
Michael Kass NIST, Don Brutzman NPS |
translated |
21 January 2001 |
modified |
28 August 2023 |
description |
A ProximitySensor bounding box of size 10 by 10 by 10 surrounds a Sphere geometry. An avatar shaped like a pointing device receives both the position_changed and orientation_changed events generated by the ProximitySensor when the users pointing device enters its bounding box. The result is: when the user sequentially moves through the Viewpoint stack, the avatar will follow the cursor in both position (X, Y and Z) as well as orientation. When the viewer enters the bounding box, the avatar should always appear as a symmetric diamond with both a horizontal and vertical axis. Regardless of the avatar position inside the ProximitySensor bounding box, the avatar should always appear the same size and have the same orientation, stay positioned at the center of the viewing screen. When viewed from outside the bounding box, the avatar should appear at the perimeter of the bounding box, at its last exit point. The small end portion of the avatar should always intersect the perimeter of the bounding box when viewed from outside the bounding box. |
identifier |
https://www.web3d.org/x3d/content/examples/ConformanceNist/Sensors/ProximitySensor/orientation_changed.x3d |
generator |
Vrml97ToX3dNist, http://ovrt.nist.gov/v2_x3d.html |
generator |
X3D-Edit 4.0, https://savage.nps.edu/X3D-Edit |
license |
../../license.html |
|
This program uses the
X3D Java Scene Access Interface Library (X3DJSAIL).
It has been produced using the
X3dToJava.xslt
stylesheet
(version control)
is used to create Java source code from an original .x3d
model.
* @author http://www.itl.nist.gov/div897/ctg/vrml/members.html
*/
public class orientation_changed
{
/** Default constructor to create this object. */
public orientation_changed ()
{
initialize();
}
/** Create and initialize the X3D model for this object. */
public final void initialize()
{
try { // catch-all
x3dModel = new X3D().setProfile(X3D.PROFILE_INTERACTIVE).setVersion(X3D.VERSION_3_0)
.setHead(new head()
.addMeta(new meta().setName(meta.NAME_TITLE ).setContent("orientation_changed.x3d"))
.addMeta(new meta().setName(meta.NAME_MOVINGIMAGE).setContent("orientation_changed-movie.mpg"))
.addMeta(new meta().setName(meta.NAME_REFERENCE ).setContent("http://www.nist.gov/vrml.html"))
.addMeta(new meta().setName(meta.NAME_REFERENCE ).setContent("http://www.itl.nist.gov/div897/ctg/vrml/vrml.html"))
.addMeta(new meta().setName(meta.NAME_CREATOR ).setContent("http://www.itl.nist.gov/div897/ctg/vrml/members.html"))
.addMeta(new meta().setName("disclaimer").setContent("This file was provided by the National Institute of Standards and Technology, and is part of the X3D Conformance Test Suite, available at http://www.nist.gov/vrml.html The information contained within this file is provided for use in establishing conformance to the ISO VRML97 Specification. Conformance to this test does not imply recommendation or endorsement by the National Institute of Standards and Technology (NIST). This software can be redistributed and/or modified freely provided that any derivative works bear some notice that they are derived from it, and any modified versions bear some notice that they have been modified."))
.addMeta(new meta().setName(meta.NAME_REFERENCE ).setContent("Interactive Conformance Testing for VRML, Mary Brady and Lynn Rosenthal, NIST, created 8 September 2010 and updated 25 August 2016, https://www.nist.gov/itl/ssd/information-systems-group/interactive-conformance-testing-vrml"))
.addMeta(new meta().setName(meta.NAME_INFO ).setContent("Correct definition and compliance of this conformance scene is maintained by the X3D Working Group, https://www.web3d.org/working-groups/x3d"))
.addMeta(new meta().setName(meta.NAME_TRANSLATOR ).setContent("Michael Kass NIST, Don Brutzman NPS"))
.addMeta(new meta().setName(meta.NAME_TRANSLATED ).setContent("21 January 2001"))
.addMeta(new meta().setName(meta.NAME_MODIFIED ).setContent("28 August 2023"))
.addMeta(new meta().setName(meta.NAME_DESCRIPTION).setContent("A ProximitySensor bounding box of size 10 by 10 by 10 surrounds a Sphere geometry. An avatar shaped like a pointing device receives both the position_changed and orientation_changed events generated by the ProximitySensor when the users pointing device enters its bounding box. The result is: when the user sequentially moves through the Viewpoint stack, the avatar will follow the cursor in both position (X, Y and Z) as well as orientation. When the viewer enters the bounding box, the avatar should always appear as a symmetric diamond with both a horizontal and vertical axis. Regardless of the avatar position inside the ProximitySensor bounding box, the avatar should always appear the same size and have the same orientation, stay positioned at the center of the viewing screen. When viewed from outside the bounding box, the avatar should appear at the perimeter of the bounding box, at its last exit point. The small end portion of the avatar should always intersect the perimeter of the bounding box when viewed from outside the bounding box."))
.addMeta(new meta().setName(meta.NAME_IDENTIFIER ).setContent("https://www.web3d.org/x3d/content/examples/ConformanceNist/Sensors/ProximitySensor/orientation_changed.x3d"))
.addMeta(new meta().setName(meta.NAME_GENERATOR ).setContent("Vrml97ToX3dNist, http://ovrt.nist.gov/v2_x3d.html"))
.addMeta(new meta().setName(meta.NAME_GENERATOR ).setContent("X3D-Edit 4.0, https://savage.nps.edu/X3D-Edit"))
.addMeta(new meta().setName(meta.NAME_LICENSE ).setContent("../../license.html")))
.setScene(new Scene()
.addChild(new WorldInfo().setTitle("orientation_changed.x3d"))
.addChild(new NavigationInfo().setType("\"EXAMINE\" \"WALK\" \"FLY\" \"ANY\""))
.addChild(new Viewpoint().setDescription("Outside (Front)").setPosition(0.0,0.0,12.0))
.addChild(new Viewpoint().setDescription("Inside Front").setPosition(0.0,0.0,3.0))
.addChild(new Viewpoint().setDescription("Outside (Front)").setPosition(0.0,0.0,12.0))
.addChild(new Viewpoint().setDescription("Outside (Right)").setOrientation(0.0,1.0,0.0,1.57).setPosition(12.0,0.0,0.0))
.addChild(new Viewpoint().setDescription("Inside Right").setOrientation(0.0,1.0,0.0,1.57).setPosition(3.0,0.0,0.0))
.addChild(new Viewpoint().setDescription("Outside (Right)").setOrientation(0.0,1.0,0.0,1.57).setPosition(12.0,0.0,0.0))
.addChild(new Viewpoint().setDescription("Outside (Bottom)").setOrientation(1.0,0.0,0.0,1.57).setPosition(0.0,-12.0,0.0))
.addChild(new Viewpoint().setDescription("Inside Bottom").setOrientation(1.0,0.0,0.0,1.57).setPosition(0.0,-3.0,0.0))
.addChild(new Viewpoint().setDescription("Outside (Bottom)").setOrientation(1.0,0.0,0.0,1.57).setPosition(0.0,-12.0,0.0))
.addChild(new Viewpoint().setDescription("Outside (Rear)").setOrientation(0.0,1.0,0.0,3.14).setPosition(0.0,0.0,-12.0))
.addChild(new Viewpoint().setDescription("Inside Rear").setOrientation(0.0,1.0,0.0,3.14).setPosition(0.0,0.0,-3.0))
.addChild(new Viewpoint().setDescription("Outside (Rear)").setOrientation(0.0,1.0,0.0,3.14).setPosition(0.0,0.0,-12.0))
.addChild(new Viewpoint().setDescription("Outside (Left)").setOrientation(0.0,1.0,0.0,-1.57).setPosition(-12.0,0.0,0.0))
.addChild(new Viewpoint().setDescription("Inside Left").setOrientation(0.0,1.0,0.0,-1.57).setPosition(-3.0,0.0,0.0))
.addChild(new Viewpoint().setDescription("Outside (Left)").setOrientation(0.0,1.0,0.0,-1.57).setPosition(-12.0,0.0,0.0))
.addChild(new Viewpoint().setDescription("Outside (Top)").setOrientation(1.0,0.0,0.0,-1.57).setPosition(0.0,10.0,0.0))
.addChild(new Viewpoint().setDescription("Inside Top").setOrientation(1.0,0.0,0.0,-1.57).setPosition(0.0,3.0,0.0))
.addChild(new Viewpoint().setDescription("Outside (Top)").setOrientation(1.0,0.0,0.0,-1.57).setPosition(0.0,12.0,0.0))
.addChild(new Transform()
.addChild(new Transform()
.addChild(new PointLight())
.addChild(new Shape()
.setAppearance(new Appearance()
.setMaterial(new Material().setDiffuseColor(1.0,1.0,1.0)))
.setGeometry(new Sphere())))
.addChild(new Transform().setTranslation(-1.0,-1.0,0.0)
.addChild(new PointLight()))
.addChild(new Transform().setTranslation(-1.0,1.0,0.0))
.addChild(new Transform().setTranslation(1.0,1.0,0.0)
.addChild(new PointLight()))
.addChild(new Transform().setTranslation(1.0,-1.0,0.0)
.addChild(new PointLight()))
.addChild(new Transform()
.addChild(new ProximitySensor("PROX_SENSOR").setSize(10.0,10.0,10.0))
.addChild(new Shape()
.setAppearance(new Appearance()
.setMaterial(new Material().setEmissiveColor(1.0,1.0,1.0)))
.setGeometry(new IndexedLineSet().setCoordIndex(new int[] {0,1,-1,1,2,-1,2,3,-1,3,0,-1,4,5,-1,5,6,-1,6,7,-1,7,4,-1,1,5,-1,2,6,-1,0,4,-1,7,3,-1})
.setCoord(new Coordinate().setPoint(new MFVec3f(new double[] {-5.0,-5.0,-5.0,5.0,-5.0,-5.0,5.0,5.0,-5.0,-5.0,5.0,-5.0,-5.0,-5.0,5.0,5.0,-5.0,5.0,5.0,5.0,5.0,-5.0,5.0,5.0})))))
.addChild(new Transform()
.addChild(new Transform("MYCONE")
.addChild(new Shape()
.setAppearance(new Appearance()
.setMaterial(new Material().setEmissiveColor(0.0,0.0,1.0)))
.setGeometry(new IndexedLineSet().setColorPerVertex(false).setCoordIndex(new int[] {0,3,-1,3,4,-1,3,2,-1,2,4,-1,2,1,-1,1,4,-1,1,0,-1,0,4,-1,3,0,-1,0,5,-1,2,3,-1,3,5,-1,1,2,-1,2,5,-1,0,1,-1,1,5,-1})
.setCoord(new Coordinate().setPoint(new MFVec3f(new double[] {-0.1,0.0,-1.0,0.0,-0.1,-1.0,0.1,0.0,-1.0,0.0,0.1,-1.0,0.0,0.0,-1.0,0.0,0.0,-0.2})))
.setColor(new Color().setColor(new MFColor(new double[] {0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0,0.0,0.0,1.0})))))))))
.addChild(new ROUTE().setFromNode("PROX_SENSOR").setFromField("orientation_changed").setToNode("MYCONE").setToField("set_rotation"))
.addChild(new ROUTE().setFromNode("PROX_SENSOR").setFromField("position_changed").setToNode("MYCONE").setToField("set_translation")));
}
catch (Exception ex)
{
System.err.println ("*** Further hints on X3DJSAIL errors and exceptions at");
System.err.println ("*** https://www.web3d.org/specifications/java/X3DJSAIL.html");
throw (ex);
}
}
// end of initialize() method
/** The initialized model object, created within initialize() method. */
private X3D x3dModel;
/**
* Provide a
* shallow copy
* of the X3D model.
* @see X3D
* @return orientation_changed model
*/
public X3D getX3dModel()
{
return x3dModel;
}
/**
* Default main() method provided for test purposes, uses CommandLine to set global ConfigurationProperties for this object.
* @param args array of input parameters, provided as arguments
* @see X3D.handleArguments(args)
* @see X3D.validationReport()
* @see CommandLine
* @see CommandLine.USAGE
* @see ConfigurationProperties
*/
public static void main(String args[])
{
System.out.println("Build this X3D model, showing validation diagnostics...");
X3D thisExampleX3dModel = new orientation_changed().getX3dModel();
// System.out.println("X3D model construction complete.");
// next handle command line arguments
boolean hasArguments = (args != null) && (args.length > 0);
boolean validate = true; // default
boolean argumentsLoadNewModel = false;
String fileName = new String();
if (args != null)
{
for (String arg : args)
{
if (arg.toLowerCase().startsWith("-v") || arg.toLowerCase().contains("validate"))
{
validate = true; // making sure
}
if (arg.toLowerCase().endsWith(X3D.FILE_EXTENSION_X3D) ||
arg.toLowerCase().endsWith(X3D.FILE_EXTENSION_CLASSICVRML) ||
arg.toLowerCase().endsWith(X3D.FILE_EXTENSION_X3DB) ||
arg.toLowerCase().endsWith(X3D.FILE_EXTENSION_VRML97) ||
arg.toLowerCase().endsWith(X3D.FILE_EXTENSION_EXI) ||
arg.toLowerCase().endsWith(X3D.FILE_EXTENSION_GZIP) ||
arg.toLowerCase().endsWith(X3D.FILE_EXTENSION_ZIP) ||
arg.toLowerCase().endsWith(X3D.FILE_EXTENSION_HTML) ||
arg.toLowerCase().endsWith(X3D.FILE_EXTENSION_XHTML))
{
argumentsLoadNewModel = true;
fileName = arg;
}
}
}
if (argumentsLoadNewModel)
System.out.println("WARNING: \"ConformanceNist.Sensors.ProximitySensor.orientation_changed\" model invocation is attempting to load file \"" + fileName + "\" instead of simply validating itself... file loading ignored.");
else if (hasArguments) // if no arguments provided, this method produces usage warning
thisExampleX3dModel.handleArguments(args);
if (validate)
{
// System.out.println("--- TODO fix duplicated outputs ---"); // omit when duplicated outputs problem is solved/refactored
String validationResults = thisExampleX3dModel.validationReport();
// System.out.println("-----------------------------------"); // omit when duplicated outputs problem is solved/refactored
System.out.print("ConformanceNist.Sensors.ProximitySensor.orientation_changed self-validation test results: ");
if (!validationResults.equals("success"))
System.out.println();
System.out.println(validationResults.trim());
}
}
}