x_ite 5.0.3 → 6.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.vscode/settings.json +12 -5
- package/.vscode/tasks.json +25 -1
- package/Makefile +36 -28
- package/README.md +6 -11
- package/build/bin/dist.pl +0 -6
- package/build/bin/examples-and-tests.pl +75 -0
- package/build/bin/tests-menu.pl +57 -0
- package/build/bin/version.pl +7 -4
- package/build/parts/default.start.frag.js +3 -2
- package/dist/assets/components/annotation.js +3 -2
- package/dist/assets/components/annotation.min.js +1 -1
- package/dist/assets/components/cad-geometry.js +3 -2
- package/dist/assets/components/cad-geometry.min.js +1 -1
- package/dist/assets/components/cube-map-texturing.js +8 -20
- package/dist/assets/components/cube-map-texturing.min.js +1 -1
- package/dist/assets/components/dis.js +3 -2
- package/dist/assets/components/dis.min.js +1 -1
- package/dist/assets/components/event-utilities.js +4 -3
- package/dist/assets/components/event-utilities.min.js +1 -1
- package/dist/assets/components/geometry2d.js +38 -52
- package/dist/assets/components/geometry2d.min.js +1 -1
- package/dist/assets/components/geospatial.js +34 -1686
- package/dist/assets/components/geospatial.min.js +1 -1
- package/dist/assets/components/h-anim.js +71 -77
- package/dist/assets/components/h-anim.min.js +1 -1
- package/dist/assets/components/key-device-sensor.js +4 -3
- package/dist/assets/components/key-device-sensor.min.js +1 -1
- package/dist/assets/components/layout.js +101 -173
- package/dist/assets/components/layout.min.js +1 -1
- package/dist/assets/components/nurbs.js +3 -2
- package/dist/assets/components/nurbs.min.js +1 -1
- package/dist/assets/components/particle-systems.js +1926 -1669
- package/dist/assets/components/particle-systems.min.js +1 -1
- package/dist/assets/components/picking.js +34 -41
- package/dist/assets/components/picking.min.js +1 -1
- package/dist/assets/components/projective-texture-mapping.js +73 -86
- package/dist/assets/components/projective-texture-mapping.min.js +1 -1
- package/dist/assets/components/rigid-body-physics.js +37 -57
- package/dist/assets/components/rigid-body-physics.min.js +1 -1
- package/dist/assets/components/scripting.js +3 -2
- package/dist/assets/components/scripting.min.js +1 -1
- package/dist/assets/components/texturing-3d.js +27 -33
- package/dist/assets/components/texturing-3d.min.js +3 -3
- package/dist/assets/components/volume-rendering.js +12 -11
- package/dist/assets/components/volume-rendering.min.js +1 -1
- package/dist/assets/components/x_ite.js +3 -2
- package/dist/assets/components/x_ite.min.js +1 -1
- package/dist/assets/images/Shading.png +0 -0
- package/dist/assets/linetype/1.png +0 -0
- package/dist/assets/linetype/10.png +0 -0
- package/dist/assets/linetype/11.png +0 -0
- package/dist/assets/linetype/12.png +0 -0
- package/dist/assets/linetype/13.png +0 -0
- package/dist/assets/linetype/14.png +0 -0
- package/dist/assets/linetype/15.png +0 -0
- package/dist/assets/linetype/16.png +0 -0
- package/dist/assets/linetype/2.png +0 -0
- package/dist/assets/linetype/3.png +0 -0
- package/dist/assets/linetype/4.png +0 -0
- package/dist/assets/linetype/5.png +0 -0
- package/dist/assets/linetype/6.png +0 -0
- package/dist/assets/linetype/7.png +0 -0
- package/dist/assets/linetype/8.png +0 -0
- package/dist/assets/linetype/9.png +0 -0
- package/dist/assets/shaders/webgl1/Gouraud.vs +1 -1
- package/dist/assets/shaders/webgl1/Line.fs +0 -21
- package/dist/assets/shaders/webgl1/Line.vs +0 -10
- package/dist/assets/shaders/webgl1/PBR.fs +1 -1
- package/dist/assets/shaders/webgl1/PBR.vs +1 -1
- package/dist/assets/shaders/webgl1/Phong.fs +1 -1
- package/dist/assets/shaders/webgl1/Point.vs +1 -1
- package/dist/assets/shaders/webgl2/Depth.vs +29 -1
- package/dist/assets/shaders/webgl2/Gouraud.vs +32 -4
- package/dist/assets/shaders/webgl2/Line.fs +24 -12
- package/dist/assets/shaders/webgl2/Line.vs +36 -11
- package/dist/assets/shaders/webgl2/LineTransform.fs +4 -0
- package/dist/assets/shaders/webgl2/LineTransform.vs +57 -0
- package/dist/assets/shaders/webgl2/PBR.fs +1 -1
- package/dist/assets/shaders/webgl2/PBR.vs +35 -7
- package/dist/assets/shaders/webgl2/Phong.fs +1 -1
- package/dist/assets/shaders/webgl2/Phong.vs +31 -3
- package/dist/assets/shaders/webgl2/Point.vs +30 -2
- package/dist/assets/shaders/webgl2/Unlit.vs +31 -3
- package/dist/example.html +6 -6
- package/dist/x_ite.css +199 -224
- package/dist/x_ite.js +16335 -15917
- package/dist/x_ite.min.js +17 -17
- package/dist/x_ite.zip +0 -0
- package/docs/404.md +6 -0
- package/docs/Accessing-the-External-Browser.md +21 -15
- package/docs/Browser-Support.md +6 -0
- package/docs/Custom-Shaders.md +18 -25
- package/docs/Features.md +11 -5
- package/docs/Gemfile +44 -0
- package/docs/Gemfile.lock +122 -0
- package/docs/Glossary.md +6 -0
- package/docs/How-To-Configure-Your-Web-Server.md +6 -0
- package/docs/Supported-Nodes.md +9 -1
- package/docs/What's-New.md +93 -39
- package/docs/XHTML-DOM-Integration.md +6 -0
- package/docs/_config.yml +2 -2
- package/docs/assets/css/main.scss +26 -0
- package/docs/index.md +42 -50
- package/docs/reference/Browser-Services.md +9 -3
- package/docs/reference/Constants-Services.md +6 -0
- package/docs/reference/ECMAScript-Object-and-Function-Definitions.md +12 -6
- package/docs/reference/Field-Services-and-Objects.md +105 -1
- package/docs/reference/Prototype-Services.md +11 -0
- package/docs/reference/Route-Services.md +9 -0
- package/docs/reference/Scene-Services.md +17 -2
- package/docs/reference/Script-Node-Authoring-Interface.md +7 -1
- package/docs/tutorials/Adding-backgrounds.md +6 -0
- package/docs/tutorials/Adding-fog.md +6 -0
- package/docs/tutorials/Adding-sound.md +6 -0
- package/docs/tutorials/Animating-transforms.md +6 -0
- package/docs/tutorials/Basic-Nodes.md +6 -0
- package/docs/tutorials/Building-a-X3D-world.md +6 -0
- package/docs/tutorials/Building-elevation-grids.md +6 -0
- package/docs/tutorials/Building-extruded-shapes.md +6 -0
- package/docs/tutorials/Building-primitive-shapes.md +6 -0
- package/docs/tutorials/Building-shapes-out-of-points,-lines,-and-faces.md +6 -0
- package/docs/tutorials/Controlling-appearance-with-materials.md +6 -0
- package/docs/tutorials/Controlling-color-on-coordinate-based-geometry.md +6 -0
- package/docs/tutorials/Controlling-detail.md +6 -0
- package/docs/tutorials/Controlling-how-textures-are-mapped.md +6 -0
- package/docs/tutorials/Controlling-navigation.md +6 -0
- package/docs/tutorials/Controlling-shading-on-coordinate-based-geometry.md +6 -0
- package/docs/tutorials/Controlling-the-viewpoint.md +6 -0
- package/docs/tutorials/Creating-new-node-types.md +6 -0
- package/docs/tutorials/Grouping-nodes.md +6 -0
- package/docs/tutorials/Hello,-World!.md +6 -0
- package/docs/tutorials/Improving-Performance.md +6 -0
- package/docs/tutorials/Increasing-Rendering-Speed.md +6 -0
- package/docs/tutorials/Introducing-X3D.md +6 -0
- package/docs/tutorials/Introducing-animation.md +6 -0
- package/docs/tutorials/Introducing-script-use.md +6 -0
- package/docs/tutorials/Lighting-your-world.md +6 -0
- package/docs/tutorials/Mapping-textures.md +6 -0
- package/docs/tutorials/Naming-nodes.md +6 -0
- package/docs/tutorials/Providing-information-about-your-world.md +6 -0
- package/docs/tutorials/Sensing-the-viewer.md +6 -0
- package/docs/tutorials/Sensing-viewer-actions.md +6 -0
- package/docs/tutorials/Transforming-Shapes.md +6 -0
- package/docs/tutorials/Writing-program-scripts-with-ECMAScript.md +6 -0
- package/docs/tutorials/index.md +42 -36
- package/package.json +6 -7
- package/src/assets/components/geometry2d.js +1 -1
- package/src/assets/components/key-device-sensor.js +1 -1
- package/src/assets/components/layout.js +1 -1
- package/src/assets/components/particle-systems.js +1 -1
- package/src/assets/components/volume-rendering.js +1 -1
- package/src/assets/images/Shading.png +0 -0
- package/src/assets/linetype/1.png +0 -0
- package/src/assets/linetype/10.png +0 -0
- package/src/assets/linetype/11.png +0 -0
- package/src/assets/linetype/12.png +0 -0
- package/src/assets/linetype/13.png +0 -0
- package/src/assets/linetype/14.png +0 -0
- package/src/assets/linetype/15.png +0 -0
- package/src/assets/linetype/16.png +0 -0
- package/src/assets/linetype/2.png +0 -0
- package/src/assets/linetype/3.png +0 -0
- package/src/assets/linetype/4.png +0 -0
- package/src/assets/linetype/5.png +0 -0
- package/src/assets/linetype/6.png +0 -0
- package/src/assets/linetype/7.png +0 -0
- package/src/assets/linetype/8.png +0 -0
- package/src/assets/linetype/9.png +0 -0
- package/src/assets/shaders/Types.glsl +1 -9
- package/src/assets/shaders/webgl1/Gouraud.fs +1 -1
- package/src/assets/shaders/webgl1/Gouraud.vs +2 -3
- package/src/assets/shaders/webgl1/Line.fs +3 -28
- package/src/assets/shaders/webgl1/Line.vs +6 -20
- package/src/assets/shaders/webgl1/PBR.fs +6 -6
- package/src/assets/shaders/webgl1/PBR.vs +1 -1
- package/src/assets/shaders/webgl1/Phong.fs +10 -10
- package/src/assets/shaders/webgl1/Point.vs +2 -2
- package/src/assets/shaders/webgl1/Unlit.fs +4 -4
- package/src/assets/shaders/webgl1/include/Normal.glsl +1 -1
- package/src/assets/shaders/webgl1/include/Texture.glsl +3 -8
- package/src/assets/shaders/webgl2/Depth.vs +4 -1
- package/src/assets/shaders/webgl2/Gouraud.fs +1 -1
- package/src/assets/shaders/webgl2/Gouraud.vs +8 -6
- package/src/assets/shaders/webgl2/Line.fs +11 -17
- package/src/assets/shaders/webgl2/Line.vs +17 -21
- package/src/assets/shaders/webgl2/LineTransform.fs +6 -0
- package/src/assets/shaders/webgl2/LineTransform.vs +77 -0
- package/src/assets/shaders/webgl2/PBR.fs +6 -6
- package/src/assets/shaders/webgl2/PBR.vs +10 -7
- package/src/assets/shaders/webgl2/Phong.fs +11 -11
- package/src/assets/shaders/webgl2/Phong.vs +6 -3
- package/src/assets/shaders/webgl2/Point.vs +5 -4
- package/src/assets/shaders/webgl2/Unlit.fs +5 -5
- package/src/assets/shaders/webgl2/Unlit.vs +6 -3
- package/src/assets/shaders/webgl2/include/Line2.glsl +20 -0
- package/src/assets/shaders/webgl2/include/Normal.glsl +1 -1
- package/src/assets/shaders/webgl2/include/Particle.glsl +36 -0
- package/src/assets/shaders/webgl2/include/Texture.glsl +3 -3
- package/src/example.html +6 -6
- package/src/examples.js +5 -4
- package/src/standard/Math/Algorithm.js +12 -28
- package/src/standard/Math/Geometry/Line2.js +163 -0
- package/src/standard/Math/Geometry/Line3.js +3 -5
- package/src/standard/Math/Geometry/Plane3.js +0 -2
- package/src/standard/Math/Geometry/Triangle3.js +1 -1
- package/src/standard/Math/Geometry/ViewVolume.js +121 -103
- package/src/standard/Math/Numbers/Color3.js +6 -0
- package/src/standard/Math/Numbers/Color4.js +7 -0
- package/src/standard/Math/Numbers/Complex.js +48 -34
- package/src/standard/Math/Numbers/Matrix2.js +62 -2
- package/src/standard/Math/Numbers/Matrix3.js +129 -110
- package/src/standard/Math/Numbers/Matrix4.js +138 -119
- package/src/standard/Math/Numbers/Quaternion.js +12 -5
- package/src/standard/Math/Numbers/Rotation4.js +8 -1
- package/src/standard/Math/Numbers/Vector2.js +42 -9
- package/src/standard/Math/Numbers/Vector3.js +50 -14
- package/src/standard/Math/Numbers/Vector4.js +48 -11
- package/src/standard/Math/Utility/BVH.js +45 -17
- package/src/tests.js +68 -66
- package/src/x_ite/Base/X3DBaseNode.js +22 -11
- package/src/x_ite/Base/X3DField.js +1 -1
- package/src/x_ite/Browser/Core/BrowserOptions.js +24 -143
- package/src/x_ite/Browser/Core/BrowserTimings.js +6 -4
- package/src/x_ite/Browser/Core/Context.js +185 -0
- package/src/x_ite/Browser/Core/ContextMenu.js +398 -211
- package/src/x_ite/Browser/Core/Notification.js +1 -0
- package/src/x_ite/Browser/Core/X3DCoreContext.js +35 -146
- package/src/x_ite/Browser/Followers/X3DArrayFollowerTemplate.js +1 -1
- package/src/x_ite/Browser/Geometry2D/Disk2DOptions.js +1 -0
- package/src/x_ite/Browser/Geometry2D/X3DGeometry2DContext.js +2 -2
- package/src/x_ite/Browser/Geometry3D/X3DGeometry3DContext.js +41 -2
- package/src/x_ite/Browser/Geospatial/Geocentric.js +2 -2
- package/src/x_ite/Browser/Interpolation/CatmullRomSplineInterpolatorTemplate.js +1 -1
- package/src/x_ite/Browser/Layout/ScreenText.js +18 -65
- package/src/x_ite/Browser/Layout/X3DLayoutContext.js +59 -16
- package/src/x_ite/Browser/Navigation/ExamineViewer.js +13 -20
- package/src/x_ite/Browser/Navigation/LookAtViewer.js +1 -4
- package/src/x_ite/Browser/Navigation/PlaneViewer.js +0 -3
- package/src/x_ite/Browser/Navigation/X3DFlyViewer.js +15 -8
- package/src/x_ite/Browser/Navigation/X3DViewer.js +12 -20
- package/src/x_ite/Browser/Networking/X3DNetworkingContext.js +11 -7
- package/src/x_ite/Browser/ParticleSystems/BVH.glsl +183 -0
- package/src/x_ite/Browser/ParticleSystems/Box3.glsl +47 -0
- package/src/x_ite/Browser/ParticleSystems/GeometryTypes.js +66 -0
- package/src/x_ite/Browser/ParticleSystems/Line3.glsl +55 -0
- package/src/x_ite/Browser/ParticleSystems/Plane3.glsl +160 -0
- package/src/x_ite/Browser/PointingDeviceSensor/PointingDevice.js +27 -3
- package/src/x_ite/Browser/PointingDeviceSensor/X3DPointingDeviceSensorContext.js +41 -37
- package/src/x_ite/Browser/Rendering/X3DRenderingContext.js +21 -13
- package/src/x_ite/Browser/Shaders/Shader.js +33 -12
- package/src/x_ite/Browser/Shaders/ShaderSource.js +6 -0
- package/src/x_ite/Browser/Shaders/ShaderTest.js +16 -10
- package/src/x_ite/Browser/Shape/X3DShapeContext.js +50 -9
- package/src/x_ite/Browser/Text/X3DTextContext.js +4 -13
- package/src/x_ite/Browser/Text/X3DTextGeometry.js +2 -1
- package/src/x_ite/Browser/Texturing/X3DTexturingContext.js +71 -34
- package/src/x_ite/Browser/Texturing3D/DICOMParser.js +2 -2
- package/src/x_ite/Browser/Time/X3DTimeContext.js +4 -2
- package/src/x_ite/Browser/VERSION.js +1 -1
- package/src/x_ite/Browser/X3DBrowser.js +7 -6
- package/src/x_ite/Browser/X3DBrowserContext.js +43 -10
- package/src/x_ite/Components/Core/X3DNode.js +4 -0
- package/src/x_ite/Components/Core/X3DPrototypeInstance.js +0 -2
- package/src/x_ite/Components/CubeMapTexturing/ComposedCubeMapTexture.js +3 -4
- package/src/x_ite/Components/CubeMapTexturing/GeneratedCubeMapTexture.js +1 -12
- package/src/x_ite/Components/CubeMapTexturing/ImageCubeMapTexture.js +1 -2
- package/src/x_ite/Components/EnvironmentalEffects/TextureBackground.js +1 -1
- package/src/x_ite/Components/EnvironmentalEffects/X3DBackgroundNode.js +76 -77
- package/src/x_ite/Components/EnvironmentalEffects/X3DFogObject.js +2 -9
- package/src/x_ite/Components/EnvironmentalSensor/ProximitySensor.js +51 -65
- package/src/x_ite/Components/EventUtilities/X3DSequencerNode.js +1 -1
- package/src/x_ite/Components/Followers/ColorDamper.js +1 -1
- package/src/x_ite/Components/Followers/X3DChaserNode.js +18 -32
- package/src/x_ite/Components/Followers/X3DDamperNode.js +1 -6
- package/src/x_ite/Components/Followers/X3DFollowerNode.js +1 -1
- package/src/x_ite/Components/Geometry2D/Disk2D.js +30 -46
- package/src/x_ite/Components/Geometry2D/TriangleSet2D.js +1 -1
- package/src/x_ite/Components/Geometry3D/ElevationGrid.js +12 -4
- package/src/x_ite/Components/Geometry3D/IndexedFaceSet.js +4 -4
- package/src/x_ite/Components/Geospatial/GeoCoordinate.js +10 -27
- package/src/x_ite/Components/Geospatial/GeoLOD.js +1 -1
- package/src/x_ite/Components/Geospatial/GeoPositionInterpolator.js +5 -10
- package/src/x_ite/Components/Geospatial/GeoTouchSensor.js +9 -16
- package/src/x_ite/Components/Geospatial/GeoTransform.js +6 -18
- package/src/x_ite/Components/Geospatial/GeoViewpoint.js +26 -30
- package/src/x_ite/Components/Geospatial/X3DGeospatialObject.js +20 -27
- package/src/x_ite/Components/Grouping/X3DGroupingNode.js +8 -8
- package/src/x_ite/Components/Grouping/X3DTransformNode.js +0 -4
- package/src/x_ite/Components/HAnim/HAnimHumanoid.js +68 -75
- package/src/x_ite/Components/Interpolation/OrientationInterpolator.js +4 -11
- package/src/x_ite/Components/Interpolation/X3DInterpolatorNode.js +1 -1
- package/src/x_ite/Components/Layout/LayoutGroup.js +4 -9
- package/src/x_ite/Components/Layout/ScreenFontStyle.js +1 -1
- package/src/x_ite/Components/Layout/ScreenGroup.js +16 -80
- package/src/x_ite/Components/Lighting/DirectionalLight.js +28 -36
- package/src/x_ite/Components/Lighting/PointLight.js +32 -47
- package/src/x_ite/Components/Lighting/SpotLight.js +33 -48
- package/src/x_ite/Components/Navigation/Billboard.js +49 -56
- package/src/x_ite/Components/Navigation/LOD.js +2 -2
- package/src/x_ite/Components/Navigation/OrthoViewpoint.js +29 -30
- package/src/x_ite/Components/Navigation/Viewpoint.js +16 -20
- package/src/x_ite/Components/Navigation/X3DViewpointNode.js +82 -111
- package/src/x_ite/Components/Networking/Anchor.js +18 -7
- package/src/x_ite/Components/ParticleSystems/BoundedPhysicsModel.js +6 -6
- package/src/x_ite/Components/ParticleSystems/ConeEmitter.js +44 -36
- package/src/x_ite/Components/ParticleSystems/ExplosionEmitter.js +26 -17
- package/src/x_ite/Components/ParticleSystems/ForcePhysicsModel.js +20 -7
- package/src/x_ite/Components/ParticleSystems/ParticleSystem.js +463 -882
- package/src/x_ite/Components/ParticleSystems/PointEmitter.js +39 -35
- package/src/x_ite/Components/ParticleSystems/PolylineEmitter.js +112 -128
- package/src/x_ite/Components/ParticleSystems/SurfaceEmitter.js +105 -112
- package/src/x_ite/Components/ParticleSystems/VolumeEmitter.js +138 -176
- package/src/x_ite/Components/ParticleSystems/WindPhysicsModel.js +16 -11
- package/src/x_ite/Components/ParticleSystems/X3DParticleEmitterNode.js +807 -217
- package/src/x_ite/Components/Picking/LinePickSensor.js +31 -39
- package/src/x_ite/Components/PointingDeviceSensor/CylinderSensor.js +91 -108
- package/src/x_ite/Components/PointingDeviceSensor/PlaneSensor.js +56 -59
- package/src/x_ite/Components/PointingDeviceSensor/SphereSensor.js +54 -71
- package/src/x_ite/Components/PointingDeviceSensor/TouchSensor.js +8 -15
- package/src/x_ite/Components/ProjectiveTextureMapping/TextureProjectorParallel.js +43 -50
- package/src/x_ite/Components/ProjectiveTextureMapping/TextureProjectorPerspective.js +32 -39
- package/src/x_ite/Components/Rendering/ClipPlane.js +3 -11
- package/src/x_ite/Components/Rendering/Color.js +12 -24
- package/src/x_ite/Components/Rendering/ColorRGBA.js +13 -25
- package/src/x_ite/Components/Rendering/IndexedLineSet.js +26 -4
- package/src/x_ite/Components/Rendering/LineSet.js +35 -13
- package/src/x_ite/Components/Rendering/PointSet.js +35 -13
- package/src/x_ite/Components/Rendering/X3DComposedGeometryNode.js +13 -5
- package/src/x_ite/Components/Rendering/X3DGeometryNode.js +331 -387
- package/src/x_ite/Components/Rendering/X3DLineGeometryNode.js +350 -140
- package/src/x_ite/Components/Rendering/X3DPointGeometryNode.js +116 -126
- package/src/x_ite/Components/RigidBodyPhysics/DoubleAxisHingeJoint.js +24 -38
- package/src/x_ite/Components/RigidBodyPhysics/SingleAxisHingeJoint.js +10 -17
- package/src/x_ite/Components/Shaders/ComposedShader.js +35 -75
- package/src/x_ite/Components/Shaders/FloatVertexAttribute.js +8 -11
- package/src/x_ite/Components/Shaders/Matrix3VertexAttribute.js +10 -14
- package/src/x_ite/Components/Shaders/Matrix4VertexAttribute.js +10 -14
- package/src/x_ite/Components/Shaders/ShaderPart.js +1 -10
- package/src/x_ite/Components/Shaders/X3DProgrammableShaderObject.js +220 -210
- package/src/x_ite/Components/Shaders/X3DShaderNode.js +28 -10
- package/src/x_ite/Components/Shaders/X3DVertexAttributeNode.js +15 -1
- package/src/x_ite/Components/Shape/Appearance.js +37 -4
- package/src/x_ite/Components/Shape/FillProperties.js +12 -1
- package/src/x_ite/Components/Shape/LineProperties.js +33 -1
- package/src/x_ite/Components/Shape/PointProperties.js +24 -3
- package/src/x_ite/Components/Shape/Shape.js +30 -39
- package/src/x_ite/Components/Shape/TwoSidedMaterial.js +3 -1
- package/src/x_ite/Components/Sound/Sound.js +31 -41
- package/src/x_ite/Components/Text/Text.js +6 -20
- package/src/x_ite/Components/Texturing/ImageTexture.js +1 -1
- package/src/x_ite/Components/Texturing/MovieTexture.js +1 -1
- package/src/x_ite/Components/Texturing/PixelTexture.js +2 -2
- package/src/x_ite/Components/Texturing/TextureCoordinate.js +5 -5
- package/src/x_ite/Components/Texturing/TextureProperties.js +4 -4
- package/src/x_ite/Components/Texturing/X3DSingleTextureNode.js +5 -4
- package/src/x_ite/Components/Texturing/X3DTexture2DNode.js +24 -33
- package/src/x_ite/Components/Texturing3D/TextureCoordinate3D.js +5 -5
- package/src/x_ite/Components/Texturing3D/TextureCoordinate4D.js +5 -5
- package/src/x_ite/Components/Texturing3D/X3DTexture3DNode.js +12 -19
- package/src/x_ite/Components/VolumeRendering/X3DVolumeDataNode.js +8 -8
- package/src/x_ite/Components.js +2 -2
- package/src/x_ite/Fallback.js +9 -3
- package/src/x_ite/Fields/SFColor.js +4 -0
- package/src/x_ite/Fields/SFColorRGBA.js +4 -0
- package/src/x_ite/Fields/SFImage.js +2 -11
- package/src/x_ite/Fields/SFMatrixPrototypeTemplate.js +4 -0
- package/src/x_ite/Fields/SFRotation.js +4 -0
- package/src/x_ite/Fields/SFString.js +4 -0
- package/src/x_ite/Fields/SFVecPrototypeTemplate.js +22 -2
- package/src/x_ite/Parser/XMLParser.js +1 -1
- package/src/x_ite/Rendering/TextureBuffer.js +43 -36
- package/src/x_ite/Rendering/VertexArray.js +103 -0
- package/src/x_ite/Rendering/X3DRenderObject.js +127 -148
- package/src/x_ite/X3D.js +32 -26
- package/src/x_ite.config.js +0 -5
- package/src/x_ite.css +216 -175
- package/src/x_ite.html +15 -10
- package/src/x_ite.js +49 -1
- package/x_ite.min.html +15 -10
- package/dist/assets/hatching/0.png +0 -0
- package/dist/assets/linetype/0.png +0 -0
- package/src/assets/hatching/0.png +0 -0
- package/src/assets/linetype/0.png +0 -0
- package/src/spinner.css +0 -67
- package/src/x_ite/Browser/Shape/LineStipples.xcf +0 -0
|
@@ -50,22 +50,25 @@
|
|
|
50
50
|
define ([
|
|
51
51
|
"jquery",
|
|
52
52
|
"x_ite/Base/X3DBaseNode",
|
|
53
|
+
"x_ite/Components/Geospatial/GeoViewpoint",
|
|
53
54
|
"locale/gettext",
|
|
54
|
-
"contextMenu",
|
|
55
55
|
"lib/jquery.fullscreen-min",
|
|
56
|
+
"jquery-mousewheel",
|
|
56
57
|
],
|
|
57
58
|
function ($,
|
|
58
59
|
X3DBaseNode,
|
|
60
|
+
GeoViewpoint,
|
|
59
61
|
_)
|
|
60
62
|
{
|
|
61
63
|
"use strict";
|
|
62
64
|
|
|
65
|
+
const _userMenu = Symbol ();
|
|
66
|
+
|
|
63
67
|
function ContextMenu (executionContext)
|
|
64
68
|
{
|
|
65
69
|
X3DBaseNode .call (this, executionContext);
|
|
66
70
|
|
|
67
|
-
this
|
|
68
|
-
this .active = false;
|
|
71
|
+
this [_userMenu] = null;
|
|
69
72
|
}
|
|
70
73
|
|
|
71
74
|
ContextMenu .prototype = Object .assign (Object .create (X3DBaseNode .prototype),
|
|
@@ -89,146 +92,61 @@ function ($,
|
|
|
89
92
|
|
|
90
93
|
const browser = this .getBrowser ();
|
|
91
94
|
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
$.contextMenu ({
|
|
96
|
-
selector: ".x_ite-private-browser-" + browser .getNumber (),
|
|
95
|
+
this .init ({
|
|
96
|
+
element: browser .getElement (),
|
|
97
|
+
appendTo: browser .getShadow (),
|
|
97
98
|
build: this .build .bind (this),
|
|
98
99
|
animation: {duration: 500, show: "fadeIn", hide: "fadeOut"},
|
|
99
|
-
hideOnSecondTrigger: true,
|
|
100
|
-
events:
|
|
101
|
-
{
|
|
102
|
-
show: function (options)
|
|
103
|
-
{
|
|
104
|
-
this .active = true;
|
|
105
|
-
|
|
106
|
-
if (browser .getElement () .fullScreen ())
|
|
107
|
-
{
|
|
108
|
-
browser .getElement () .append (options .$menu);
|
|
109
|
-
|
|
110
|
-
setTimeout (function ()
|
|
111
|
-
{
|
|
112
|
-
browser .getElement () .append (options .$layer .css ({
|
|
113
|
-
position: "absolute",
|
|
114
|
-
width: "100%",
|
|
115
|
-
height: "100%",
|
|
116
|
-
}));
|
|
117
|
-
},
|
|
118
|
-
1);
|
|
119
|
-
}
|
|
120
|
-
},
|
|
121
|
-
activated: function (options)
|
|
122
|
-
{
|
|
123
|
-
// Display submenus on left side if there is no space on right side.
|
|
124
|
-
|
|
125
|
-
if (options .$menu .hasClass ("x_ite-private-menu-submenus-left"))
|
|
126
|
-
{
|
|
127
|
-
options .$menu .find (".context-menu-list") .each (function (i, e)
|
|
128
|
-
{
|
|
129
|
-
$(e) .css ("right", $(e) .parent () .parent () .css ("width"));
|
|
130
|
-
});
|
|
131
|
-
}
|
|
132
|
-
else
|
|
133
|
-
{
|
|
134
|
-
options .$menu .find (".context-menu-list") .each (function (i, e)
|
|
135
|
-
{
|
|
136
|
-
$(e) .css ("left", (parseInt ($(e) .parent () .parent () .css ("width")) - 2) + "px");
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
// If the submenu is higher than vh, add scrollbars.
|
|
141
|
-
options .$menu .find (".context-menu-list") .each (function (i, e)
|
|
142
|
-
{
|
|
143
|
-
if ($(e) .height () > $(window) .height ())
|
|
144
|
-
{
|
|
145
|
-
$(e) .css ({
|
|
146
|
-
"overflow-y": "scroll",
|
|
147
|
-
"max-height": "100vh",
|
|
148
|
-
});
|
|
149
|
-
}
|
|
150
|
-
});
|
|
151
|
-
|
|
152
|
-
// If the submenu is higher than vh, reposition it.
|
|
153
|
-
options .$menu .find (".context-menu-item") .on ("mouseenter", function (event)
|
|
154
|
-
{
|
|
155
|
-
event .stopImmediatePropagation ();
|
|
156
|
-
|
|
157
|
-
const
|
|
158
|
-
t = $(event .target),
|
|
159
|
-
e = t .children (".context-menu-list");
|
|
160
|
-
|
|
161
|
-
if (!e .length)
|
|
162
|
-
return;
|
|
163
|
-
|
|
164
|
-
e .css ("top", "");
|
|
165
|
-
|
|
166
|
-
const bottom = e .offset () .top + e .height () - $(window) .scrollTop () - $(window) .height ();
|
|
167
|
-
|
|
168
|
-
if (bottom > 0)
|
|
169
|
-
e .offset ({ "top": e .offset () .top - bottom });
|
|
170
|
-
});
|
|
171
|
-
}
|
|
172
|
-
.bind (this),
|
|
173
|
-
hide: function (options)
|
|
174
|
-
{
|
|
175
|
-
this .active = false;
|
|
176
|
-
}
|
|
177
|
-
.bind (this),
|
|
178
|
-
},
|
|
179
100
|
});
|
|
180
101
|
},
|
|
181
102
|
getUserMenu: function ()
|
|
182
103
|
{
|
|
183
|
-
return this
|
|
104
|
+
return this [_userMenu];
|
|
184
105
|
},
|
|
185
106
|
setUserMenu: function (userMenu)
|
|
186
107
|
{
|
|
187
|
-
this
|
|
108
|
+
this [_userMenu] = userMenu;
|
|
188
109
|
},
|
|
189
|
-
|
|
110
|
+
createUserMenu: function ()
|
|
190
111
|
{
|
|
191
|
-
|
|
112
|
+
const userMenu = { };
|
|
113
|
+
|
|
114
|
+
if (typeof this [_userMenu] === "function")
|
|
115
|
+
{
|
|
116
|
+
const menu = this [_userMenu] ();
|
|
117
|
+
|
|
118
|
+
if ($.isPlainObject (menu))
|
|
119
|
+
{
|
|
120
|
+
for (const key in menu)
|
|
121
|
+
userMenu ["user-" + key] = menu [key];
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
return userMenu;
|
|
192
126
|
},
|
|
193
|
-
build: function (
|
|
127
|
+
build: function (event)
|
|
194
128
|
{
|
|
195
129
|
const
|
|
196
130
|
browser = this .getBrowser (),
|
|
197
131
|
activeLayer = browser .getActiveLayer (),
|
|
198
132
|
currentViewpoint = activeLayer ? activeLayer .getViewpoint () : null,
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
133
|
+
fullscreen = browser .getElement () .fullScreen ();
|
|
134
|
+
|
|
135
|
+
if (! browser .getBrowserOptions () .getContextMenu ())
|
|
136
|
+
return;
|
|
202
137
|
|
|
203
138
|
const menu = {
|
|
204
|
-
className: "x_ite-private-menu
|
|
139
|
+
className: "x_ite-private-menu",
|
|
205
140
|
items: {
|
|
141
|
+
"title": {
|
|
142
|
+
name: browser .getName () + " Browser v" + browser .getVersion (),
|
|
143
|
+
className: "context-menu-title context-menu-not-selectable",
|
|
144
|
+
},
|
|
206
145
|
"separator0": "--------",
|
|
207
146
|
"viewpoints": {
|
|
208
147
|
name: _("Viewpoints"),
|
|
209
148
|
className: "context-menu-icon x_ite-private-icon-viewpoint",
|
|
210
149
|
items: this .getViewpoints (),
|
|
211
|
-
callback: function (viewpoint)
|
|
212
|
-
{
|
|
213
|
-
if (! viewpoint)
|
|
214
|
-
return;
|
|
215
|
-
|
|
216
|
-
browser .bindViewpoint (browser .getActiveLayer (), viewpoint);
|
|
217
|
-
browser .getSurface () .focus ();
|
|
218
|
-
}
|
|
219
|
-
.bind (this, currentViewpoint),
|
|
220
|
-
},
|
|
221
|
-
"separator1": "--------",
|
|
222
|
-
"viewer": {
|
|
223
|
-
name: _(this .getViewerName (currentViewer)),
|
|
224
|
-
className: "context-menu-icon x_ite-private-icon-" + currentViewer .toLowerCase () + "-viewer",
|
|
225
|
-
callback: function (viewer)
|
|
226
|
-
{
|
|
227
|
-
browser ._viewer = viewer;
|
|
228
|
-
browser .getNotification () ._string = _(this .getViewerName (viewer));
|
|
229
|
-
browser .getSurface () .focus ();
|
|
230
|
-
}
|
|
231
|
-
.bind (this, currentViewer),
|
|
232
150
|
},
|
|
233
151
|
"available-viewers": {
|
|
234
152
|
name: _("Available Viewers"),
|
|
@@ -262,7 +180,26 @@ function ($,
|
|
|
262
180
|
.bind (this),
|
|
263
181
|
},
|
|
264
182
|
},
|
|
265
|
-
"
|
|
183
|
+
"display-rubberband": {
|
|
184
|
+
name: _("Display Rubberband"),
|
|
185
|
+
type: "checkbox",
|
|
186
|
+
selected: browser .getBrowserOption ("Rubberband"),
|
|
187
|
+
events: {
|
|
188
|
+
click: function (event)
|
|
189
|
+
{
|
|
190
|
+
const rubberband = $(event .target) .is (":checked");
|
|
191
|
+
|
|
192
|
+
browser .setBrowserOption ("Rubberband", rubberband);
|
|
193
|
+
|
|
194
|
+
if (rubberband)
|
|
195
|
+
browser .getNotification () ._string = _("Rubberband") + ": " + _("on");
|
|
196
|
+
else
|
|
197
|
+
browser .getNotification () ._string = _("Rubberband") + ": " + _("off");
|
|
198
|
+
}
|
|
199
|
+
.bind (this),
|
|
200
|
+
},
|
|
201
|
+
},
|
|
202
|
+
"separator1": "--------",
|
|
266
203
|
"primitive-quality": {
|
|
267
204
|
name: _("Primitive Quality"),
|
|
268
205
|
className: "context-menu-icon x_ite-private-icon-primitive-quality",
|
|
@@ -359,25 +296,83 @@ function ($,
|
|
|
359
296
|
},
|
|
360
297
|
},
|
|
361
298
|
},
|
|
362
|
-
"
|
|
363
|
-
name: _("
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
299
|
+
"shading": {
|
|
300
|
+
name: _("Shading"),
|
|
301
|
+
className: "context-menu-icon x_ite-private-icon-shading",
|
|
302
|
+
items: {
|
|
303
|
+
"point": {
|
|
304
|
+
name: _("Point"),
|
|
305
|
+
type: "radio",
|
|
306
|
+
radio: "shading",
|
|
307
|
+
selected: browser .getBrowserOption ("Shading") === "POINT",
|
|
308
|
+
events: {
|
|
309
|
+
click: function ()
|
|
310
|
+
{
|
|
311
|
+
browser .setBrowserOption ("Shading", "POINT");
|
|
312
|
+
browser .getNotification () ._string = _("Shading") + ": " + _("Point");
|
|
313
|
+
}
|
|
314
|
+
.bind (this),
|
|
315
|
+
},
|
|
316
|
+
},
|
|
317
|
+
"wireframe": {
|
|
318
|
+
name: _("Wireframe"),
|
|
319
|
+
type: "radio",
|
|
320
|
+
radio: "shading",
|
|
321
|
+
selected: browser .getBrowserOption ("Shading") === "WIREFRAME",
|
|
322
|
+
events: {
|
|
323
|
+
click: function ()
|
|
324
|
+
{
|
|
325
|
+
browser .setBrowserOption ("Shading", "WIREFRAME");
|
|
326
|
+
browser .getNotification () ._string = _("Shading") + ": " + _("Wireframe");
|
|
327
|
+
}
|
|
328
|
+
.bind (this),
|
|
329
|
+
},
|
|
330
|
+
},
|
|
331
|
+
"flat": {
|
|
332
|
+
name: _("Flat"),
|
|
333
|
+
type: "radio",
|
|
334
|
+
radio: "shading",
|
|
335
|
+
selected: browser .getBrowserOption ("Shading") === "FLAT",
|
|
336
|
+
events: {
|
|
337
|
+
click: function ()
|
|
338
|
+
{
|
|
339
|
+
browser .setBrowserOption ("Shading", "FLAT");
|
|
340
|
+
browser .getNotification () ._string = _("Shading") + ": " + _("Flat");
|
|
341
|
+
}
|
|
342
|
+
.bind (this),
|
|
343
|
+
},
|
|
344
|
+
},
|
|
345
|
+
"gouraud": {
|
|
346
|
+
name: _("Gouraud"),
|
|
347
|
+
type: "radio",
|
|
348
|
+
radio: "shading",
|
|
349
|
+
selected: browser .getBrowserOption ("Shading") === "GOURAUD",
|
|
350
|
+
events: {
|
|
351
|
+
click: function ()
|
|
352
|
+
{
|
|
353
|
+
browser .setBrowserOption ("Shading", "GOURAUD");
|
|
354
|
+
browser .getNotification () ._string = _("Shading") + ": " + _("Gouraud");
|
|
355
|
+
}
|
|
356
|
+
.bind (this),
|
|
357
|
+
},
|
|
358
|
+
},
|
|
359
|
+
"phong": {
|
|
360
|
+
name: _("Phong"),
|
|
361
|
+
type: "radio",
|
|
362
|
+
radio: "shading",
|
|
363
|
+
selected: browser .getBrowserOption ("Shading") === "PHONG",
|
|
364
|
+
events: {
|
|
365
|
+
click: function ()
|
|
366
|
+
{
|
|
367
|
+
browser .setBrowserOption ("Shading", "PHONG");
|
|
368
|
+
browser .getNotification () ._string = _("Shading") + ": " + _("Phong");
|
|
369
|
+
}
|
|
370
|
+
.bind (this),
|
|
371
|
+
},
|
|
372
|
+
},
|
|
379
373
|
},
|
|
380
374
|
},
|
|
375
|
+
"separator2": "--------",
|
|
381
376
|
"browser-timings": {
|
|
382
377
|
name: _("Browser Timings"),
|
|
383
378
|
type: "checkbox",
|
|
@@ -393,7 +388,9 @@ function ($,
|
|
|
393
388
|
},
|
|
394
389
|
"fullscreen": {
|
|
395
390
|
name: fullscreen ? _("Leave Fullscreen") : _("Fullscreen"),
|
|
396
|
-
className: "context-menu-icon " + (fullscreen
|
|
391
|
+
className: "context-menu-icon " + (fullscreen
|
|
392
|
+
? "x_ite-private-icon-leave-fullscreen"
|
|
393
|
+
: "x_ite-private-icon-enter-fullscreen"),
|
|
397
394
|
callback: function ()
|
|
398
395
|
{
|
|
399
396
|
browser .getElement () .toggleFullScreen ();
|
|
@@ -401,108 +398,100 @@ function ($,
|
|
|
401
398
|
.bind (this),
|
|
402
399
|
},
|
|
403
400
|
"separator3": "--------",
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
className: "context-menu-icon x_ite-private-icon-world-info",
|
|
407
|
-
callback: function ()
|
|
408
|
-
{
|
|
409
|
-
define .show ();
|
|
410
|
-
|
|
411
|
-
require (["https://cdn.jsdelivr.net/gh/showdownjs/showdown@1.9.1/dist/showdown.min.js"], function (showdown)
|
|
412
|
-
{
|
|
413
|
-
define .hide ();
|
|
401
|
+
},
|
|
402
|
+
};
|
|
414
403
|
|
|
415
|
-
|
|
404
|
+
Object .assign (menu .items, this .createUserMenu ());
|
|
416
405
|
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
406
|
+
Object .assign (menu .items, {
|
|
407
|
+
"separator4": "--------",
|
|
408
|
+
"world-info": {
|
|
409
|
+
name: _("Show World Info"),
|
|
410
|
+
className: "context-menu-icon x_ite-private-icon-world-info",
|
|
411
|
+
callback: function ()
|
|
412
|
+
{
|
|
413
|
+
define .show ();
|
|
425
414
|
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
converter .setOption ("literalMidWordUnderscores", true);
|
|
430
|
-
converter .setOption ("strikethrough", true);
|
|
431
|
-
converter .setOption ("openLinksInNewWindow", false);
|
|
415
|
+
require (["https://cdn.jsdelivr.net/gh/showdownjs/showdown@1.9.1/dist/showdown.min.js"], function (showdown)
|
|
416
|
+
{
|
|
417
|
+
define .hide ();
|
|
432
418
|
|
|
433
|
-
|
|
419
|
+
browser .getShadow () .find (".x_ite-private-world-info") .remove ();
|
|
434
420
|
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
421
|
+
const
|
|
422
|
+
converter = new showdown .Converter (),
|
|
423
|
+
priv = browser .getShadow () .find (".x_ite-private-browser"),
|
|
424
|
+
overlay = $("<div></div>") .addClass ("x_ite-private-world-info-overlay") .appendTo (priv),
|
|
425
|
+
div = $("<div></div>") .addClass ("x_ite-private-world-info") .appendTo (overlay),
|
|
426
|
+
worldInfo = browser .getExecutionContext () .getWorldInfos () [0],
|
|
427
|
+
title = worldInfo .title,
|
|
428
|
+
info = worldInfo .info;
|
|
429
|
+
|
|
430
|
+
converter .setOption ("omitExtraWLInCodeBlocks", true);
|
|
431
|
+
converter .setOption ("simplifiedAutoLink", true);
|
|
432
|
+
converter .setOption ("excludeTrailingPunctuationFromURLs", true);
|
|
433
|
+
converter .setOption ("literalMidWordUnderscores", true);
|
|
434
|
+
converter .setOption ("strikethrough", true);
|
|
435
|
+
converter .setOption ("openLinksInNewWindow", false);
|
|
436
|
+
|
|
437
|
+
$("<div></div>") .addClass ("x_ite-private-world-info-top") .text ("World Info") .appendTo (div);
|
|
438
|
+
|
|
439
|
+
if (title .length)
|
|
440
|
+
{
|
|
441
|
+
$("<div></div>") .addClass ("x_ite-private-world-info-title") .text (title) .appendTo (div);
|
|
442
|
+
}
|
|
439
443
|
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
+
for (const line of info)
|
|
445
|
+
{
|
|
446
|
+
$("<div></div>") .addClass ("x_ite-private-world-info-info") .html (converter .makeHtml (line)) .appendTo (div);
|
|
447
|
+
}
|
|
444
448
|
|
|
445
|
-
|
|
449
|
+
div .find ("a") .on ("click", function (event) { event .stopPropagation (); });
|
|
446
450
|
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
451
|
+
// Open external link in new tab.
|
|
452
|
+
div .find ("a[href^=http]") .each (function ()
|
|
453
|
+
{
|
|
454
|
+
if (this .href .indexOf (location .hostname) !== -1)
|
|
455
|
+
return;
|
|
452
456
|
|
|
453
|
-
|
|
454
|
-
|
|
457
|
+
$(this) .attr ("target", "_blank");
|
|
458
|
+
});
|
|
455
459
|
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
},
|
|
460
|
+
overlay .on ("click", function () { overlay .remove (); });
|
|
461
|
+
})
|
|
459
462
|
},
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
463
|
+
},
|
|
464
|
+
"about": {
|
|
465
|
+
name: _("About X_ITE"),
|
|
466
|
+
className: "context-menu-icon x_ite-private-icon-help-about",
|
|
467
|
+
callback: function ()
|
|
468
|
+
{
|
|
469
|
+
window .open (browser .getProviderUrl ());
|
|
467
470
|
},
|
|
468
471
|
},
|
|
469
|
-
};
|
|
470
|
-
|
|
471
|
-
if (typeof this .userMenu === "function")
|
|
472
|
-
{
|
|
473
|
-
const userMenu = this .userMenu ();
|
|
474
|
-
|
|
475
|
-
if ($.isPlainObject (userMenu))
|
|
476
|
-
{
|
|
477
|
-
Object .assign (menu .items, { "separator4": "--------" });
|
|
478
|
-
|
|
479
|
-
for (const key in userMenu)
|
|
480
|
-
menu .items ["user-" + key] = userMenu [key];
|
|
481
|
-
}
|
|
482
|
-
}
|
|
483
|
-
|
|
484
|
-
if (leftSubMenus)
|
|
485
|
-
menu .className += " x_ite-private-menu-submenus-left";
|
|
472
|
+
});
|
|
486
473
|
|
|
487
474
|
if ($.isEmptyObject (menu .items .viewpoints .items))
|
|
488
|
-
{
|
|
489
|
-
delete menu .items ["separator0"];
|
|
490
475
|
delete menu .items ["viewpoints"];
|
|
491
|
-
}
|
|
492
476
|
|
|
493
477
|
if (Object .keys (menu .items ["available-viewers"] .items) .length < 2)
|
|
494
478
|
{
|
|
495
479
|
delete menu .items ["available-viewers"];
|
|
496
480
|
}
|
|
497
481
|
|
|
498
|
-
if (!browser .getCurrentViewer () .match (/^(?:EXAMINE|FLY)$/) || (currentViewpoint
|
|
482
|
+
if (! browser .getCurrentViewer () .match (/^(?:EXAMINE|FLY)$/) || (currentViewpoint instanceof GeoViewpoint))
|
|
499
483
|
{
|
|
500
484
|
delete menu .items ["straighten-horizon"];
|
|
501
485
|
}
|
|
502
486
|
|
|
487
|
+
if (! browser .getDebug ())
|
|
488
|
+
{
|
|
489
|
+
delete menu .items ["shading"];
|
|
490
|
+
}
|
|
491
|
+
|
|
503
492
|
const worldInfo = browser .getExecutionContext () .getWorldInfos () [0];
|
|
504
493
|
|
|
505
|
-
if (!worldInfo || (worldInfo .title .length === 0 && worldInfo .info .length === 0))
|
|
494
|
+
if (! worldInfo || (worldInfo .title .length === 0 && worldInfo .info .length === 0))
|
|
506
495
|
{
|
|
507
496
|
delete menu .items ["world-info"];
|
|
508
497
|
}
|
|
@@ -599,6 +588,204 @@ function ($,
|
|
|
599
588
|
return _("None Viewer");
|
|
600
589
|
}
|
|
601
590
|
},
|
|
591
|
+
init: function (options)
|
|
592
|
+
{
|
|
593
|
+
this .show = this .createRoot .bind (this, options);
|
|
594
|
+
|
|
595
|
+
options .element .on ("contextmenu", this .show);
|
|
596
|
+
},
|
|
597
|
+
show: function (event)
|
|
598
|
+
{ },
|
|
599
|
+
hide: function (event)
|
|
600
|
+
{ },
|
|
601
|
+
createRoot: function (options, event)
|
|
602
|
+
{
|
|
603
|
+
const
|
|
604
|
+
menu = options .build (event),
|
|
605
|
+
level = 1;
|
|
606
|
+
|
|
607
|
+
if (! menu) return;
|
|
608
|
+
|
|
609
|
+
// Layer
|
|
610
|
+
|
|
611
|
+
const layer = $("<div></div>")
|
|
612
|
+
.addClass ("context-menu-layer")
|
|
613
|
+
.addClass (menu .className)
|
|
614
|
+
.appendTo (options .appendTo);
|
|
615
|
+
|
|
616
|
+
const hide = this .hide = function ()
|
|
617
|
+
{
|
|
618
|
+
delete this .hide;
|
|
619
|
+
|
|
620
|
+
layer .remove ();
|
|
621
|
+
|
|
622
|
+
ul [options .animation .hide] (options .animation .duration, function ()
|
|
623
|
+
{
|
|
624
|
+
ul .remove ();
|
|
625
|
+
|
|
626
|
+
if (options .events && typeof options .events .hide === "function")
|
|
627
|
+
options .events .hide ();
|
|
628
|
+
});
|
|
629
|
+
|
|
630
|
+
return false;
|
|
631
|
+
}
|
|
632
|
+
.bind (this);
|
|
633
|
+
|
|
634
|
+
// Menu
|
|
635
|
+
|
|
636
|
+
const
|
|
637
|
+
x = event .pageX - $(document) .scrollLeft (),
|
|
638
|
+
y = event .pageY - $(document) .scrollTop ();
|
|
639
|
+
|
|
640
|
+
const ul = $("<ul></ul>")
|
|
641
|
+
.hide ()
|
|
642
|
+
.addClass ("context-menu-list")
|
|
643
|
+
.addClass (menu .className)
|
|
644
|
+
.addClass ("context-menu-root")
|
|
645
|
+
.css ({ "left": x, "top": y })
|
|
646
|
+
.appendTo (options .appendTo);
|
|
647
|
+
|
|
648
|
+
for (const k in menu .items)
|
|
649
|
+
ul .append (this .createItem (menu .items [k], "context-menu-root", k, level + 1, hide));
|
|
650
|
+
|
|
651
|
+
ul [options .animation .show] (options .animation .duration);
|
|
652
|
+
|
|
653
|
+
// Reposition menu if to right or to low.
|
|
654
|
+
|
|
655
|
+
if (ul .offset () .left - $(document) .scrollLeft () + ul .outerWidth () > $(window) .width ())
|
|
656
|
+
ul .offset ({ "left": $(document) .scrollLeft () + Math .max (0, $(window) .width () - ul .outerWidth ()) });
|
|
657
|
+
|
|
658
|
+
if (ul .offset () .top - $(document) .scrollTop () + ul .outerHeight () > $(window) .height ())
|
|
659
|
+
ul .offset ({ "top": $(document) .scrollTop () + Math .max (0, $(window) .height () - ul .outerHeight ()) });
|
|
660
|
+
|
|
661
|
+
// Display submenus on the left or right side.
|
|
662
|
+
// If the submenu is higher than vh, add scrollbars.
|
|
663
|
+
|
|
664
|
+
ul .find ("ul") .each (function (i, e)
|
|
665
|
+
{
|
|
666
|
+
e = $(e);
|
|
667
|
+
|
|
668
|
+
const
|
|
669
|
+
width = e .outerWidth () + ul .outerWidth (),
|
|
670
|
+
position = ul .offset () .left - $(document) .scrollLeft () + width > $(window) .width () ? "right" : "left";
|
|
671
|
+
|
|
672
|
+
e .css ("width", e .outerWidth ());
|
|
673
|
+
e .css (position, e .parent () .closest ("ul") .width ());
|
|
674
|
+
|
|
675
|
+
if (e .outerHeight () >= $(window) .height ())
|
|
676
|
+
e .css ({ "max-height": "100vh", "overflow-y": "scroll" });
|
|
677
|
+
});
|
|
678
|
+
|
|
679
|
+
// If the submenu is higher than vh, reposition it.
|
|
680
|
+
|
|
681
|
+
ul .find ("li") .on ("mouseenter touchstart", function (event)
|
|
682
|
+
{
|
|
683
|
+
event .stopImmediatePropagation ();
|
|
684
|
+
|
|
685
|
+
const
|
|
686
|
+
t = $(event .target) .closest ("li"),
|
|
687
|
+
e = t .children ("ul");
|
|
688
|
+
|
|
689
|
+
if (! e .length)
|
|
690
|
+
return;
|
|
691
|
+
|
|
692
|
+
e .css ("top", "");
|
|
693
|
+
|
|
694
|
+
const bottom = e .offset () .top + e .outerHeight () - $(window) .scrollTop () - $(window) .height ();
|
|
695
|
+
|
|
696
|
+
if (bottom > 0)
|
|
697
|
+
e .offset ({ "top": e .offset () .top - bottom });
|
|
698
|
+
});
|
|
699
|
+
|
|
700
|
+
// Layer
|
|
701
|
+
|
|
702
|
+
layer .on ("click contextmenu", hide);
|
|
703
|
+
ul .on ("contextmenu", hide);
|
|
704
|
+
|
|
705
|
+
// Show
|
|
706
|
+
|
|
707
|
+
if (options .events && typeof options .events .show === "function")
|
|
708
|
+
options .events .show (ul);
|
|
709
|
+
|
|
710
|
+
return false;
|
|
711
|
+
},
|
|
712
|
+
createItem: function (item, parent, key, level, hide)
|
|
713
|
+
{
|
|
714
|
+
const li = $("<li></li>") .addClass ("context-menu-item");
|
|
715
|
+
|
|
716
|
+
switch (typeof item)
|
|
717
|
+
{
|
|
718
|
+
case "string":
|
|
719
|
+
{
|
|
720
|
+
if (item .match (/^-+$/))
|
|
721
|
+
li .addClass (["context-menu-separator", "context-menu-not-selectable"]);
|
|
722
|
+
|
|
723
|
+
break;
|
|
724
|
+
}
|
|
725
|
+
case "object":
|
|
726
|
+
{
|
|
727
|
+
if (item .className)
|
|
728
|
+
li .addClass (item .className);
|
|
729
|
+
|
|
730
|
+
switch (item .type)
|
|
731
|
+
{
|
|
732
|
+
case "radio":
|
|
733
|
+
case "checkbox":
|
|
734
|
+
{
|
|
735
|
+
const
|
|
736
|
+
label = $("<label></label>") .appendTo (li),
|
|
737
|
+
input = $("<input></input>") .appendTo (label);
|
|
738
|
+
|
|
739
|
+
input
|
|
740
|
+
.attr ("type", item .type)
|
|
741
|
+
.attr ("name", "context-menu-input-" + (item .radio || parent));
|
|
742
|
+
|
|
743
|
+
$("<span></span>") .text (item .name) .appendTo (label);
|
|
744
|
+
|
|
745
|
+
if (item .selected)
|
|
746
|
+
input .attr ("checked", "checked");
|
|
747
|
+
|
|
748
|
+
for (const k in item .events)
|
|
749
|
+
{
|
|
750
|
+
if (typeof item .events [k] === "function")
|
|
751
|
+
input .on (k, item .events [k]);
|
|
752
|
+
}
|
|
753
|
+
|
|
754
|
+
li .addClass ("context-menu-input");
|
|
755
|
+
|
|
756
|
+
break;
|
|
757
|
+
}
|
|
758
|
+
default:
|
|
759
|
+
{
|
|
760
|
+
if (item .name)
|
|
761
|
+
$("<span></span>") .text (item .name) .appendTo (li);
|
|
762
|
+
|
|
763
|
+
if (typeof item .callback === "function")
|
|
764
|
+
li .on ("click", item .callback) .on ("click", hide);
|
|
765
|
+
|
|
766
|
+
break;
|
|
767
|
+
}
|
|
768
|
+
}
|
|
769
|
+
|
|
770
|
+
break;
|
|
771
|
+
}
|
|
772
|
+
}
|
|
773
|
+
|
|
774
|
+
if (typeof item .items === "object" && level < 3)
|
|
775
|
+
{
|
|
776
|
+
const ul = $("<ul></ul>")
|
|
777
|
+
.addClass ("context-menu-list")
|
|
778
|
+
.css ({ "z-index": level })
|
|
779
|
+
.appendTo (li);
|
|
780
|
+
|
|
781
|
+
for (const k in item .items)
|
|
782
|
+
ul .append (this .createItem (item .items [k], key, k, level + 1, hide));
|
|
783
|
+
|
|
784
|
+
li .addClass ("context-menu-submenu");
|
|
785
|
+
}
|
|
786
|
+
|
|
787
|
+
return li;
|
|
788
|
+
},
|
|
602
789
|
});
|
|
603
790
|
|
|
604
791
|
return ContextMenu;
|