package Savage.Weapons.Torpedoes;

import org.web3d.x3d.jsail.Core.*;
import org.web3d.x3d.jsail.fields.*;
import org.web3d.x3d.jsail.Geometry3D.*;
import org.web3d.x3d.jsail.Grouping.*;
import org.web3d.x3d.jsail.Interpolation.*;
import org.web3d.x3d.jsail.Navigation.*;
import org.web3d.x3d.jsail.Networking.*;
import org.web3d.x3d.jsail.Shape.*;
import org.web3d.x3d.jsail.Time.*;

// Javadoc metadata annotations follow, see below for X3DJSAIL Java source code.
/**
 * <p> U.S. Navy Mk46 torpedo. </p>
 <p> Related links: Catalog page <a href="../../../../Weapons/Torpedoes/Mk46TorpedoIndex.html" target="_blank">Mk46Torpedo</a>,  source <a href="../../../../Weapons/Torpedoes/Mk46Torpedo.java">Mk46Torpedo.java</a>, <a href="https://www.web3d.org/x3d/content/examples/X3dResources.html" target="_blank">X3D Resources</a>, <a href="https://www.web3d.org/x3d/content/examples/X3dSceneAuthoringHints.html" target="_blank">X3D Scene Authoring Hints</a>, and <a href="https://www.web3d.org/x3d/content/X3dTooltips.html" target="_blank">X3D Tooltips</a>. </p>
	<table style="color:black; border:0px solid; border-spacing:10px 0px;">
        <caption>Scene Meta Information</caption>
		<tr style="background-color:silver; border-color:silver;">
			<td style="text-align:center; padding:10px 0px;"><i>meta tags</i></td>
			<td style="text-align:left;   padding:10px 0px;">&nbsp; Document Metadata </td>
		</tr>

		<tr>
			<td style="text-align:right; vertical-align: text-top;"> <i> title </i> </td>
			<td> <a href="../../../../Weapons/Torpedoes/Mk46Torpedo.x3d">Mk46Torpedo.x3d</a> </td>
		</tr>
		<tr>
			<td style="text-align:right; vertical-align: text-top;"> <i> description </i> </td>
			<td> U.S. Navy Mk46 torpedo </td>
		</tr>
		<tr>
			<td style="text-align:right; vertical-align: text-top;"> <i> created </i> </td>
			<td> 7 April 2003 </td>
		</tr>
		<tr>
			<td style="text-align:right; vertical-align: text-top;"> <i> modified </i> </td>
			<td> 28 November 2019 </td>
		</tr>
		<tr>
			<td style="text-align:right; vertical-align: text-top;"> <i> creator </i> </td>
			<td> Jeffrey Weekley and UW3303 course </td>
		</tr>
		<tr>
			<td style="text-align:right; vertical-align: text-top;"> <i> photo </i> </td>
			<td> <a href="http://www.chinfo.navy.mil/navpalib/factfile/weapons/wep-torp.html" target="_blank">http://www.chinfo.navy.mil/navpalib/factfile/weapons/wep-torp.html</a> </td>
		</tr>
		<tr>
			<td style="text-align:right; vertical-align: text-top;"> <i> reference </i> </td>
			<td> <a href="https://www.fas.org/man/dod-101/sys/ship/weaps/mk-46.htm" target="_blank">https://www.fas.org/man/dod-101/sys/ship/weaps/mk-46.htm</a> </td>
		</tr>
		<tr>
			<td style="text-align:right; vertical-align: text-top;"> <i> identifier </i> </td>
			<td> <a href="https://www.web3d.org/x3d/content/examples/Savage/Weapons/Torpedoes/Mk46Torpedo.x3d" target="_blank">https://www.web3d.org/x3d/content/examples/Savage/Weapons/Torpedoes/Mk46Torpedo.x3d</a> </td>
		</tr>
		<tr>
			<td style="text-align:right; vertical-align: text-top;"> <i> generator </i> </td>
			<td> X3D-Edit 3.2, <a href="https://www.web3d.org/x3d/tools/X3D-Edit" target="_blank">https://www.web3d.org/x3d/tools/X3D-Edit</a> </td>
		</tr>
		<tr>
			<td style="text-align:right; vertical-align: text-top;"> <i> license </i> </td>
			<td> <a href="../../../../Weapons/Torpedoes/../../license.html">../../license.html</a> </td>
		</tr>
		<tr style="background-color:silver; border-color:silver;">
			<td style="text-align:center;" colspan="2">  &nbsp; </td>
		</tr>
	</table>

	<p>
		This program uses the
		<a href="https://www.web3d.org/specifications/java/X3DJSAIL.html" target="_blank">X3D Java Scene Access Interface Library (X3DJSAIL)</a>.
		It has been produced using the 
		<a href="https://www.web3d.org/x3d/stylesheets/X3dToJava.xslt" target="_blank">X3dToJava.xslt</a>
		stylesheet
	       (<a href="https://sourceforge.net/p/x3d/code/HEAD/tree/www.web3d.org/x3d/stylesheets/X3dToJava.xslt" target="_blank">version control</a>)
                which is used to create Java source code from an original <code>.x3d</code> model.
	</p>

	* @author Jeffrey Weekley and UW3303 course
 */

