x_ite 5.0.2 → 6.0.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.
Files changed (340) hide show
  1. package/.vscode/settings.json +12 -5
  2. package/.vscode/tasks.json +21 -0
  3. package/Makefile +10 -15
  4. package/README.md +6 -11
  5. package/build/bin/dist.pl +0 -6
  6. package/build/bin/version.pl +1 -4
  7. package/dist/assets/components/annotation.js +2 -2
  8. package/dist/assets/components/annotation.min.js +1 -1
  9. package/dist/assets/components/cad-geometry.js +2 -2
  10. package/dist/assets/components/cad-geometry.min.js +1 -1
  11. package/dist/assets/components/cube-map-texturing.js +6 -19
  12. package/dist/assets/components/cube-map-texturing.min.js +1 -1
  13. package/dist/assets/components/dis.js +2 -2
  14. package/dist/assets/components/dis.min.js +1 -1
  15. package/dist/assets/components/event-utilities.js +3 -3
  16. package/dist/assets/components/event-utilities.min.js +1 -1
  17. package/dist/assets/components/geometry2d.js +4 -4
  18. package/dist/assets/components/geometry2d.min.js +1 -1
  19. package/dist/assets/components/geospatial.js +32 -1685
  20. package/dist/assets/components/geospatial.min.js +1 -1
  21. package/dist/assets/components/h-anim.js +70 -77
  22. package/dist/assets/components/h-anim.min.js +1 -1
  23. package/dist/assets/components/key-device-sensor.js +3 -3
  24. package/dist/assets/components/key-device-sensor.min.js +1 -1
  25. package/dist/assets/components/layout.js +38 -52
  26. package/dist/assets/components/layout.min.js +1 -1
  27. package/dist/assets/components/nurbs.js +277 -194
  28. package/dist/assets/components/nurbs.min.js +1 -1
  29. package/dist/assets/components/particle-systems.js +1918 -1658
  30. package/dist/assets/components/particle-systems.min.js +1 -1
  31. package/dist/assets/components/picking.js +33 -41
  32. package/dist/assets/components/picking.min.js +1 -1
  33. package/dist/assets/components/projective-texture-mapping.js +72 -86
  34. package/dist/assets/components/projective-texture-mapping.min.js +1 -1
  35. package/dist/assets/components/rigid-body-physics.js +36 -57
  36. package/dist/assets/components/rigid-body-physics.min.js +1 -1
  37. package/dist/assets/components/scripting.js +2 -2
  38. package/dist/assets/components/scripting.min.js +1 -1
  39. package/dist/assets/components/texturing-3d.js +26 -75
  40. package/dist/assets/components/texturing-3d.min.js +3 -3
  41. package/dist/assets/components/volume-rendering.js +10 -10
  42. package/dist/assets/components/volume-rendering.min.js +1 -1
  43. package/dist/assets/components/x_ite.js +2 -2
  44. package/dist/assets/components/x_ite.min.js +1 -1
  45. package/dist/assets/linetype/1.png +0 -0
  46. package/dist/assets/linetype/10.png +0 -0
  47. package/dist/assets/linetype/11.png +0 -0
  48. package/dist/assets/linetype/12.png +0 -0
  49. package/dist/assets/linetype/13.png +0 -0
  50. package/dist/assets/linetype/14.png +0 -0
  51. package/dist/assets/linetype/15.png +0 -0
  52. package/dist/assets/linetype/16.png +0 -0
  53. package/dist/assets/linetype/2.png +0 -0
  54. package/dist/assets/linetype/3.png +0 -0
  55. package/dist/assets/linetype/4.png +0 -0
  56. package/dist/assets/linetype/5.png +0 -0
  57. package/dist/assets/linetype/6.png +0 -0
  58. package/dist/assets/linetype/7.png +0 -0
  59. package/dist/assets/linetype/8.png +0 -0
  60. package/dist/assets/linetype/9.png +0 -0
  61. package/dist/assets/shaders/webgl1/Line.fs +0 -21
  62. package/dist/assets/shaders/webgl1/Line.vs +0 -10
  63. package/dist/assets/shaders/webgl1/PBR.vs +1 -1
  64. package/dist/assets/shaders/webgl2/Depth.vs +29 -1
  65. package/dist/assets/shaders/webgl2/Gouraud.vs +31 -3
  66. package/dist/assets/shaders/webgl2/Line.fs +24 -12
  67. package/dist/assets/shaders/webgl2/Line.vs +36 -11
  68. package/dist/assets/shaders/webgl2/LineTransform.fs +4 -0
  69. package/dist/assets/shaders/webgl2/LineTransform.vs +57 -0
  70. package/dist/assets/shaders/webgl2/PBR.vs +35 -7
  71. package/dist/assets/shaders/webgl2/Phong.vs +31 -3
  72. package/dist/assets/shaders/webgl2/Point.vs +29 -1
  73. package/dist/assets/shaders/webgl2/Unlit.vs +31 -3
  74. package/dist/example.html +6 -6
  75. package/dist/x_ite.css +180 -208
  76. package/dist/x_ite.js +16477 -16629
  77. package/dist/x_ite.min.js +17 -17
  78. package/dist/x_ite.zip +0 -0
  79. package/docs/404.md +6 -0
  80. package/docs/Accessing-the-External-Browser.md +20 -14
  81. package/docs/Browser-Support.md +6 -0
  82. package/docs/Custom-Shaders.md +17 -24
  83. package/docs/Features.md +7 -1
  84. package/docs/Gemfile +44 -0
  85. package/docs/Gemfile.lock +122 -0
  86. package/docs/Glossary.md +6 -0
  87. package/docs/How-To-Configure-Your-Web-Server.md +6 -0
  88. package/docs/Supported-Nodes.md +9 -1
  89. package/docs/What's-New.md +31 -0
  90. package/docs/XHTML-DOM-Integration.md +6 -0
  91. package/docs/_config.yml +1 -1
  92. package/docs/assets/css/main.scss +26 -0
  93. package/docs/index.md +38 -46
  94. package/docs/reference/Browser-Services.md +9 -3
  95. package/docs/reference/Constants-Services.md +6 -0
  96. package/docs/reference/ECMAScript-Object-and-Function-Definitions.md +6 -0
  97. package/docs/reference/Field-Services-and-Objects.md +6 -0
  98. package/docs/reference/Prototype-Services.md +6 -0
  99. package/docs/reference/Route-Services.md +6 -0
  100. package/docs/reference/Scene-Services.md +8 -2
  101. package/docs/reference/Script-Node-Authoring-Interface.md +7 -1
  102. package/docs/tutorials/Adding-backgrounds.md +6 -0
  103. package/docs/tutorials/Adding-fog.md +6 -0
  104. package/docs/tutorials/Adding-sound.md +6 -0
  105. package/docs/tutorials/Animating-transforms.md +6 -0
  106. package/docs/tutorials/Basic-Nodes.md +6 -0
  107. package/docs/tutorials/Building-a-X3D-world.md +6 -0
  108. package/docs/tutorials/Building-elevation-grids.md +6 -0
  109. package/docs/tutorials/Building-extruded-shapes.md +6 -0
  110. package/docs/tutorials/Building-primitive-shapes.md +6 -0
  111. package/docs/tutorials/Building-shapes-out-of-points,-lines,-and-faces.md +6 -0
  112. package/docs/tutorials/Controlling-appearance-with-materials.md +6 -0
  113. package/docs/tutorials/Controlling-color-on-coordinate-based-geometry.md +6 -0
  114. package/docs/tutorials/Controlling-detail.md +6 -0
  115. package/docs/tutorials/Controlling-how-textures-are-mapped.md +6 -0
  116. package/docs/tutorials/Controlling-navigation.md +6 -0
  117. package/docs/tutorials/Controlling-shading-on-coordinate-based-geometry.md +6 -0
  118. package/docs/tutorials/Controlling-the-viewpoint.md +6 -0
  119. package/docs/tutorials/Creating-new-node-types.md +6 -0
  120. package/docs/tutorials/Grouping-nodes.md +6 -0
  121. package/docs/tutorials/Hello,-World!.md +6 -0
  122. package/docs/tutorials/Improving-Performance.md +6 -0
  123. package/docs/tutorials/Increasing-Rendering-Speed.md +6 -0
  124. package/docs/tutorials/Introducing-X3D.md +6 -0
  125. package/docs/tutorials/Introducing-animation.md +6 -0
  126. package/docs/tutorials/Introducing-script-use.md +6 -0
  127. package/docs/tutorials/Lighting-your-world.md +6 -0
  128. package/docs/tutorials/Mapping-textures.md +6 -0
  129. package/docs/tutorials/Naming-nodes.md +6 -0
  130. package/docs/tutorials/Providing-information-about-your-world.md +6 -0
  131. package/docs/tutorials/Sensing-the-viewer.md +6 -0
  132. package/docs/tutorials/Sensing-viewer-actions.md +6 -0
  133. package/docs/tutorials/Transforming-Shapes.md +6 -0
  134. package/docs/tutorials/Writing-program-scripts-with-ECMAScript.md +6 -0
  135. package/docs/tutorials/index.md +6 -0
  136. package/package.json +6 -7
  137. package/src/assets/components/geometry2d.js +1 -1
  138. package/src/assets/components/key-device-sensor.js +1 -1
  139. package/src/assets/components/layout.js +1 -1
  140. package/src/assets/components/particle-systems.js +1 -1
  141. package/src/assets/components/volume-rendering.js +1 -1
  142. package/src/assets/linetype/1.png +0 -0
  143. package/src/assets/linetype/10.png +0 -0
  144. package/src/assets/linetype/11.png +0 -0
  145. package/src/assets/linetype/12.png +0 -0
  146. package/src/assets/linetype/13.png +0 -0
  147. package/src/assets/linetype/14.png +0 -0
  148. package/src/assets/linetype/15.png +0 -0
  149. package/src/assets/linetype/16.png +0 -0
  150. package/src/assets/linetype/2.png +0 -0
  151. package/src/assets/linetype/3.png +0 -0
  152. package/src/assets/linetype/4.png +0 -0
  153. package/src/assets/linetype/5.png +0 -0
  154. package/src/assets/linetype/6.png +0 -0
  155. package/src/assets/linetype/7.png +0 -0
  156. package/src/assets/linetype/8.png +0 -0
  157. package/src/assets/linetype/9.png +0 -0
  158. package/src/assets/shaders/Types.glsl +1 -9
  159. package/src/assets/shaders/webgl1/Line.fs +3 -28
  160. package/src/assets/shaders/webgl1/Line.vs +5 -19
  161. package/src/assets/shaders/webgl1/PBR.vs +1 -1
  162. package/src/assets/shaders/webgl1/Point.vs +2 -3
  163. package/src/assets/shaders/webgl2/Depth.vs +4 -1
  164. package/src/assets/shaders/webgl2/Gouraud.vs +5 -3
  165. package/src/assets/shaders/webgl2/Line.fs +11 -17
  166. package/src/assets/shaders/webgl2/Line.vs +16 -20
  167. package/src/assets/shaders/webgl2/LineTransform.fs +6 -0
  168. package/src/assets/shaders/webgl2/LineTransform.vs +77 -0
  169. package/src/assets/shaders/webgl2/PBR.vs +10 -7
  170. package/src/assets/shaders/webgl2/Phong.vs +6 -3
  171. package/src/assets/shaders/webgl2/Point.vs +6 -6
  172. package/src/assets/shaders/webgl2/Unlit.vs +6 -3
  173. package/src/assets/shaders/webgl2/include/Line2.glsl +20 -0
  174. package/src/assets/shaders/webgl2/include/Particle.glsl +36 -0
  175. package/src/example.html +6 -6
  176. package/src/standard/Math/Algorithm.js +12 -28
  177. package/src/standard/Math/Geometry/Plane3.js +0 -2
  178. package/src/standard/Math/Geometry/ViewVolume.js +88 -83
  179. package/src/standard/Math/Numbers/Color3.js +6 -0
  180. package/src/standard/Math/Numbers/Color4.js +7 -0
  181. package/src/standard/Math/Numbers/Complex.js +5 -0
  182. package/src/standard/Math/Numbers/Matrix2.js +20 -2
  183. package/src/standard/Math/Numbers/Matrix3.js +129 -110
  184. package/src/standard/Math/Numbers/Matrix4.js +138 -119
  185. package/src/standard/Math/Numbers/Quaternion.js +7 -0
  186. package/src/standard/Math/Numbers/Rotation4.js +7 -0
  187. package/src/standard/Math/Numbers/Vector2.js +8 -5
  188. package/src/standard/Math/Numbers/Vector3.js +16 -10
  189. package/src/standard/Math/Numbers/Vector4.js +12 -7
  190. package/src/standard/Math/Utility/BVH.js +45 -17
  191. package/src/tests.js +6 -1
  192. package/src/x_ite/Base/X3DBaseNode.js +22 -11
  193. package/src/x_ite/Base/X3DField.js +1 -1
  194. package/src/x_ite/Browser/Core/BrowserOptions.js +2 -2
  195. package/src/x_ite/Browser/Core/BrowserTimings.js +4 -2
  196. package/src/x_ite/Browser/Core/Context.js +185 -0
  197. package/src/x_ite/Browser/Core/ContextMenu.js +299 -193
  198. package/src/x_ite/Browser/Core/Notification.js +1 -0
  199. package/src/x_ite/Browser/Core/X3DCoreContext.js +35 -146
  200. package/src/x_ite/Browser/Layout/ScreenText.js +11 -4
  201. package/src/x_ite/Browser/Layout/X3DLayoutContext.js +4 -15
  202. package/src/x_ite/Browser/Navigation/ExamineViewer.js +12 -19
  203. package/src/x_ite/Browser/Navigation/LookAtViewer.js +0 -3
  204. package/src/x_ite/Browser/Navigation/PlaneViewer.js +0 -3
  205. package/src/x_ite/Browser/Navigation/X3DFlyViewer.js +14 -7
  206. package/src/x_ite/Browser/Navigation/X3DViewer.js +12 -20
  207. package/src/x_ite/Browser/Networking/X3DNetworkingContext.js +11 -7
  208. package/src/x_ite/Browser/ParticleSystems/BVH.glsl +183 -0
  209. package/src/x_ite/Browser/ParticleSystems/Box3.glsl +47 -0
  210. package/src/x_ite/Browser/ParticleSystems/GeometryTypes.js +66 -0
  211. package/src/x_ite/Browser/ParticleSystems/Line3.glsl +55 -0
  212. package/src/x_ite/Browser/ParticleSystems/Plane3.glsl +160 -0
  213. package/src/x_ite/Browser/PointingDeviceSensor/PointingDevice.js +27 -3
  214. package/src/x_ite/Browser/PointingDeviceSensor/X3DPointingDeviceSensorContext.js +37 -37
  215. package/src/x_ite/Browser/Rendering/X3DRenderingContext.js +19 -13
  216. package/src/x_ite/Browser/Shaders/Shader.js +33 -12
  217. package/src/x_ite/Browser/Shaders/ShaderSource.js +6 -0
  218. package/src/x_ite/Browser/Shaders/ShaderTest.js +16 -10
  219. package/src/x_ite/Browser/Shape/X3DShapeContext.js +50 -9
  220. package/src/x_ite/Browser/Text/X3DTextContext.js +4 -13
  221. package/src/x_ite/Browser/Texturing/X3DTexturingContext.js +23 -33
  222. package/src/x_ite/Browser/Texturing3D/DICOMParser.js +2 -2
  223. package/src/x_ite/Browser/Time/X3DTimeContext.js +3 -1
  224. package/src/x_ite/Browser/VERSION.js +1 -1
  225. package/src/x_ite/Browser/X3DBrowser.js +7 -6
  226. package/src/x_ite/Browser/X3DBrowserContext.js +35 -10
  227. package/src/x_ite/Components/Core/X3DNode.js +4 -0
  228. package/src/x_ite/Components/Core/X3DPrototypeInstance.js +0 -2
  229. package/src/x_ite/Components/CubeMapTexturing/ComposedCubeMapTexture.js +3 -4
  230. package/src/x_ite/Components/CubeMapTexturing/GeneratedCubeMapTexture.js +1 -12
  231. package/src/x_ite/Components/CubeMapTexturing/ImageCubeMapTexture.js +0 -1
  232. package/src/x_ite/Components/EnvironmentalEffects/TextureBackground.js +1 -1
  233. package/src/x_ite/Components/EnvironmentalEffects/X3DBackgroundNode.js +76 -77
  234. package/src/x_ite/Components/EnvironmentalEffects/X3DFogObject.js +2 -9
  235. package/src/x_ite/Components/EnvironmentalSensor/ProximitySensor.js +51 -65
  236. package/src/x_ite/Components/EventUtilities/X3DSequencerNode.js +1 -1
  237. package/src/x_ite/Components/Followers/X3DChaserNode.js +18 -32
  238. package/src/x_ite/Components/Followers/X3DDamperNode.js +1 -6
  239. package/src/x_ite/Components/Geometry2D/TriangleSet2D.js +1 -1
  240. package/src/x_ite/Components/Geometry3D/ElevationGrid.js +12 -4
  241. package/src/x_ite/Components/Geometry3D/IndexedFaceSet.js +4 -4
  242. package/src/x_ite/Components/Geospatial/GeoCoordinate.js +10 -27
  243. package/src/x_ite/Components/Geospatial/GeoPositionInterpolator.js +5 -10
  244. package/src/x_ite/Components/Geospatial/GeoTouchSensor.js +9 -16
  245. package/src/x_ite/Components/Geospatial/GeoTransform.js +6 -18
  246. package/src/x_ite/Components/Geospatial/X3DGeospatialObject.js +20 -27
  247. package/src/x_ite/Components/Grouping/X3DGroupingNode.js +8 -8
  248. package/src/x_ite/Components/Grouping/X3DTransformNode.js +0 -4
  249. package/src/x_ite/Components/HAnim/HAnimHumanoid.js +68 -75
  250. package/src/x_ite/Components/Interpolation/OrientationInterpolator.js +4 -11
  251. package/src/x_ite/Components/Interpolation/X3DInterpolatorNode.js +1 -1
  252. package/src/x_ite/Components/Layout/LayoutGroup.js +4 -9
  253. package/src/x_ite/Components/Layout/ScreenFontStyle.js +1 -1
  254. package/src/x_ite/Components/Layout/ScreenGroup.js +18 -23
  255. package/src/x_ite/Components/Lighting/DirectionalLight.js +28 -36
  256. package/src/x_ite/Components/Lighting/PointLight.js +32 -47
  257. package/src/x_ite/Components/Lighting/SpotLight.js +33 -48
  258. package/src/x_ite/Components/Navigation/Billboard.js +49 -56
  259. package/src/x_ite/Components/Navigation/LOD.js +1 -1
  260. package/src/x_ite/Components/Navigation/X3DViewpointNode.js +82 -111
  261. package/src/x_ite/Components/Networking/Anchor.js +10 -4
  262. package/src/x_ite/Components/ParticleSystems/BoundedPhysicsModel.js +6 -6
  263. package/src/x_ite/Components/ParticleSystems/ConeEmitter.js +44 -36
  264. package/src/x_ite/Components/ParticleSystems/ExplosionEmitter.js +26 -17
  265. package/src/x_ite/Components/ParticleSystems/ForcePhysicsModel.js +20 -7
  266. package/src/x_ite/Components/ParticleSystems/ParticleSystem.js +461 -876
  267. package/src/x_ite/Components/ParticleSystems/PointEmitter.js +39 -35
  268. package/src/x_ite/Components/ParticleSystems/PolylineEmitter.js +112 -128
  269. package/src/x_ite/Components/ParticleSystems/SurfaceEmitter.js +105 -112
  270. package/src/x_ite/Components/ParticleSystems/VolumeEmitter.js +138 -176
  271. package/src/x_ite/Components/ParticleSystems/WindPhysicsModel.js +16 -11
  272. package/src/x_ite/Components/ParticleSystems/X3DParticleEmitterNode.js +807 -217
  273. package/src/x_ite/Components/Picking/LinePickSensor.js +31 -39
  274. package/src/x_ite/Components/PointingDeviceSensor/CylinderSensor.js +90 -107
  275. package/src/x_ite/Components/PointingDeviceSensor/PlaneSensor.js +48 -55
  276. package/src/x_ite/Components/PointingDeviceSensor/SphereSensor.js +53 -70
  277. package/src/x_ite/Components/PointingDeviceSensor/TouchSensor.js +8 -15
  278. package/src/x_ite/Components/ProjectiveTextureMapping/TextureProjectorParallel.js +43 -50
  279. package/src/x_ite/Components/ProjectiveTextureMapping/TextureProjectorPerspective.js +32 -39
  280. package/src/x_ite/Components/Rendering/ClipPlane.js +3 -11
  281. package/src/x_ite/Components/Rendering/Color.js +12 -37
  282. package/src/x_ite/Components/Rendering/ColorRGBA.js +13 -38
  283. package/src/x_ite/Components/Rendering/IndexedLineSet.js +12 -4
  284. package/src/x_ite/Components/Rendering/LineSet.js +21 -13
  285. package/src/x_ite/Components/Rendering/PointSet.js +21 -13
  286. package/src/x_ite/Components/Rendering/X3DColorNode.js +13 -0
  287. package/src/x_ite/Components/Rendering/X3DComposedGeometryNode.js +13 -5
  288. package/src/x_ite/Components/Rendering/X3DGeometryNode.js +248 -325
  289. package/src/x_ite/Components/Rendering/X3DLineGeometryNode.js +305 -134
  290. package/src/x_ite/Components/Rendering/X3DPointGeometryNode.js +99 -122
  291. package/src/x_ite/Components/RigidBodyPhysics/DoubleAxisHingeJoint.js +24 -38
  292. package/src/x_ite/Components/RigidBodyPhysics/SingleAxisHingeJoint.js +10 -17
  293. package/src/x_ite/Components/Shaders/ComposedShader.js +35 -75
  294. package/src/x_ite/Components/Shaders/FloatVertexAttribute.js +5 -15
  295. package/src/x_ite/Components/Shaders/Matrix3VertexAttribute.js +7 -24
  296. package/src/x_ite/Components/Shaders/Matrix4VertexAttribute.js +7 -24
  297. package/src/x_ite/Components/Shaders/ShaderPart.js +1 -10
  298. package/src/x_ite/Components/Shaders/X3DProgrammableShaderObject.js +219 -209
  299. package/src/x_ite/Components/Shaders/X3DShaderNode.js +1 -1
  300. package/src/x_ite/Components/Shaders/X3DVertexAttributeNode.js +23 -1
  301. package/src/x_ite/Components/Shape/Appearance.js +12 -0
  302. package/src/x_ite/Components/Shape/FillProperties.js +12 -1
  303. package/src/x_ite/Components/Shape/LineProperties.js +33 -1
  304. package/src/x_ite/Components/Shape/PointProperties.js +23 -1
  305. package/src/x_ite/Components/Shape/Shape.js +27 -34
  306. package/src/x_ite/Components/Sound/Sound.js +30 -40
  307. package/src/x_ite/Components/Text/Text.js +6 -20
  308. package/src/x_ite/Components/Texturing/TextureCoordinate.js +5 -26
  309. package/src/x_ite/Components/Texturing/TextureProperties.js +4 -4
  310. package/src/x_ite/Components/Texturing/X3DSingleTextureCoordinateNode.js +21 -0
  311. package/src/x_ite/Components/Texturing/X3DSingleTextureNode.js +5 -4
  312. package/src/x_ite/Components/Texturing/X3DTexture2DNode.js +24 -33
  313. package/src/x_ite/Components/Texturing3D/TextureCoordinate3D.js +5 -26
  314. package/src/x_ite/Components/Texturing3D/TextureCoordinate4D.js +5 -26
  315. package/src/x_ite/Components/Texturing3D/X3DTexture3DNode.js +12 -19
  316. package/src/x_ite/Components/VolumeRendering/X3DVolumeDataNode.js +7 -7
  317. package/src/x_ite/Components.js +2 -2
  318. package/src/x_ite/Fallback.js +9 -3
  319. package/src/x_ite/Fields/SFColor.js +4 -0
  320. package/src/x_ite/Fields/SFColorRGBA.js +4 -0
  321. package/src/x_ite/Fields/SFMatrixPrototypeTemplate.js +4 -0
  322. package/src/x_ite/Fields/SFRotation.js +4 -0
  323. package/src/x_ite/Fields/SFString.js +4 -0
  324. package/src/x_ite/Fields/SFVecPrototypeTemplate.js +4 -0
  325. package/src/x_ite/Parser/XMLParser.js +1 -1
  326. package/src/x_ite/Rendering/TextureBuffer.js +43 -36
  327. package/src/x_ite/Rendering/VertexArray.js +101 -0
  328. package/src/x_ite/Rendering/X3DRenderObject.js +123 -144
  329. package/src/x_ite/X3D.js +32 -26
  330. package/src/x_ite.config.js +0 -5
  331. package/src/x_ite.css +200 -162
  332. package/src/x_ite.html +26 -10
  333. package/src/x_ite.js +42 -0
  334. package/x_ite.min.html +26 -10
  335. package/dist/assets/hatching/0.png +0 -0
  336. package/dist/assets/linetype/0.png +0 -0
  337. package/src/assets/hatching/0.png +0 -0
  338. package/src/assets/linetype/0.png +0 -0
  339. package/src/spinner.css +0 -67
  340. 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 .userMenu = null;
68
- this .active = false;
71
+ this [_userMenu] = null;
69
72
  }
70
73
 
71
74
  ContextMenu .prototype = Object .assign (Object .create (X3DBaseNode .prototype),
@@ -89,151 +92,67 @@ function ($,
89
92
 
90
93
  const browser = this .getBrowser ();
91
94
 
92
- if (! browser .getBrowserOptions () .getContextMenu ())
93
- return;
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 .userMenu;
104
+ return this [_userMenu];
184
105
  },
185
106
  setUserMenu: function (userMenu)
186
107
  {
187
- this .userMenu = userMenu;
108
+ this [_userMenu] = userMenu;
188
109
  },
189
- getActive: function ()
110
+ createUserMenu: function ()
190
111
  {
191
- return this .active;
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 (trigger, event)
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
- currentViewer = browser ._viewer .getValue (),
200
- fullscreen = browser .getElement () .fullScreen (),
201
- leftSubMenus = $(document) .width () - event .pageX < 370;
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 x_ite-private-menu-title",
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"),
235
153
  items: this .getAvailableViewers (),
236
154
  },
155
+ "separator1": "--------",
237
156
  "straighten-horizon": {
238
157
  name: _("Straighten Horizon"),
239
158
  type: "checkbox",
@@ -393,7 +312,9 @@ function ($,
393
312
  },
394
313
  "fullscreen": {
395
314
  name: fullscreen ? _("Leave Fullscreen") : _("Fullscreen"),
396
- className: "context-menu-icon " + (fullscreen ? "x_ite-private-icon-leave-fullscreen" : "x_ite-private-icon-fullscreen"),
315
+ className: "context-menu-icon " + (fullscreen
316
+ ? "x_ite-private-icon-leave-fullscreen"
317
+ : "x_ite-private-icon-enter-fullscreen"),
397
318
  callback: function ()
398
319
  {
399
320
  browser .getElement () .toggleFullScreen ();
@@ -401,108 +322,95 @@ function ($,
401
322
  .bind (this),
402
323
  },
403
324
  "separator3": "--------",
404
- "world-info": {
405
- name: _("Show World Info"),
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 ();
325
+ },
326
+ };
414
327
 
415
- browser .getElement () .find (".x_ite-private-world-info") .remove ();
328
+ Object .assign (menu .items, this .createUserMenu ());
416
329
 
417
- const
418
- converter = new showdown .Converter (),
419
- priv = browser .getElement () .find (".x_ite-private-browser"),
420
- overlay = $("<div></div>") .addClass ("x_ite-private-world-info-overlay") .appendTo (priv),
421
- div = $("<div></div>") .addClass ("x_ite-private-world-info") .appendTo (overlay),
422
- worldInfo = browser .getExecutionContext () .getWorldInfos () [0],
423
- title = worldInfo .title,
424
- info = worldInfo .info;
330
+ Object .assign (menu .items, {
331
+ "separator4": "--------",
332
+ "world-info": {
333
+ name: _("Show World Info"),
334
+ className: "context-menu-icon x_ite-private-icon-world-info",
335
+ callback: function ()
336
+ {
337
+ define .show ();
425
338
 
426
- converter .setOption ("omitExtraWLInCodeBlocks", true);
427
- converter .setOption ("simplifiedAutoLink", true);
428
- converter .setOption ("excludeTrailingPunctuationFromURLs", true);
429
- converter .setOption ("literalMidWordUnderscores", true);
430
- converter .setOption ("strikethrough", true);
431
- converter .setOption ("openLinksInNewWindow", false);
339
+ require (["https://cdn.jsdelivr.net/gh/showdownjs/showdown@1.9.1/dist/showdown.min.js"], function (showdown)
340
+ {
341
+ define .hide ();
432
342
 
433
- $("<div></div>") .addClass ("x_ite-private-world-info-top") .text ("World Info") .appendTo (div);
343
+ browser .getShadow () .find (".x_ite-private-world-info") .remove ();
434
344
 
435
- if (title .length)
436
- {
437
- $("<div></div>") .addClass ("x_ite-private-world-info-title") .text (title) .appendTo (div);
438
- }
345
+ const
346
+ converter = new showdown .Converter (),
347
+ priv = browser .getShadow () .find (".x_ite-private-browser"),
348
+ overlay = $("<div></div>") .addClass ("x_ite-private-world-info-overlay") .appendTo (priv),
349
+ div = $("<div></div>") .addClass ("x_ite-private-world-info") .appendTo (overlay),
350
+ worldInfo = browser .getExecutionContext () .getWorldInfos () [0],
351
+ title = worldInfo .title,
352
+ info = worldInfo .info;
353
+
354
+ converter .setOption ("omitExtraWLInCodeBlocks", true);
355
+ converter .setOption ("simplifiedAutoLink", true);
356
+ converter .setOption ("excludeTrailingPunctuationFromURLs", true);
357
+ converter .setOption ("literalMidWordUnderscores", true);
358
+ converter .setOption ("strikethrough", true);
359
+ converter .setOption ("openLinksInNewWindow", false);
360
+
361
+ $("<div></div>") .addClass ("x_ite-private-world-info-top") .text ("World Info") .appendTo (div);
362
+
363
+ if (title .length)
364
+ {
365
+ $("<div></div>") .addClass ("x_ite-private-world-info-title") .text (title) .appendTo (div);
366
+ }
439
367
 
440
- for (const line of info)
441
- {
442
- $("<div></div>") .addClass ("x_ite-private-world-info-info") .html (converter .makeHtml (line)) .appendTo (div);
443
- }
368
+ for (const line of info)
369
+ {
370
+ $("<div></div>") .addClass ("x_ite-private-world-info-info") .html (converter .makeHtml (line)) .appendTo (div);
371
+ }
444
372
 
445
- div .find ("a") .on ("click", function (event) { event .stopPropagation (); });
373
+ div .find ("a") .on ("click", function (event) { event .stopPropagation (); });
446
374
 
447
- // Open external link in new tab.
448
- div .find ("a[href^=http]") .each (function ()
449
- {
450
- if (this .href .indexOf (location .hostname) !== -1)
451
- return;
375
+ // Open external link in new tab.
376
+ div .find ("a[href^=http]") .each (function ()
377
+ {
378
+ if (this .href .indexOf (location .hostname) !== -1)
379
+ return;
452
380
 
453
- $(this) .attr ("target", "_blank");
454
- });
381
+ $(this) .attr ("target", "_blank");
382
+ });
455
383
 
456
- overlay .on ("click", function () { overlay .remove (); });
457
- })
458
- },
384
+ overlay .on ("click", function () { overlay .remove (); });
385
+ })
459
386
  },
460
- "about": {
461
- name: _("About X_ITE"),
462
- className: "context-menu-icon x_ite-private-icon-help-about",
463
- callback: function ()
464
- {
465
- window .open (browser .getProviderUrl ());
466
- },
387
+ },
388
+ "about": {
389
+ name: _("About X_ITE"),
390
+ className: "context-menu-icon x_ite-private-icon-help-about",
391
+ callback: function ()
392
+ {
393
+ window .open (browser .getProviderUrl ());
467
394
  },
468
395
  },
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";
396
+ });
486
397
 
487
398
  if ($.isEmptyObject (menu .items .viewpoints .items))
488
- {
489
- delete menu .items ["separator0"];
490
399
  delete menu .items ["viewpoints"];
491
- }
492
400
 
493
401
  if (Object .keys (menu .items ["available-viewers"] .items) .length < 2)
494
402
  {
495
403
  delete menu .items ["available-viewers"];
496
404
  }
497
405
 
498
- if (!browser .getCurrentViewer () .match (/^(?:EXAMINE|FLY)$/) || (currentViewpoint && currentViewpoint .getTypeName () === "GeoViewpoint"))
406
+ if (! browser .getCurrentViewer () .match (/^(?:EXAMINE|FLY)$/) || (currentViewpoint instanceof GeoViewpoint))
499
407
  {
500
408
  delete menu .items ["straighten-horizon"];
501
409
  }
502
410
 
503
411
  const worldInfo = browser .getExecutionContext () .getWorldInfos () [0];
504
412
 
505
- if (!worldInfo || (worldInfo .title .length === 0 && worldInfo .info .length === 0))
413
+ if (! worldInfo || (worldInfo .title .length === 0 && worldInfo .info .length === 0))
506
414
  {
507
415
  delete menu .items ["world-info"];
508
416
  }
@@ -599,6 +507,204 @@ function ($,
599
507
  return _("None Viewer");
600
508
  }
601
509
  },