public class Mk46Torpedo
{
	/** Default constructor to create this object. */
	public Mk46Torpedo ()
	{
	  initialize();
	}

	/** Create and initialize the X3D model for this object. */
	public final void initialize()
	{
            try { // catch-all
  x3dModel = new X3D().setProfile(X3D.PROFILE_IMMERSIVE).setVersion(X3D.VERSION_3_0)
  .setHead(new head()
    .addMeta(new meta().setName(meta.NAME_TITLE      ).setContent("Mk46Torpedo.x3d"))
    .addMeta(new meta().setName(meta.NAME_DESCRIPTION).setContent("U.S. Navy Mk46 torpedo"))
    .addMeta(new meta().setName(meta.NAME_CREATED    ).setContent("7 April 2003"))
    .addMeta(new meta().setName(meta.NAME_MODIFIED   ).setContent("28 November 2019"))
    .addMeta(new meta().setName(meta.NAME_CREATOR    ).setContent("Jeffrey Weekley and UW3303 course"))
    .addMeta(new meta().setName(meta.NAME_PHOTO      ).setContent("http://www.chinfo.navy.mil/navpalib/factfile/weapons/wep-torp.html"))
    .addMeta(new meta().setName(meta.NAME_REFERENCE  ).setContent("https://www.fas.org/man/dod-101/sys/ship/weaps/mk-46.htm"))
    .addMeta(new meta().setName(meta.NAME_IDENTIFIER ).setContent("https://www.web3d.org/x3d/content/examples/Savage/Weapons/Torpedoes/Mk46Torpedo.x3d"))
    .addMeta(new meta().setName(meta.NAME_GENERATOR  ).setContent("X3D-Edit 3.2, https://www.web3d.org/x3d/tools/X3D-Edit"))
    .addMeta(new meta().setName(meta.NAME_LICENSE    ).setContent("../../license.html")))
  .setScene(new Scene()
    .addChild(new WorldInfo().setTitle("Mk46Torpedo.x3d"))
    .addChild(new WorldInfo().setInfo(new String[] {"Only unclassified open resources were used to create this model."}))
    .addChild(new Inline().setUrl(new String[] {"../../Tools/Authoring/GridXZ_20x20Movable.x3d","https://www.web3d.org/x3d/content/examples/Savage/Tools/Authoring/GridXZ_20x20Movable.x3d","../../Tools/Authoring/GridXZ_20x20Movable.wrl","https://www.web3d.org/x3d/content/examples/Savage/Tools/Authoring/GridXZ_20x20Movable.wrl"}))
    .addChild(new Viewpoint().setDescription("Mk46 Torpedo").setPosition(0.0,0.0,5.0))
    .addChild(new Group()
      .addChild(new Transform("torpedo").setRotation(0.0,0.0,1.0,1.57079).setTranslation(2.66,0.0,0.0)
        .addChild(new Transform("torpedoband1").setTranslation(0.0,2.53,0.0)
          .addChild(new Shape()
            .setGeometry(new Cylinder().setBottom(false).setHeight(2.13).setRadius(0.163).setTop(false))
            .setAppearance(new Appearance()
              .setMaterial(new Material().setDiffuseColor(0.1,0.2,0.1).setSpecularColor(0.15,0.25,0.15)))))
        .addChild(new Transform("torpedonose").setRotation(1.0,0.0,0.0,3.1416).setScale(0.613,0.3,0.613).setTranslation(0.0,1.485,0.0)
          .addChild(new Shape()
            .setAppearance(new Appearance()
              .setMaterial(new Material().setDiffuseColor(0.05,0.05,0.075).setSpecularColor(0.1,0.1,0.15)))
            .setGeometry(new Extrusion().setCreaseAngle(1.785).setCrossSection(new MFVec2f(new double[] {0.267,0.000,0.231,-0.134,0.134,-0.231,0.0,-0.267,-0.134,-0.231,-0.231,-0.134,-0.267,0.000,-0.231,0.134,-0.134,0.231,0.0,0.267,0.134,0.231,0.231,0.134,0.267,0.0})).setScale(new MFVec2f(new double[] {1.00,1.00,0.95,0.95,0.88,0.88,0.76,0.76,0.48,0.48})).setSpine(new MFVec3f(new double[] {0.00,0.00,0.00,0.00,0.10,0.00,0.00,0.20,0.00,0.00,0.30,0.00,0.00,0.40,0.00})))))
        .addChild(new Transform().setScale(0.613,0.25,0.613).setTranslation(0.0,1.95,0.0)
          .addChild(new Group("controlfins")
            .addChild(new Transform().setRotation(0.0,-1.0,0.0,5.27).setTranslation(0.0,0.125,0.0)
              .addChild(new Transform("ControlFin1"))
              .addChild(new Transform("ControlFin2").setRotation(0.0,1.0,0.0,3.17))
              .addChild(new Transform("ControlFin3").setRotation(0.0,1.0,0.0,1.57))
              .addChild(new Transform("ControlFin4").setRotation(0.0,1.0,0.0,4.74))))
          .addChild(new Group("stabilzerfins")
            .addChild(new Transform().setTranslation(0.0,8.15,0.0)
              .addChild(new Transform("stabilizerfin1").setTranslation(0.19,-0.625,0.0)
                .addChild(new Shape()
                  .setGeometry(new Box().setSize(0.175,0.75,0.02))
                  .setAppearance(new Appearance()
                    .setMaterial(new Material().setDiffuseColor(0.1,0.2,0.1)))))
              .addChild(new Transform("stabilizerfin2").setRotation(0.0,1.0,0.0,1.57).setTranslation(0.0,-0.625,0.19)
                .addChild(new Shape()
                  .setGeometry(new Box().setSize(0.175,0.75,0.02))
                  .setAppearance(new Appearance()
                    .setMaterial(new Material().setDiffuseColor(0.1,0.2,0.1)))))
              .addChild(new Transform("stabilizerfin3").setRotation(0.0,1.0,0.0,3.1416)
                .addChild(new Transform().setUSE("stabilizerfin1")))
              .addChild(new Transform("stabilizerfin4").setRotation(0.0,1.0,0.0,3.1416)
                .addChild(new Transform().setUSE("stabilizerfin2")))))
          .addChild(new Group("TailSection")
            .addChild(new Transform("torpedotail").setRotation(1.0,0.0,0.0,3.1416).setTranslation(0.0,7.9375,0.0)
              .addChild(new Shape()
                .setAppearance(new Appearance()
                  .setMaterial(new Material().setDiffuseColor(0.05,0.05,0.075).setSpecularColor(0.1,0.1,0.15)))
                .setGeometry(new Extrusion().setCreaseAngle(2.0).setCrossSection(new MFVec2f(new double[] {0.267,0.000,0.231,-0.134,0.134,-0.231,0.0,-0.267,-0.134,-0.231,-0.231,-0.134,-0.267,0.000,-0.231,0.134,-0.134,0.231,0.0,0.267,0.134,0.231,0.231,0.134,0.267,0.0})).setEndCap(false).setScale(new MFVec2f(new double[] {0.342,0.342,0.500,0.500,0.643,0.643,0.766,0.766,0.866,0.866,0.940,0.940,0.985,0.985,1.0,1.0})).setSpine(new MFVec3f(new double[] {0.0,0.0,0.000,0.0,0.114,0.000,0.0,0.266,0.000,0.0,0.453,0.000,0.0,0.670,0.000,0.0,0.910,0.000,0.0,1.166,0.000,0.0,1.431,0.0}))))
              .addChild(new Transform().setScale(1.0,1.5,1.0).setTranslation(0.0,0.125,0.0)
                .addChild(new Shape("torpedoshroud")
                  .setAppearance(new Appearance()
                    .setMaterial(new Material().setDiffuseColor(0.05,0.05,0.075).setSpecularColor(0.1,0.1,0.15)))
                  .setGeometry(new Extrusion().setCreaseAngle(.785).setCrossSection(new MFVec2f(new double[] {0.00,0.00,-0.02,0.00,-0.02,-0.10,-0.06,-0.20,-0.04,-0.20,0.00,-0.10,0.00,0.00})).setSolid(false).setSpine(new MFVec3f(new double[] {0.20,0.00,0.00,0.19,0.00,-0.07,0.15,0.00,-0.13,0.10,0.00,-0.17,0.03,0.00,-0.20,-0.03,0.00,-0.20,-0.10,0.00,-0.17,-0.15,0.00,-0.13,-0.19,0.00,-0.07,-0.20,0.00,0.00,-0.19,0.00,0.07,-0.15,0.00,0.13,-0.10,0.00,0.17,-0.03,0.00,0.20,0.03,0.00,0.20,0.10,0.00,0.17,0.15,0.00,0.13,0.19,0.00,0.07,0.20,0.00,0.00})))))
              .addChild(new Group("torpedostator")
                .addChild(new Transform("propeller").setTranslation(0.0,-0.15,0.0)
                  .addChild(new Group("statorblade1")
                    .addChild(new Transform("torpedostatorblade1")
                      .addChild(new Transform().setRotation(-1.0,0.0,0.0,3.43).setTranslation(0.075,0.0,0.0)
                        .addChild(new Shape()
                          .setGeometry(new Box().setSize(0.125,0.09,0.015))
                          .setAppearance(new Appearance()
                            .setMaterial(new Material().setDiffuseColor(0.05,0.05,0.075))))))
                    .addChild(new Transform("torpedostatorblade1A")
                      .addChild(new Transform().setRotation(1.0,0.0,0.0,3.43).setTranslation(-0.075,0.0,0.0)
                        .addChild(new Shape()
                          .setGeometry(new Box().setSize(0.125,0.09,0.015))
                          .setAppearance(new Appearance()
                            .setMaterial(new Material().setDiffuseColor(0.05,0.05,0.075)))))))
                  .addChild(new Group("statorblade2")
                    .addChild(new Transform().setRotation(0.0,1.0,0.0,2.04)
                      .addChild(new Group().setUSE("statorblade1"))))
                  .addChild(new Group("statorblade3")
                    .addChild(new Transform().setRotation(0.0,-1.0,0.0,5.27)
                      .addChild(new Group().setUSE("statorblade1"))))
                  .addChild(new Transform("statorbladeshaft").setTranslation(0.0,0.0,0.0)
                    .addChild(new Shape()
                      .setAppearance(new Appearance()
                        .setMaterial(new Material().setDiffuseColor(0.05,0.05,0.075)))
                      .setGeometry(new Cylinder().setHeight(0.1).setRadius(0.05))))
                  .addChild(new Transform("statorcrankshaft").setTranslation(0.0,0.1,0.0)
                    .addChild(new Shape()
                      .setGeometry(new Cylinder().setHeight(.125).setRadius(.025))
                      .setAppearance(new Appearance()
                        .setMaterial(new Material().setDiffuseColor(0.0,0.0,0.75))))))
                .addChild(new OrientationInterpolator("PropSpin").setKey(new double[] {0.0,0.5,1.0}).setKeyValue(new MFRotation(new double[] {0.0,1.0,0.0,0.00,0.0,1.0,0.0,3.14,0.0,1.0,0.0,6.28})))
                .addChild(new TimeSensor("Clock").setCycleInterval(0.5).setLoop(true))
                .addComments(" Spins the propellor and stator once every 4 seconds ")))))))
    .addChild(new ROUTE().setFromNode("Clock").setFromField("fraction_changed").setToNode("PropSpin").setToField("set_fraction"))
    .addChild(new ROUTE().setFromNode("PropSpin").setFromField("value_changed").setToNode("propeller").setToField("rotation")));
            }
            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 
	 * <a href="https://dzone.com/articles/java-copy-shallow-vs-deep-in-which-you-will-swim" target="_blank">shallow copy</a>
	 * of the X3D model.
	 * @see <a href="https://www.web3d.org/specifications/java/javadoc/org/web3d/x3d/jsail/Core/X3D.html">X3D</a>
	 * @return Mk46Torpedo 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 <a href="https://www.web3d.org/specifications/java/javadoc/org/web3d/x3d/jsail/Core/X3D.html#handleArguments-java.lang.String:A-">X3D.handleArguments(args)</a>
     * @see <a href="https://www.web3d.org/specifications/java/javadoc/org/web3d/x3d/jsail/Core/X3D.html#validationReport--">X3D.validationReport()</a>
     * @see <a href="https://www.web3d.org/specifications/java/javadoc/org/web3d/x3d/jsail/CommandLine.html">CommandLine</a>
     * @see <a href="https://www.web3d.org/specifications/java/javadoc/org/web3d/x3d/jsail/CommandLine.html#USAGE">CommandLine.USAGE</a>
     * @see <a href="https://www.web3d.org/specifications/java/javadoc/org/web3d/x3d/jsail/ConfigurationProperties.html">ConfigurationProperties</a>
     */
    public static void main(String args[])
    {
        System.out.println("Build this X3D model, showing validation diagnostics...");
        X3D thisExampleX3dModel = new Mk46Torpedo().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: \"Savage.Weapons.Torpedoes.Mk46Torpedo\" 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("Savage.Weapons.Torpedoes.Mk46Torpedo self-validation test confirmation: ");
                if (!validationResults.equals("success"))
                    System.out.println();
                System.out.println(validationResults.trim());

                // experimental: test X3DJSAIL output files
                // Weapons/Torpedoes/Mk46Torpedo_JavaExport.* file validation is checked when building X3D Example Archives
                String filenameX3D  = "Weapons/Torpedoes/Mk46Torpedo_JavaExport.x3d"; 
                String filenameX3DV = "Weapons/Torpedoes/Mk46Torpedo_JavaExport.x3dv"; 
                String filenameJSON = "Weapons/Torpedoes/Mk46Torpedo_JavaExport.json";
                thisExampleX3dModel.toFileX3D        (filenameX3D);
                thisExampleX3dModel.toFileClassicVRML(filenameX3DV);
// TODO         thisExampleX3dModel.toFileJSON       (filenameJSON);
        }
    }
}