510
+ init: function (options)
511
+ {
512
+ this .show = this .createRoot .bind (this, options);
513
+
514
+ options .element .on ("contextmenu", this .show);
515
+ },
516
+ show: function (event)
517
+ { },
518
+ hide: function (event)
519
+ { },
520
+ createRoot: function (options, event)
521
+ {
522
+ const
523
+ menu = options .build (event),
524
+ level = 1;
525
+
526
+ if (! menu) return;
527
+
528
+ // Layer
529
+
530
+ const layer = $("<div></div>")
531
+ .addClass ("context-menu-layer")
532
+ .addClass (menu .className)
533
+ .appendTo (options .appendTo);
534
+
535
+ const hide = this .hide = function ()
536
+ {
537
+ delete this .hide;
538
+
539
+ layer .remove ();
540
+
541
+ ul [options .animation .hide] (options .animation .duration, function ()
542
+ {
543
+ ul .remove ();
544
+
545
+ if (options .events && typeof options .events .hide === "function")
546
+ options .events .hide ();
547
+ });
548
+
549
+ return false;
550
+ }
551
+ .bind (this);
552
+
553
+ // Menu
554
+
555
+ const
556
+ x = event .pageX - $(document) .scrollLeft (),
557
+ y = event .pageY - $(document) .scrollTop ();
558
+
559
+ const ul = $("<ul></ul>")
560
+ .hide ()
561
+ .addClass ("context-menu-list")
562
+ .addClass (menu .className)
563
+ .addClass ("context-menu-root")
564
+ .css ({ "left": x, "top": y })
565
+ .appendTo (layer);
566
+
567
+ for (const k in menu .items)
568
+ ul .append (this .createItem (menu .items [k], "context-menu-root", k, level + 1, hide));
569
+
570
+ ul [options .animation .show] (options .animation .duration);
571
+
572
+ // Reposition menu if to right or to low.
573
+
574
+ if (ul .offset () .left - $(document) .scrollLeft () + ul .outerWidth () > $(window) .width ())
575
+ ul .offset ({ "left": $(document) .scrollLeft () + Math .max (0, $(window) .width () - ul .outerWidth ()) });
576
+
577
+ if (ul .offset () .top - $(document) .scrollTop () + ul .outerHeight () > $(window) .height ())
578
+ ul .offset ({ "top": $(document) .scrollTop () + Math .max (0, $(window) .height () - ul .outerHeight ()) });
579
+
580
+ // Display submenus on the left or right side.
581
+ // If the submenu is higher than vh, add scrollbars.
582
+
583
+ ul .find ("ul") .each (function (i, e)
584
+ {
585
+ e = $(e);
586
+
587
+ const
588
+ width = e .outerWidth () + ul .outerWidth (),
589
+ position = ul .offset () .left - $(document) .scrollLeft () + width > $(window) .width () ? "right" : "left";
590
+
591
+ e .css ("width", e .outerWidth ());
592
+ e .css (position, e .parent () .closest ("ul") .width ());
593
+
594
+ if (e .outerHeight () >= $(window) .height ())
595
+ e .css ({ "max-height": "100vh", "overflow-y": "scroll" });
596
+ });
597
+
598
+ // If the submenu is higher than vh, reposition it.
599
+
600
+ ul .find ("li") .on ("mouseenter touchstart", function (event)
601
+ {
602
+ event .stopImmediatePropagation ();
603
+
604
+ const
605
+ t = $(event .target) .closest ("li"),
606
+ e = t .children ("ul");
607
+
608
+ if (! e .length)
609
+ return;
610
+
611
+ e .css ("top", "");
612
+
613
+ const bottom = e .offset () .top + e .outerHeight () - $(window) .scrollTop () - $(window) .height ();
614
+
615
+ if (bottom > 0)
616
+ e .offset ({ "top": e .offset () .top - bottom });
617
+ });
618
+
619
+ // Layer
620
+
621
+ layer .on ("click contextmenu", hide);
622
+ ul .on ("contextmenu", hide);
623
+
624
+ // Show
625
+
626
+ if (options .events && typeof options .events .show === "function")
627
+ options .events .show (ul);
628
+
629
+ return false;
630
+ },
631
+ createItem: function (item, parent, key, level, hide)
632
+ {
633
+ const li = $("<li></li>") .addClass ("context-menu-item");
634
+
635
+ switch (typeof item)
636
+ {
637
+ case "string":
638
+ {
639
+ if (item .match (/^-+$/))
640
+ li .addClass (["context-menu-separator", "context-menu-not-selectable"]);
641
+
642
+ break;
643
+ }
644
+ case "object":
645
+ {
646
+ if (item .className)
647
+ li .addClass (item .className);
648
+
649
+ switch (item .type)
650
+ {
651
+ case "radio":
652
+ case "checkbox":
653
+ {
654
+ const
655
+ label = $("<label></label>") .appendTo (li),
656
+ input = $("<input></input>") .appendTo (label);
657
+
658
+ input
659
+ .attr ("type", item .type)
660
+ .attr ("name", "context-menu-input-" + parent);
661
+
662
+ $("<span></span>") .text (item .name) .appendTo (label);
663
+
664
+ if (item .selected)
665
+ input .attr ("checked", "checked");
666
+
667
+ for (const key in item .events)
668
+ {
669
+ if (typeof item .events [key] === "function")
670
+ input .on (key, item .events [key]);
671
+ }
672
+
673
+ li .addClass ("context-menu-input");
674
+
675
+ break;
676
+ }
677
+ default:
678
+ {
679
+ if (item .name)
680
+ $("<span></span>") .text (item .name) .appendTo (li);
681
+
682
+ if (typeof item .callback === "function")
683
+ li .on ("click", item .callback) .on ("click", hide);
684
+
685
+ break;
686
+ }
687
+ }
688
+
689
+ break;
690
+ }
691
+ }
692
+
693
+ if (typeof item .items === "object" && level < 3)
694
+ {
695
+ const ul = $("<ul></ul>")
696
+ .addClass ("context-menu-list")
697
+ .css ({ "z-index": level })
698
+ .appendTo (li);
699
+
700
+ for (const k in item .items)
701
+ ul .append (this .createItem (item .items [k], key, k, level + 1, hide));
702
+
703
+ li .addClass ("context-menu-submenu");
704
+ }
705
+
706
+ return li;
707
+ },
602
708
  });
603
709
 
604
710
  return ContextMenu;
@@ -94,6 +94,7 @@ function ($,
94
94
  X3DBaseNode .prototype .initialize .call (this);
95
95
 
96
96
  this .element = $("<div></div>")
97
+ .hide ()
97
98
  .addClass ("x_ite-private-notification")
98
99
  .appendTo (this .getBrowser () .getSurface ())
99
100
  .animate ({ width: 0 });