x_ite 4.0.5 → 4.7.5

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 (1007) hide show
  1. package/.github/ISSUE_TEMPLATE/bug_report.md +38 -0
  2. package/.vscode/settings.json +15 -0
  3. package/.vscode/tasks.json +25 -0
  4. package/Makefile +55 -15
  5. package/README.md +13 -130
  6. package/build/bin/dist.pl +156 -0
  7. package/build/bin/version-number.pl +25 -0
  8. package/build/{version.pl → bin/version.pl} +64 -21
  9. package/build/components/annotation.build.js +15 -0
  10. package/build/components/cad-geometry.build.js +15 -0
  11. package/build/components/cube-map-texturing.build.js +15 -0
  12. package/build/components/dis.build.js +15 -0
  13. package/build/components/event-utilities.build.js +15 -0
  14. package/build/components/geometry2d.build.js +15 -0
  15. package/build/components/geospatial.build.js +15 -0
  16. package/build/components/h-anim.build.js +15 -0
  17. package/build/components/key-device-sensor.build.js +15 -0
  18. package/build/components/layout.build.js +15 -0
  19. package/build/components/nurbs.build.js +15 -0
  20. package/build/components/particle-systems.build.js +15 -0
  21. package/build/components/picking.build.js +15 -0
  22. package/build/components/projective-texture-mapping.build.js +15 -0
  23. package/build/components/rigid-body-physics.build.js +15 -0
  24. package/build/components/scripting.build.js +15 -0
  25. package/build/components/texturing-3d.build.js +15 -0
  26. package/build/components/volume-rendering.build.js +15 -0
  27. package/build/components/x_ite.build.js +15 -0
  28. package/build/parts/default.end.frag +2 -0
  29. package/build/parts/default.start.frag +6 -0
  30. package/build/parts/x_ite.end.frag +23 -0
  31. package/build/parts/x_ite.start.frag +8 -0
  32. package/build/x_ite.build.js +18 -0
  33. package/dist/LICENSE.txt +49 -0
  34. package/dist/assets/components/annotation.js +813 -0
  35. package/dist/assets/components/annotation.min.js +1 -0
  36. package/dist/assets/components/cad-geometry.js +1037 -0
  37. package/dist/assets/components/cad-geometry.min.js +1 -0
  38. package/dist/assets/components/cube-map-texturing.js +1212 -0
  39. package/dist/assets/components/cube-map-texturing.min.js +1 -0
  40. package/dist/assets/components/dis.js +908 -0
  41. package/dist/assets/components/dis.min.js +1 -0
  42. package/dist/assets/components/event-utilities.js +1114 -0
  43. package/dist/assets/components/event-utilities.min.js +1 -0
  44. package/dist/assets/components/geometry2d.js +2190 -0
  45. package/dist/assets/components/geometry2d.min.js +1 -0
  46. package/dist/assets/components/geospatial.js +3850 -0
  47. package/dist/assets/components/geospatial.min.js +2 -0
  48. package/dist/assets/components/h-anim.js +1084 -0
  49. package/dist/assets/components/h-anim.min.js +1 -0
  50. package/dist/assets/components/key-device-sensor.js +850 -0
  51. package/dist/assets/components/key-device-sensor.min.js +1 -0
  52. package/dist/assets/components/layout.js +2008 -0
  53. package/dist/assets/components/layout.min.js +1 -0
  54. package/dist/assets/components/nurbs.js +5388 -0
  55. package/dist/assets/components/nurbs.min.js +2 -0
  56. package/dist/assets/components/particle-systems.js +4216 -0
  57. package/dist/assets/components/particle-systems.min.js +2 -0
  58. package/dist/assets/components/picking.js +2481 -0
  59. package/dist/assets/components/picking.min.js +1 -0
  60. package/dist/assets/components/projective-texture-mapping.js +813 -0
  61. package/dist/assets/components/projective-texture-mapping.min.js +1 -0
  62. package/dist/assets/components/rigid-body-physics.js +4569 -0
  63. package/dist/assets/components/rigid-body-physics.min.js +59 -0
  64. package/dist/assets/components/scripting.js +801 -0
  65. package/dist/assets/components/scripting.min.js +1 -0
  66. package/dist/assets/components/texturing-3d.js +10054 -0
  67. package/dist/assets/components/texturing-3d.min.js +48 -0
  68. package/dist/assets/components/volume-rendering.js +3966 -0
  69. package/dist/assets/components/volume-rendering.min.js +3 -0
  70. package/dist/assets/components/x_ite.js +285 -0
  71. package/dist/assets/components/x_ite.min.js +1 -0
  72. package/{fonts → dist/assets/fonts}/DroidSerif-Bold.ttf +0 -0
  73. package/{fonts → dist/assets/fonts}/DroidSerif-BoldItalic.ttf +0 -0
  74. package/{fonts → dist/assets/fonts}/DroidSerif-Italic.ttf +0 -0
  75. package/{fonts → dist/assets/fonts}/DroidSerif-Regular.ttf +0 -0
  76. package/{fonts → dist/assets/fonts}/Ubuntu-B.ttf +0 -0
  77. package/{fonts → dist/assets/fonts}/Ubuntu-BI.ttf +0 -0
  78. package/{fonts → dist/assets/fonts}/Ubuntu-R.ttf +0 -0
  79. package/{fonts → dist/assets/fonts}/Ubuntu-RI.ttf +0 -0
  80. package/{fonts → dist/assets/fonts}/UbuntuMono-B.ttf +0 -0
  81. package/{fonts → dist/assets/fonts}/UbuntuMono-BI.ttf +0 -0
  82. package/{fonts → dist/assets/fonts}/UbuntuMono-R.ttf +0 -0
  83. package/{fonts → dist/assets/fonts}/UbuntuMono-RI.ttf +0 -0
  84. package/dist/assets/hatching/0.png +0 -0
  85. package/dist/assets/hatching/1.png +0 -0
  86. package/dist/assets/hatching/10.png +0 -0
  87. package/dist/assets/hatching/11.png +0 -0
  88. package/dist/assets/hatching/12.png +0 -0
  89. package/dist/assets/hatching/13.png +0 -0
  90. package/dist/assets/hatching/14.png +0 -0
  91. package/dist/assets/hatching/15.png +0 -0
  92. package/dist/assets/hatching/16.png +0 -0
  93. package/dist/assets/hatching/17.png +0 -0
  94. package/dist/assets/hatching/18.png +0 -0
  95. package/dist/assets/hatching/19.png +0 -0
  96. package/dist/assets/hatching/2.png +0 -0
  97. package/dist/assets/hatching/3.png +0 -0
  98. package/dist/assets/hatching/4.png +0 -0
  99. package/dist/assets/hatching/5.png +0 -0
  100. package/dist/assets/hatching/6.png +0 -0
  101. package/dist/assets/hatching/7.png +0 -0
  102. package/dist/assets/hatching/8.png +0 -0
  103. package/dist/assets/hatching/9.png +0 -0
  104. package/dist/{images → assets/images}/ExamineViewer.png +0 -0
  105. package/dist/{images → assets/images}/FlyViewer.png +0 -0
  106. package/dist/{images → assets/images}/NoneViewer.png +0 -0
  107. package/dist/{images → assets/images}/PlaneViewer.png +0 -0
  108. package/dist/{images → assets/images}/PrimitiveQuality.png +0 -0
  109. package/dist/{images → assets/images}/TextureQuality.png +0 -0
  110. package/dist/{images → assets/images}/Time.png +0 -0
  111. package/dist/{images → assets/images}/Viewpoint.png +0 -0
  112. package/dist/{images → assets/images}/WalkViewer.png +0 -0
  113. package/dist/assets/images/go-next.png +0 -0
  114. package/dist/{images → assets/images}/gtk-fullscreen.png +0 -0
  115. package/dist/{images → assets/images}/gtk-leave-fullscreen.png +0 -0
  116. package/dist/{images → assets/images}/gtk-zoom-fit.png +0 -0
  117. package/dist/{images → assets/images}/gtk-zoom-in.png +0 -0
  118. package/dist/{images → assets/images}/help-about.png +0 -0
  119. package/dist/{images → assets/images}/icon.bw.png +0 -0
  120. package/dist/{images → assets/images}/icon.png +0 -0
  121. package/dist/assets/images/logo.128.png +0 -0
  122. package/dist/{images → assets/images}/logo.bw.png +0 -0
  123. package/dist/{images → assets/images}/logo.png +0 -0
  124. package/dist/assets/linetype/0.png +0 -0
  125. package/dist/assets/linetype/1.png +0 -0
  126. package/dist/assets/linetype/10.png +0 -0
  127. package/dist/assets/linetype/11.png +0 -0
  128. package/dist/assets/linetype/12.png +0 -0
  129. package/dist/assets/linetype/13.png +0 -0
  130. package/dist/assets/linetype/14.png +0 -0
  131. package/dist/assets/linetype/15.png +0 -0
  132. package/dist/assets/linetype/16.png +0 -0
  133. package/dist/assets/linetype/2.png +0 -0
  134. package/dist/assets/linetype/3.png +0 -0
  135. package/dist/assets/linetype/4.png +0 -0
  136. package/dist/assets/linetype/5.png +0 -0
  137. package/dist/assets/linetype/6.png +0 -0
  138. package/dist/assets/linetype/7.png +0 -0
  139. package/dist/assets/linetype/8.png +0 -0
  140. package/dist/assets/linetype/9.png +0 -0
  141. package/dist/assets/shaders/webgl1/Background.fs +23 -0
  142. package/dist/assets/shaders/webgl1/Background.vs +16 -0
  143. package/dist/assets/shaders/webgl1/Depth.fs +60 -0
  144. package/dist/assets/shaders/webgl1/Depth.vs +13 -0
  145. package/dist/assets/shaders/webgl1/Fallback.fs +28 -0
  146. package/dist/assets/shaders/webgl1/Fallback.vs +24 -0
  147. package/dist/assets/shaders/webgl1/FallbackUnlit.fs +16 -0
  148. package/dist/assets/shaders/webgl1/FallbackUnlit.vs +18 -0
  149. package/dist/assets/shaders/webgl1/Gouraud.fs +529 -0
  150. package/dist/assets/shaders/webgl1/Gouraud.vs +108 -0
  151. package/dist/assets/shaders/webgl1/Phong.fs +838 -0
  152. package/dist/assets/shaders/webgl1/Phong.vs +52 -0
  153. package/dist/assets/shaders/webgl1/PointSet.fs +541 -0
  154. package/dist/assets/shaders/webgl1/PointSet.vs +48 -0
  155. package/dist/assets/shaders/webgl1/Unlit.fs +541 -0
  156. package/dist/assets/shaders/webgl1/Unlit.vs +52 -0
  157. package/dist/assets/shaders/webgl1/Wireframe.fs +93 -0
  158. package/dist/assets/shaders/webgl1/Wireframe.vs +47 -0
  159. package/dist/assets/shaders/webgl2/Background.fs +25 -0
  160. package/dist/assets/shaders/webgl2/Background.vs +17 -0
  161. package/dist/assets/shaders/webgl2/Depth.fs +62 -0
  162. package/dist/assets/shaders/webgl2/Depth.vs +14 -0
  163. package/dist/assets/shaders/webgl2/Gouraud.fs +684 -0
  164. package/dist/assets/shaders/webgl2/Gouraud.vs +109 -0
  165. package/dist/assets/shaders/webgl2/Phong.fs +1014 -0
  166. package/dist/assets/shaders/webgl2/Phong.vs +53 -0
  167. package/dist/assets/shaders/webgl2/PointSet.fs +696 -0
  168. package/dist/assets/shaders/webgl2/PointSet.vs +49 -0
  169. package/dist/assets/shaders/webgl2/Unlit.fs +696 -0
  170. package/dist/assets/shaders/webgl2/Unlit.vs +53 -0
  171. package/dist/assets/shaders/webgl2/Wireframe.fs +102 -0
  172. package/dist/assets/shaders/webgl2/Wireframe.vs +48 -0
  173. package/dist/example.html +8 -7
  174. package/dist/x_ite.css +180 -59
  175. package/dist/x_ite.js +74696 -68048
  176. package/dist/x_ite.min.js +42 -41
  177. package/dist/x_ite.zip +0 -0
  178. package/docs/404.md +5 -0
  179. package/docs/Accessing-the-External-Browser.md +290 -0
  180. package/docs/Browser-Support.md +47 -0
  181. package/docs/Custom-Shaders.md +905 -0
  182. package/docs/Features.md +49 -0
  183. package/docs/Glossary.md +339 -0
  184. package/docs/How-To-Configure-Your-Web-Server.md +56 -0
  185. package/docs/Supported-Nodes.md +370 -0
  186. package/docs/What's-New.md +1240 -0
  187. package/docs/XHTML-DOM-Integration.md +82 -0
  188. package/docs/_config.yml +140 -0
  189. package/docs/_data/navigation.yml +137 -0
  190. package/docs/assets/css/main.scss +100 -0
  191. package/docs/assets/images/logo.png +0 -0
  192. package/docs/google3696ee938394d7b6.html +1 -0
  193. package/docs/index.md +1026 -0
  194. package/docs/reference/Browser-Services.md +333 -0
  195. package/docs/reference/Constants-Services.md +376 -0
  196. package/docs/reference/ECMAScript-Object-and-Function-Definitions.md +128 -0
  197. package/docs/reference/Field-Services-and-Objects.md +1006 -0
  198. package/docs/reference/Prototype-Services.md +121 -0
  199. package/docs/reference/Route-Services.md +49 -0
  200. package/docs/reference/Scene-Services.md +360 -0
  201. package/docs/reference/Script-Node-Authoring-Interface.md +334 -0
  202. package/docs/tutorials/Adding-backgrounds.md +268 -0
  203. package/docs/tutorials/Adding-fog.md +67 -0
  204. package/docs/tutorials/Adding-sound.md +326 -0
  205. package/docs/tutorials/Animating-transforms.md +385 -0
  206. package/docs/tutorials/Basic-Nodes.md +317 -0
  207. package/docs/tutorials/Building-a-X3D-world.md +152 -0
  208. package/docs/tutorials/Building-elevation-grids.md +170 -0
  209. package/docs/tutorials/Building-extruded-shapes.md +145 -0
  210. package/docs/tutorials/Building-primitive-shapes.md +204 -0
  211. package/docs/tutorials/Building-shapes-out-of-points,-lines,-and-faces.md +311 -0
  212. package/docs/tutorials/Controlling-appearance-with-materials.md +186 -0
  213. package/docs/tutorials/Controlling-color-on-coordinate-based-geometry.md +208 -0
  214. package/docs/tutorials/Controlling-detail.md +130 -0
  215. package/docs/tutorials/Controlling-how-textures-are-mapped.md +277 -0
  216. package/docs/tutorials/Controlling-navigation.md +70 -0
  217. package/docs/tutorials/Controlling-shading-on-coordinate-based-geometry.md +180 -0
  218. package/docs/tutorials/Controlling-the-viewpoint.md +49 -0
  219. package/docs/tutorials/Creating-new-node-types.md +313 -0
  220. package/docs/tutorials/Grouping-nodes.md +237 -0
  221. package/docs/tutorials/Hello,-World!.md +204 -0
  222. package/docs/tutorials/Improving-Performance.md +227 -0
  223. package/docs/tutorials/Increasing-Rendering-Speed.md +110 -0
  224. package/docs/tutorials/Introducing-X3D.md +94 -0
  225. package/docs/tutorials/Introducing-animation.md +211 -0
  226. package/docs/tutorials/Introducing-script-use.md +127 -0
  227. package/docs/tutorials/Lighting-your-world.md +139 -0
  228. package/docs/tutorials/Mapping-textures.md +212 -0
  229. package/docs/tutorials/Naming-nodes.md +161 -0
  230. package/docs/tutorials/Providing-information-about-your-world.md +30 -0
  231. package/docs/tutorials/Sensing-the-viewer.md +205 -0
  232. package/docs/tutorials/Sensing-viewer-actions.md +214 -0
  233. package/docs/tutorials/Transforming-Shapes.md +270 -0
  234. package/docs/tutorials/Writing-program-scripts-with-ECMAScript.md +631 -0
  235. package/docs/tutorials/index.md +78 -0
  236. package/meta/logo/logo.png +0 -0
  237. package/meta/logo/logo.svg +216 -217
  238. package/meta/web3d.html +76 -54
  239. package/package.json +41 -24
  240. package/src/assets/components/annotation.js +87 -0
  241. package/src/assets/components/cad-geometry.js +88 -0
  242. package/src/assets/components/cube-map-texturing.js +78 -0
  243. package/src/assets/components/dis.js +84 -0
  244. package/src/assets/components/event-utilities.js +93 -0
  245. package/src/assets/components/geometry2d.js +93 -0
  246. package/src/assets/components/geospatial.js +102 -0
  247. package/src/assets/components/h-anim.js +83 -0
  248. package/src/assets/components/key-device-sensor.js +78 -0
  249. package/src/assets/components/layout.js +87 -0
  250. package/src/assets/components/nurbs.js +118 -0
  251. package/src/assets/components/particle-systems.js +105 -0
  252. package/src/assets/components/picking.js +87 -0
  253. package/src/assets/components/projective-texture-mapping.js +75 -0
  254. package/src/assets/components/rigid-body-physics.js +123 -0
  255. package/src/assets/components/scripting.js +72 -0
  256. package/src/assets/components/texturing-3d.js +91 -0
  257. package/src/assets/components/volume-rendering.js +118 -0
  258. package/src/assets/components/x_ite.js +69 -0
  259. package/src/assets/fonts/DroidSerif-Bold.ttf +0 -0
  260. package/src/assets/fonts/DroidSerif-BoldItalic.ttf +0 -0
  261. package/src/assets/fonts/DroidSerif-Italic.ttf +0 -0
  262. package/src/assets/fonts/DroidSerif-Regular.ttf +0 -0
  263. package/src/assets/fonts/Ubuntu-B.ttf +0 -0
  264. package/src/assets/fonts/Ubuntu-BI.ttf +0 -0
  265. package/src/assets/fonts/Ubuntu-R.ttf +0 -0
  266. package/src/assets/fonts/Ubuntu-RI.ttf +0 -0
  267. package/src/assets/fonts/UbuntuMono-B.ttf +0 -0
  268. package/src/assets/fonts/UbuntuMono-BI.ttf +0 -0
  269. package/src/assets/fonts/UbuntuMono-R.ttf +0 -0
  270. package/src/assets/fonts/UbuntuMono-RI.ttf +0 -0
  271. package/src/assets/hatching/0.png +0 -0
  272. package/src/assets/hatching/1.png +0 -0
  273. package/src/assets/hatching/10.png +0 -0
  274. package/src/assets/hatching/11.png +0 -0
  275. package/src/assets/hatching/12.png +0 -0
  276. package/src/assets/hatching/13.png +0 -0
  277. package/src/assets/hatching/14.png +0 -0
  278. package/src/assets/hatching/15.png +0 -0
  279. package/src/assets/hatching/16.png +0 -0
  280. package/src/assets/hatching/17.png +0 -0
  281. package/src/assets/hatching/18.png +0 -0
  282. package/src/assets/hatching/19.png +0 -0
  283. package/src/assets/hatching/2.png +0 -0
  284. package/src/assets/hatching/3.png +0 -0
  285. package/src/assets/hatching/4.png +0 -0
  286. package/src/assets/hatching/5.png +0 -0
  287. package/src/assets/hatching/6.png +0 -0
  288. package/src/assets/hatching/7.png +0 -0
  289. package/src/assets/hatching/8.png +0 -0
  290. package/src/assets/hatching/9.png +0 -0
  291. package/src/{images → assets/images}/ExamineViewer.png +0 -0
  292. package/src/{images → assets/images}/FlyViewer.png +0 -0
  293. package/src/{images → assets/images}/NoneViewer.png +0 -0
  294. package/src/{images → assets/images}/PlaneViewer.png +0 -0
  295. package/src/{images → assets/images}/PrimitiveQuality.png +0 -0
  296. package/src/{images → assets/images}/TextureQuality.png +0 -0
  297. package/src/{images → assets/images}/Time.png +0 -0
  298. package/src/{images → assets/images}/Viewpoint.png +0 -0
  299. package/src/{images → assets/images}/WalkViewer.png +0 -0
  300. package/src/assets/images/go-next.png +0 -0
  301. package/src/{images → assets/images}/gtk-fullscreen.png +0 -0
  302. package/src/{images → assets/images}/gtk-leave-fullscreen.png +0 -0
  303. package/src/{images → assets/images}/gtk-zoom-fit.png +0 -0
  304. package/src/{images → assets/images}/gtk-zoom-in.png +0 -0
  305. package/src/{images → assets/images}/help-about.png +0 -0
  306. package/src/{images → assets/images}/icon.bw.png +0 -0
  307. package/src/{images → assets/images}/icon.png +0 -0
  308. package/src/assets/images/logo.128.png +0 -0
  309. package/src/{images → assets/images}/logo.bw.png +0 -0
  310. package/src/{images → assets/images}/logo.png +0 -0
  311. package/src/assets/linetype/0.png +0 -0
  312. package/src/assets/linetype/1.png +0 -0
  313. package/src/assets/linetype/10.png +0 -0
  314. package/src/assets/linetype/11.png +0 -0
  315. package/src/assets/linetype/12.png +0 -0
  316. package/src/assets/linetype/13.png +0 -0
  317. package/src/assets/linetype/14.png +0 -0
  318. package/src/assets/linetype/15.png +0 -0
  319. package/src/assets/linetype/16.png +0 -0
  320. package/src/assets/linetype/2.png +0 -0
  321. package/src/assets/linetype/3.png +0 -0
  322. package/src/assets/linetype/4.png +0 -0
  323. package/src/assets/linetype/5.png +0 -0
  324. package/src/assets/linetype/6.png +0 -0
  325. package/src/assets/linetype/7.png +0 -0
  326. package/src/assets/linetype/8.png +0 -0
  327. package/src/assets/linetype/9.png +0 -0
  328. package/src/assets/shaders/Types.glsl +102 -0
  329. package/src/assets/shaders/webgl1/Background.fs +16 -0
  330. package/src/assets/shaders/webgl1/Background.vs +22 -0
  331. package/src/assets/shaders/webgl1/Depth.fs +16 -0
  332. package/src/assets/shaders/webgl1/Depth.vs +20 -0
  333. package/src/assets/shaders/webgl1/Fallback.fs +38 -0
  334. package/src/assets/shaders/webgl1/Fallback.vs +30 -0
  335. package/src/assets/shaders/webgl1/FallbackUnlit.fs +22 -0
  336. package/src/assets/shaders/webgl1/FallbackUnlit.vs +24 -0
  337. package/src/assets/shaders/webgl1/Gouraud.fs +66 -0
  338. package/src/assets/shaders/webgl1/Gouraud.vs +148 -0
  339. package/src/assets/shaders/webgl1/Phong.fs +173 -0
  340. package/src/assets/shaders/webgl1/Phong.vs +67 -0
  341. package/src/assets/shaders/webgl1/PointSet.fs +100 -0
  342. package/src/assets/shaders/webgl1/PointSet.vs +70 -0
  343. package/src/assets/shaders/webgl1/Unlit.fs +89 -0
  344. package/src/assets/shaders/webgl1/Unlit.vs +67 -0
  345. package/src/assets/shaders/webgl1/Wireframe.fs +74 -0
  346. package/src/assets/shaders/webgl1/Wireframe.vs +63 -0
  347. package/src/assets/shaders/webgl1/include/ClipPlanes.glsl +16 -0
  348. package/src/assets/shaders/webgl1/include/Fog.glsl +38 -0
  349. package/src/assets/shaders/webgl1/include/Hatch.glsl +18 -0
  350. package/src/assets/shaders/webgl1/include/Pack.glsl +51 -0
  351. package/src/assets/shaders/webgl1/include/Perlin.glsl +40 -0
  352. package/src/assets/shaders/webgl1/include/Shadow.glsl +310 -0
  353. package/src/assets/shaders/webgl1/include/Texture.glsl +488 -0
  354. package/src/assets/shaders/webgl2/Background.fs +19 -0
  355. package/src/assets/shaders/webgl2/Background.vs +23 -0
  356. package/src/assets/shaders/webgl2/Depth.fs +19 -0
  357. package/src/assets/shaders/webgl2/Depth.vs +21 -0
  358. package/src/assets/shaders/webgl2/Gouraud.fs +64 -0
  359. package/src/assets/shaders/webgl2/Gouraud.vs +149 -0
  360. package/src/assets/shaders/webgl2/Phong.fs +171 -0
  361. package/src/assets/shaders/webgl2/Phong.vs +68 -0
  362. package/src/assets/shaders/webgl2/PointSet.fs +99 -0
  363. package/src/assets/shaders/webgl2/PointSet.vs +71 -0
  364. package/src/assets/shaders/webgl2/Unlit.fs +88 -0
  365. package/src/assets/shaders/webgl2/Unlit.vs +68 -0
  366. package/src/assets/shaders/webgl2/Wireframe.fs +73 -0
  367. package/src/assets/shaders/webgl2/Wireframe.vs +64 -0
  368. package/src/assets/shaders/webgl2/include/ClipPlanes.glsl +16 -0
  369. package/src/assets/shaders/webgl2/include/Fog.glsl +46 -0
  370. package/src/assets/shaders/webgl2/include/Hatch.glsl +18 -0
  371. package/src/assets/shaders/webgl2/include/Pack.glsl +51 -0
  372. package/src/assets/shaders/webgl2/include/Perlin.glsl +40 -0
  373. package/src/assets/shaders/webgl2/include/Shadow.glsl +324 -0
  374. package/src/assets/shaders/webgl2/include/Texture.glsl +623 -0
  375. package/src/bookmarks.js +83 -164
  376. package/src/dummy.js +1 -0
  377. package/src/example.html +8 -7
  378. package/src/examples.js +150 -0
  379. package/src/lib/ammojs/AmmoJS.js +58 -0
  380. package/src/lib/ammojs/Makefile +26 -0
  381. package/src/lib/ammojs/ammo.idl +1031 -0
  382. package/src/lib/ammojs/ammo.js +40 -0
  383. package/src/lib/jpeg/jpeg.js +1019 -0
  384. package/src/lib/nurbs/extras/sample.js +242 -0
  385. package/src/lib/nurbs/nurbs.js +342 -0
  386. package/src/lib/nurbs/src/evaluate.js +413 -0
  387. package/src/lib/nurbs/src/numerical-derivative.js +54 -0
  388. package/src/lib/nurbs/src/support.js +151 -0
  389. package/src/lib/nurbs/src/transform.js +78 -0
  390. package/src/lib/nurbs/src/utils/accessor-preamble.js +33 -0
  391. package/src/lib/nurbs/src/utils/bisection-search.js +28 -0
  392. package/src/lib/nurbs/src/utils/cache-key.js +57 -0
  393. package/src/lib/nurbs/src/utils/create-accessors.js +110 -0
  394. package/src/lib/nurbs/src/utils/infer-type.js +52 -0
  395. package/src/lib/nurbs/src/utils/is-array-like.js +10 -0
  396. package/src/lib/nurbs/src/utils/is-ndarray-like.js +18 -0
  397. package/src/lib/nurbs/src/utils/is-ndarray.js +21 -0
  398. package/src/lib/nurbs/src/utils/ndloop.js +23 -0
  399. package/src/lib/nurbs/src/utils/size-getter.js +22 -0
  400. package/src/lib/nurbs/src/utils/variable.js +31 -0
  401. package/src/locale/de.po +8 -3
  402. package/src/locale/fr.po +9 -4
  403. package/src/locale/gettext.js +3 -3
  404. package/src/spinner.css +21 -8
  405. package/src/standard/Geospatial/Geodetic.js +48 -48
  406. package/src/standard/Geospatial/ReferenceEllipsoids.js +1 -1
  407. package/src/standard/Geospatial/UniversalTransverseMercator.js +43 -43
  408. package/src/standard/Math/Algorithm.js +25 -41
  409. package/src/standard/Math/Algorithms/Bezier.js +147 -0
  410. package/src/standard/Math/Algorithms/MergeSort.js +2 -2
  411. package/src/standard/Math/Algorithms/PartialSort.js +97 -0
  412. package/src/standard/Math/Algorithms/QuickSort.js +8 -6
  413. package/src/standard/Math/Algorithms/SAT.js +4 -8
  414. package/src/standard/Math/Algorithms/eigendecomposition.js +37 -33
  415. package/src/standard/Math/Geometry/Box2.js +84 -56
  416. package/src/standard/Math/Geometry/Box3.js +457 -284
  417. package/src/standard/Math/Geometry/Camera.js +24 -15
  418. package/src/standard/Math/Geometry/Cylinder3.js +13 -13
  419. package/src/standard/Math/Geometry/Line3.js +61 -53
  420. package/src/standard/Math/Geometry/Plane3.js +16 -16
  421. package/src/standard/Math/Geometry/Sphere3.js +122 -105
  422. package/src/standard/Math/Geometry/Spheroid3.js +1 -1
  423. package/src/standard/Math/Geometry/Triangle2.js +6 -6
  424. package/src/standard/Math/Geometry/Triangle3.js +80 -88
  425. package/src/standard/Math/Geometry/ViewVolume.js +315 -116
  426. package/src/standard/Math/Numbers/Color3.js +45 -29
  427. package/src/standard/Math/Numbers/Color4.js +25 -14
  428. package/src/standard/Math/Numbers/Complex.js +15 -22
  429. package/src/standard/Math/Numbers/Matrix2.js +37 -17
  430. package/src/standard/Math/Numbers/Matrix3.js +181 -212
  431. package/src/standard/Math/Numbers/Matrix4.js +204 -262
  432. package/src/standard/Math/Numbers/Quaternion.js +60 -147
  433. package/src/standard/Math/Numbers/Rotation4.js +197 -129
  434. package/src/standard/Math/Numbers/Vector2.js +53 -109
  435. package/src/standard/Math/Numbers/Vector3.js +75 -144
  436. package/src/standard/Math/Numbers/Vector4.js +85 -155
  437. package/src/standard/Math/Utility/BVH.js +35 -30
  438. package/src/standard/Math/Utility/MatrixStack.js +6 -9
  439. package/src/standard/Networking/BinaryTransport.js +8 -8
  440. package/src/standard/Time/MicroTime.js +79 -0
  441. package/src/standard/Utility/DataStorage.js +40 -17
  442. package/src/standard/Utility/MapUtilities.js +69 -0
  443. package/src/standard/Utility/ObjectCache.js +2 -3
  444. package/src/standard/Utility/Shuffle.js +5 -6
  445. package/src/tests.js +386 -0
  446. package/src/x_ite/Base/Events.js +22 -30
  447. package/src/x_ite/Base/X3DChildObject.js +35 -19
  448. package/src/x_ite/Base/X3DEventObject.js +10 -12
  449. package/src/x_ite/Base/X3DObject.js +63 -43
  450. package/src/x_ite/Basic/FieldDefinitionArray.js +16 -10
  451. package/src/x_ite/Basic/X3DArrayField.js +3 -430
  452. package/src/x_ite/Basic/X3DBaseNode.js +551 -288
  453. package/src/x_ite/Basic/X3DField.js +133 -96
  454. package/src/x_ite/Basic/X3DFieldDefinition.js +0 -4
  455. package/src/x_ite/Basic/X3DObjectArrayField.js +545 -0
  456. package/src/x_ite/Basic/X3DTypedArrayField.js +839 -0
  457. package/src/x_ite/Bits/TraverseType.js +2 -5
  458. package/src/x_ite/Bits/X3DConstants.js +12 -322
  459. package/src/x_ite/Browser/Core/BrowserOptions.js +205 -77
  460. package/src/x_ite/Browser/Core/BrowserProperties.js +2 -4
  461. package/src/x_ite/Browser/Core/BrowserTimings.js +16 -15
  462. package/src/x_ite/Browser/Core/ContextMenu.js +202 -80
  463. package/src/x_ite/Browser/Core/Notification.js +14 -6
  464. package/src/x_ite/Browser/Core/PrimitiveQuality.js +3 -7
  465. package/src/x_ite/Browser/Core/RenderingProperties.js +10 -11
  466. package/src/x_ite/Browser/Core/Shading.js +66 -0
  467. package/src/x_ite/Browser/Core/TextureQuality.js +3 -7
  468. package/src/x_ite/Browser/Core/X3DCoreContext.js +495 -48
  469. package/src/x_ite/Browser/Core/X3DCoreContext.js.~1~ +714 -0
  470. package/src/x_ite/Browser/EnvironmentalEffects/X3DEnvironmentalEffectsContext.js +17 -23
  471. package/src/x_ite/Browser/Followers/X3DArrayChaserTemplate.js +12 -20
  472. package/src/x_ite/Browser/Followers/X3DArrayFollowerTemplate.js +82 -34
  473. package/src/x_ite/Browser/Geometry2D/Arc2DOptions.js +3 -5
  474. package/src/x_ite/Browser/Geometry2D/ArcClose2DOptions.js +3 -5
  475. package/src/x_ite/Browser/Geometry2D/Circle2DOptions.js +12 -9
  476. package/src/x_ite/Browser/Geometry2D/Disk2DOptions.js +60 -42
  477. package/src/x_ite/Browser/Geometry2D/Rectangle2DOptions.js +16 -20
  478. package/src/x_ite/Browser/Geometry2D/X3DGeometry2DContext.js +51 -12
  479. package/src/x_ite/Browser/Geometry3D/BoxOptions.js +17 -21
  480. package/src/x_ite/Browser/Geometry3D/ConeOptions.js +2 -4
  481. package/src/x_ite/Browser/Geometry3D/CylinderOptions.js +2 -4
  482. package/src/x_ite/Browser/Geometry3D/IcoSphereOptions.js +2 -4
  483. package/src/x_ite/Browser/Geometry3D/QuadSphereOptions.js +3 -5
  484. package/src/x_ite/Browser/Geometry3D/X3DGeometry3DContext.js +8 -9
  485. package/src/x_ite/Browser/Grouping/X3DGroupingContext.js +98 -0
  486. package/src/x_ite/Browser/Interpolation/CatmullRomSplineInterpolator.js +12 -12
  487. package/src/x_ite/Browser/Interpolation/CatmullRomSplineInterpolator1.js +2 -4
  488. package/src/x_ite/Browser/Interpolation/CatmullRomSplineInterpolatorTemplate.js +2 -4
  489. package/src/x_ite/Browser/KeyDeviceSensor/X3DKeyDeviceSensorContext.js +22 -200
  490. package/src/x_ite/Browser/Layout/ScreenText.js +287 -295
  491. package/src/x_ite/Browser/Layout/X3DLayoutContext.js +15 -12
  492. package/src/x_ite/Browser/Lighting/X3DLightingContext.js +18 -12
  493. package/src/x_ite/Browser/NURBS/NURBS.js +481 -0
  494. package/src/x_ite/Browser/Navigation/ExamineViewer.js +587 -127
  495. package/src/x_ite/Browser/Navigation/FlyViewer.js +23 -5
  496. package/src/x_ite/Browser/Navigation/LookAtViewer.js +402 -18
  497. package/src/x_ite/Browser/Navigation/NoneViewer.js +13 -3
  498. package/src/x_ite/Browser/Navigation/PlaneViewer.js +46 -28
  499. package/src/x_ite/Browser/Navigation/WalkViewer.js +45 -17
  500. package/src/x_ite/Browser/Navigation/X3DFlyViewer.js +414 -207
  501. package/src/x_ite/Browser/Navigation/X3DNavigationContext.js +65 -48
  502. package/src/x_ite/Browser/Navigation/X3DViewer.js +99 -45
  503. package/src/x_ite/Browser/Networking/X3DNetworkingContext.js +39 -38
  504. package/src/x_ite/Browser/Networking/urls.js +34 -5
  505. package/src/x_ite/Browser/ParticleSystems/X3DParticleSystemsContext.js +7 -9
  506. package/src/x_ite/Browser/Picking/IntersectionType.js +63 -0
  507. package/src/x_ite/Browser/Picking/MatchCriterion.js +64 -0
  508. package/src/x_ite/Browser/Picking/SortOrder.js +65 -0
  509. package/src/x_ite/Browser/Picking/VolumePicker.js +197 -0
  510. package/src/x_ite/Browser/Picking/X3DPickingContext.js +130 -0
  511. package/src/x_ite/Browser/PointingDeviceSensor/PointingDevice.js +89 -30
  512. package/src/x_ite/Browser/PointingDeviceSensor/PointingDeviceSensorContainer.js +1 -3
  513. package/src/x_ite/Browser/PointingDeviceSensor/X3DPointingDeviceSensorContext.js +33 -15
  514. package/src/x_ite/Browser/Rendering/X3DRenderingContext.js +39 -151
  515. package/src/x_ite/Browser/RigidBodyPhysics/AppliedParametersType.js +70 -0
  516. package/src/x_ite/Browser/Shaders/Shader.js +150 -50
  517. package/src/x_ite/Browser/Shaders/ShaderSource.js +140 -0
  518. package/src/x_ite/Browser/Shaders/ShaderTest.js +94 -77
  519. package/src/x_ite/Browser/Shaders/X3DShadersContext.js +220 -5
  520. package/src/x_ite/Browser/Shape/AlphaMode.js +65 -0
  521. package/src/x_ite/Browser/Shape/LineStipples.xcf +0 -0
  522. package/src/x_ite/Browser/Shape/X3DShapeContext.js +108 -4
  523. package/src/x_ite/Browser/Sound/X3DSoundContext.js +1 -20
  524. package/src/x_ite/Browser/Text/PolygonText.js +165 -359
  525. package/src/x_ite/Browser/Text/TextAlignment.js +3 -7
  526. package/src/x_ite/Browser/Text/X3DTextContext.js +38 -30
  527. package/src/x_ite/Browser/Text/X3DTextGeometry.js +58 -84
  528. package/src/x_ite/Browser/Texturing/MultiTextureFunctionType.js +64 -0
  529. package/src/x_ite/Browser/Texturing/MultiTextureModeType.js +81 -0
  530. package/src/x_ite/Browser/Texturing/MultiTextureSourceType.js +65 -0
  531. package/src/x_ite/Browser/Texturing/TextureCoordinateGeneratorModeType.js +73 -0
  532. package/src/x_ite/Browser/Texturing/X3DTexturingContext.js +148 -41
  533. package/src/x_ite/Browser/Texturing3D/DICOMParser.js +1126 -0
  534. package/src/x_ite/Browser/Texturing3D/NRRDParser.js +686 -0
  535. package/src/x_ite/Browser/Time/X3DTimeContext.js +20 -17
  536. package/src/x_ite/Browser/VERSION.js +2 -2
  537. package/src/x_ite/Browser/VolumeRendering/VolumeStyle.fs +120 -0
  538. package/src/x_ite/Browser/VolumeRendering/VolumeStyle.vs +28 -0
  539. package/src/x_ite/Browser/VolumeRendering/X3DVolumeRenderingContext.js +114 -0
  540. package/src/x_ite/Browser/X3DBrowser.js +282 -182
  541. package/src/x_ite/Browser/X3DBrowserContext.js +77 -43
  542. package/src/x_ite/Components/Annotation/AnnotationLayer.js +108 -0
  543. package/src/x_ite/Components/Annotation/AnnotationTarget.js +101 -0
  544. package/src/x_ite/Components/{PointingDeviceSensor/TouchGroup.js → Annotation/GroupAnnotation.js} +30 -24
  545. package/src/x_ite/Components/Annotation/IconAnnotation.js +110 -0
  546. package/src/x_ite/Components/Annotation/TextAnnotation.js +102 -0
  547. package/src/x_ite/Components/Annotation/URLAnnotation.js +101 -0
  548. package/src/x_ite/Components/Annotation/X3DAnnotationNode.js +76 -0
  549. package/src/x_ite/Components/CADGeometry/CADAssembly.js +6 -8
  550. package/src/x_ite/Components/CADGeometry/CADFace.js +137 -33
  551. package/src/x_ite/Components/CADGeometry/CADLayer.js +5 -18
  552. package/src/x_ite/Components/CADGeometry/CADPart.js +6 -12
  553. package/src/x_ite/Components/CADGeometry/IndexedQuadSet.js +20 -36
  554. package/src/x_ite/Components/CADGeometry/QuadSet.js +11 -24
  555. package/src/x_ite/Components/CADGeometry/X3DProductStructureChildNode.js +2 -4
  556. package/src/x_ite/Components/Core/MetadataBoolean.js +2 -4
  557. package/src/x_ite/Components/Core/MetadataDouble.js +2 -4
  558. package/src/x_ite/Components/Core/MetadataFloat.js +2 -4
  559. package/src/x_ite/Components/Core/MetadataInteger.js +2 -4
  560. package/src/x_ite/Components/Core/MetadataSet.js +2 -4
  561. package/src/x_ite/Components/Core/MetadataString.js +2 -4
  562. package/src/x_ite/Components/Core/WorldInfo.js +18 -10
  563. package/src/x_ite/Components/Core/X3DBindableNode.js +5 -36
  564. package/src/x_ite/Components/Core/X3DChildNode.js +16 -5
  565. package/src/x_ite/Components/Core/X3DInfoNode.js +2 -4
  566. package/src/x_ite/Components/Core/X3DMetadataObject.js +1 -3
  567. package/src/x_ite/Components/Core/X3DNode.js +2 -64
  568. package/src/x_ite/Components/Core/X3DPrototypeInstance.js +190 -210
  569. package/src/x_ite/Components/Core/X3DSensorNode.js +2 -4
  570. package/src/x_ite/Components/Core.js +111 -0
  571. package/src/x_ite/Components/CubeMapTexturing/ComposedCubeMapTexture.js +42 -50
  572. package/src/x_ite/Components/CubeMapTexturing/GeneratedCubeMapTexture.js +41 -42
  573. package/src/x_ite/Components/CubeMapTexturing/ImageCubeMapTexture.js +44 -59
  574. package/src/x_ite/Components/CubeMapTexturing/X3DEnvironmentTextureNode.js +48 -46
  575. package/src/x_ite/Components/DIS/DISEntityManager.js +2 -4
  576. package/src/x_ite/Components/DIS/DISEntityTypeMapping.js +2 -4
  577. package/src/x_ite/Components/DIS/EspduTransform.js +13 -9
  578. package/src/x_ite/Components/DIS/ReceiverPdu.js +13 -9
  579. package/src/x_ite/Components/DIS/SignalPdu.js +13 -9
  580. package/src/x_ite/Components/DIS/TransmitterPdu.js +13 -9
  581. package/src/x_ite/Components/EnvironmentalEffects/Background.js +2 -4
  582. package/src/x_ite/Components/EnvironmentalEffects/Fog.js +15 -18
  583. package/src/x_ite/Components/EnvironmentalEffects/FogCoordinate.js +59 -7
  584. package/src/x_ite/Components/EnvironmentalEffects/LocalFog.js +12 -10
  585. package/src/x_ite/Components/EnvironmentalEffects/TextureBackground.js +2 -4
  586. package/src/x_ite/Components/EnvironmentalEffects/X3DBackgroundNode.js +149 -143
  587. package/src/x_ite/Components/EnvironmentalEffects/X3DFogObject.js +61 -22
  588. package/src/x_ite/Components/EnvironmentalEffects.js +90 -0
  589. package/src/x_ite/Components/EnvironmentalSensor/ProximitySensor.js +121 -121
  590. package/src/x_ite/Components/EnvironmentalSensor/TransformSensor.js +173 -53
  591. package/src/x_ite/Components/EnvironmentalSensor/VisibilitySensor.js +33 -31
  592. package/src/x_ite/Components/EnvironmentalSensor/X3DEnvironmentalSensorNode.js +19 -11
  593. package/src/x_ite/Components/EnvironmentalSensor.js +81 -0
  594. package/src/x_ite/Components/EventUtilities/BooleanFilter.js +2 -4
  595. package/src/x_ite/Components/EventUtilities/BooleanSequencer.js +2 -4
  596. package/src/x_ite/Components/EventUtilities/BooleanToggle.js +2 -4
  597. package/src/x_ite/Components/EventUtilities/BooleanTrigger.js +2 -4
  598. package/src/x_ite/Components/EventUtilities/IntegerSequencer.js +2 -4
  599. package/src/x_ite/Components/EventUtilities/IntegerTrigger.js +2 -4
  600. package/src/x_ite/Components/EventUtilities/TimeTrigger.js +2 -4
  601. package/src/x_ite/Components/EventUtilities/X3DSequencerNode.js +2 -4
  602. package/src/x_ite/Components/EventUtilities/X3DTriggerNode.js +2 -4
  603. package/src/x_ite/Components/Followers/ColorChaser.js +3 -7
  604. package/src/x_ite/Components/Followers/ColorDamper.js +3 -7
  605. package/src/x_ite/Components/Followers/CoordinateChaser.js +3 -11
  606. package/src/x_ite/Components/Followers/CoordinateDamper.js +2 -10
  607. package/src/x_ite/Components/Followers/OrientationChaser.js +9 -7
  608. package/src/x_ite/Components/Followers/OrientationDamper.js +9 -7
  609. package/src/x_ite/Components/Followers/PositionChaser.js +3 -7
  610. package/src/x_ite/Components/Followers/PositionChaser2D.js +3 -7
  611. package/src/x_ite/Components/Followers/PositionDamper.js +3 -7
  612. package/src/x_ite/Components/Followers/PositionDamper2D.js +3 -7
  613. package/src/x_ite/Components/Followers/ScalarChaser.js +7 -7
  614. package/src/x_ite/Components/Followers/ScalarDamper.js +3 -7
  615. package/src/x_ite/Components/Followers/TexCoordChaser2D.js +3 -11
  616. package/src/x_ite/Components/Followers/TexCoordDamper2D.js +3 -11
  617. package/src/x_ite/Components/Followers/X3DChaserNode.js +26 -26
  618. package/src/x_ite/Components/Followers/X3DDamperNode.js +6 -10
  619. package/src/x_ite/Components/Followers/X3DFollowerNode.js +11 -11
  620. package/src/x_ite/Components/Followers.js +120 -0
  621. package/src/x_ite/Components/Geometry2D/Arc2D.js +28 -30
  622. package/src/x_ite/Components/Geometry2D/ArcClose2D.js +95 -93
  623. package/src/x_ite/Components/Geometry2D/Circle2D.js +16 -15
  624. package/src/x_ite/Components/Geometry2D/Disk2D.js +80 -88
  625. package/src/x_ite/Components/Geometry2D/Polyline2D.js +13 -19
  626. package/src/x_ite/Components/Geometry2D/Polypoint2D.js +12 -18
  627. package/src/x_ite/Components/Geometry2D/Rectangle2D.js +13 -13
  628. package/src/x_ite/Components/Geometry2D/TriangleSet2D.js +31 -30
  629. package/src/x_ite/Components/Geometry3D/Box.js +12 -12
  630. package/src/x_ite/Components/Geometry3D/Cone.js +34 -36
  631. package/src/x_ite/Components/Geometry3D/Cylinder.js +52 -54
  632. package/src/x_ite/Components/Geometry3D/ElevationGrid.js +90 -52
  633. package/src/x_ite/Components/Geometry3D/Extrusion.js +472 -388
  634. package/src/x_ite/Components/Geometry3D/IndexedFaceSet.js +193 -163
  635. package/src/x_ite/Components/Geometry3D/Sphere.js +17 -19
  636. package/src/x_ite/Components/Geometry3D.js +90 -0
  637. package/src/x_ite/Components/Geospatial/GeoCoordinate.js +124 -61
  638. package/src/x_ite/Components/Geospatial/GeoElevationGrid.js +54 -36
  639. package/src/x_ite/Components/Geospatial/GeoLOD.js +190 -98
  640. package/src/x_ite/Components/Geospatial/GeoLocation.js +8 -10
  641. package/src/x_ite/Components/Geospatial/GeoMetadata.js +2 -4
  642. package/src/x_ite/Components/Geospatial/GeoOrigin.js +2 -4
  643. package/src/x_ite/Components/Geospatial/GeoPositionInterpolator.js +4 -4
  644. package/src/x_ite/Components/Geospatial/GeoProximitySensor.js +10 -7
  645. package/src/x_ite/Components/Geospatial/GeoTouchSensor.js +4 -4
  646. package/src/x_ite/Components/Geospatial/GeoTransform.js +13 -13
  647. package/src/x_ite/Components/Geospatial/GeoViewpoint.js +131 -78
  648. package/src/x_ite/Components/Geospatial/X3DGeospatialObject.js +7 -9
  649. package/src/x_ite/Components/Grouping/Group.js +5 -7
  650. package/src/x_ite/Components/Grouping/StaticGroup.js +194 -22
  651. package/src/x_ite/Components/Grouping/Switch.js +174 -25
  652. package/src/x_ite/Components/Grouping/Transform.js +5 -7
  653. package/src/x_ite/Components/Grouping/X3DBoundedObject.js +70 -16
  654. package/src/x_ite/Components/Grouping/X3DGroupingNode.js +442 -151
  655. package/src/x_ite/Components/Grouping/X3DTransformMatrix3DNode.js +53 -29
  656. package/src/x_ite/Components/Grouping/X3DTransformNode.js +6 -9
  657. package/src/x_ite/Components/Grouping.js +93 -0
  658. package/src/x_ite/Components/{H-Anim → HAnim}/HAnimDisplacer.js +8 -10
  659. package/src/x_ite/Components/HAnim/HAnimHumanoid.js +360 -0
  660. package/src/x_ite/Components/{H-Anim → HAnim}/HAnimJoint.js +108 -23
  661. package/src/x_ite/Components/HAnim/HAnimMotion.js +113 -0
  662. package/src/x_ite/Components/{H-Anim → HAnim}/HAnimSegment.js +14 -14
  663. package/src/x_ite/Components/{H-Anim → HAnim}/HAnimSite.js +14 -16
  664. package/src/x_ite/Components/Interpolation/ColorInterpolator.js +13 -11
  665. package/src/x_ite/Components/Interpolation/CoordinateInterpolator.js +21 -13
  666. package/src/x_ite/Components/Interpolation/CoordinateInterpolator2D.js +19 -11
  667. package/src/x_ite/Components/Interpolation/EaseInEaseOut.js +8 -8
  668. package/src/x_ite/Components/Interpolation/NormalInterpolator.js +28 -14
  669. package/src/x_ite/Components/Interpolation/OrientationInterpolator.js +27 -16
  670. package/src/x_ite/Components/Interpolation/PositionInterpolator.js +10 -8
  671. package/src/x_ite/Components/Interpolation/PositionInterpolator2D.js +10 -8
  672. package/src/x_ite/Components/Interpolation/ScalarInterpolator.js +2 -4
  673. package/src/x_ite/Components/Interpolation/SplinePositionInterpolator.js +7 -9
  674. package/src/x_ite/Components/Interpolation/SplinePositionInterpolator2D.js +7 -9
  675. package/src/x_ite/Components/Interpolation/SplineScalarInterpolator.js +7 -9
  676. package/src/x_ite/Components/Interpolation/SquadOrientationInterpolator.js +10 -11
  677. package/src/x_ite/Components/Interpolation/X3DInterpolatorNode.js +2 -4
  678. package/src/x_ite/Components/Interpolation.js +111 -0
  679. package/src/x_ite/Components/KeyDeviceSensor/KeySensor.js +72 -8
  680. package/src/x_ite/Components/KeyDeviceSensor/StringSensor.js +65 -4
  681. package/src/x_ite/Components/KeyDeviceSensor/X3DKeyDeviceSensorNode.js +5 -29
  682. package/src/x_ite/Components/Layering/Layer.js +14 -6
  683. package/src/x_ite/Components/Layering/LayerSet.js +6 -10
  684. package/src/x_ite/Components/Layering/Viewport.js +10 -12
  685. package/src/x_ite/Components/Layering/X3DLayerNode.js +76 -69
  686. package/src/x_ite/Components/Layering/X3DViewportNode.js +2 -6
  687. package/src/x_ite/Components/Layering.js +84 -0
  688. package/src/x_ite/Components/Layout/Layout.js +163 -173
  689. package/src/x_ite/Components/Layout/LayoutGroup.js +20 -19
  690. package/src/x_ite/Components/Layout/LayoutLayer.js +12 -9
  691. package/src/x_ite/Components/Layout/ScreenFontStyle.js +4 -8
  692. package/src/x_ite/Components/Layout/ScreenGroup.js +63 -56
  693. package/src/x_ite/Components/Layout/X3DLayoutNode.js +2 -4
  694. package/src/x_ite/Components/Lighting/DirectionalLight.js +41 -31
  695. package/src/x_ite/Components/Lighting/PointLight.js +117 -104
  696. package/src/x_ite/Components/Lighting/SpotLight.js +77 -53
  697. package/src/x_ite/Components/Lighting/X3DLightNode.js +90 -68
  698. package/src/x_ite/Components/Lighting.js +81 -0
  699. package/src/x_ite/Components/NURBS/Contour2D.js +47 -5
  700. package/src/x_ite/Components/NURBS/ContourPolyline2D.js +69 -5
  701. package/src/x_ite/Components/NURBS/CoordinateDouble.js +2 -4
  702. package/src/x_ite/Components/NURBS/NurbsCurve.js +140 -10
  703. package/src/x_ite/Components/NURBS/NurbsCurve2D.js +117 -8
  704. package/src/x_ite/Components/NURBS/NurbsOrientationInterpolator.js +139 -10
  705. package/src/x_ite/Components/NURBS/NurbsPatchSurface.js +3 -5
  706. package/src/x_ite/Components/NURBS/NurbsPositionInterpolator.js +125 -10
  707. package/src/x_ite/Components/NURBS/NurbsSet.js +92 -11
  708. package/src/x_ite/Components/NURBS/NurbsSurfaceInterpolator.js +96 -12
  709. package/src/x_ite/Components/NURBS/NurbsSweptSurface.js +88 -7
  710. package/src/x_ite/Components/NURBS/NurbsSwungSurface.js +88 -7
  711. package/src/x_ite/Components/NURBS/NurbsTextureCoordinate.js +62 -13
  712. package/src/x_ite/Components/NURBS/NurbsTrimmedSurface.js +41 -6
  713. package/src/x_ite/Components/NURBS/X3DNurbsControlCurveNode.js +2 -4
  714. package/src/x_ite/Components/NURBS/X3DNurbsSurfaceGeometryNode.js +333 -7
  715. package/src/x_ite/Components/NURBS/X3DParametricGeometryNode.js +9 -5
  716. package/src/x_ite/Components/Navigation/Billboard.js +14 -15
  717. package/src/x_ite/Components/Navigation/Collision.js +13 -12
  718. package/src/x_ite/Components/Navigation/LOD.js +221 -66
  719. package/src/x_ite/Components/Navigation/NavigationInfo.js +110 -99
  720. package/src/x_ite/Components/Navigation/OrthoViewpoint.js +138 -45
  721. package/src/x_ite/Components/Navigation/Viewpoint.js +55 -33
  722. package/src/x_ite/Components/Navigation/ViewpointGroup.js +18 -10
  723. package/src/x_ite/Components/Navigation/X3DViewpointNode.js +241 -181
  724. package/src/x_ite/Components/Navigation.js +93 -0
  725. package/src/x_ite/Components/Networking/Anchor.js +24 -28
  726. package/src/x_ite/Components/Networking/Inline.js +68 -50
  727. package/src/x_ite/Components/Networking/LoadSensor.js +2 -4
  728. package/src/x_ite/Components/Networking/X3DNetworkSensorNode.js +2 -4
  729. package/src/x_ite/Components/Networking/X3DUrlObject.js +93 -11
  730. package/src/x_ite/Components/Networking.js +84 -0
  731. package/src/x_ite/Components/ParticleSystems/BoundedPhysicsModel.js +6 -8
  732. package/src/x_ite/Components/ParticleSystems/ConeEmitter.js +8 -4
  733. package/src/x_ite/Components/ParticleSystems/ExplosionEmitter.js +7 -4
  734. package/src/x_ite/Components/ParticleSystems/ForcePhysicsModel.js +4 -4
  735. package/src/x_ite/Components/ParticleSystems/ParticleSystem.js +451 -287
  736. package/src/x_ite/Components/ParticleSystems/PointEmitter.js +7 -4
  737. package/src/x_ite/Components/ParticleSystems/PolylineEmitter.js +53 -40
  738. package/src/x_ite/Components/ParticleSystems/SurfaceEmitter.js +62 -55
  739. package/src/x_ite/Components/ParticleSystems/VolumeEmitter.js +133 -123
  740. package/src/x_ite/Components/ParticleSystems/WindPhysicsModel.js +25 -22
  741. package/src/x_ite/Components/ParticleSystems/X3DParticleEmitterNode.js +28 -27
  742. package/src/x_ite/Components/ParticleSystems/X3DParticlePhysicsModelNode.js +2 -4
  743. package/src/x_ite/Components/Picking/LinePickSensor.js +253 -10
  744. package/src/x_ite/Components/Picking/PickableGroup.js +121 -10
  745. package/src/x_ite/Components/Picking/PointPickSensor.js +262 -12
  746. package/src/x_ite/Components/Picking/PrimitivePickSensor.js +176 -8
  747. package/src/x_ite/Components/Picking/VolumePickSensor.js +152 -8
  748. package/src/x_ite/Components/Picking/X3DPickSensorNode.js +378 -7
  749. package/src/x_ite/Components/Picking/X3DPickableObject.js +22 -4
  750. package/src/x_ite/Components/PointingDeviceSensor/CylinderSensor.js +33 -15
  751. package/src/x_ite/Components/PointingDeviceSensor/PlaneSensor.js +7 -4
  752. package/src/x_ite/Components/PointingDeviceSensor/SphereSensor.js +2 -4
  753. package/src/x_ite/Components/PointingDeviceSensor/TouchSensor.js +4 -4
  754. package/src/x_ite/Components/PointingDeviceSensor/X3DDragSensorNode.js +4 -4
  755. package/src/x_ite/Components/PointingDeviceSensor/X3DPointingDeviceSensorNode.js +3 -5
  756. package/src/x_ite/Components/PointingDeviceSensor/X3DTouchSensorNode.js +2 -4
  757. package/src/x_ite/Components/PointingDeviceSensor.js +90 -0
  758. package/src/x_ite/Components/ProjectiveTextureMapping/TextureProjectorParallel.js +282 -0
  759. package/src/x_ite/Components/ProjectiveTextureMapping/TextureProjectorPerspective.js +227 -0
  760. package/src/x_ite/Components/ProjectiveTextureMapping/X3DTextureProjectorNode.js +217 -0
  761. package/src/x_ite/Components/Rendering/ClipPlane.js +12 -16
  762. package/src/x_ite/Components/Rendering/Color.js +62 -17
  763. package/src/x_ite/Components/Rendering/ColorRGBA.js +65 -17
  764. package/src/x_ite/Components/Rendering/Coordinate.js +4 -4
  765. package/src/x_ite/Components/Rendering/IndexedLineSet.js +68 -81
  766. package/src/x_ite/Components/Rendering/IndexedTriangleFanSet.js +20 -19
  767. package/src/x_ite/Components/Rendering/IndexedTriangleSet.js +10 -7
  768. package/src/x_ite/Components/Rendering/IndexedTriangleStripSet.js +21 -23
  769. package/src/x_ite/Components/Rendering/LineSet.js +54 -37
  770. package/src/x_ite/Components/Rendering/Normal.js +65 -13
  771. package/src/x_ite/Components/Rendering/PointSet.js +52 -33
  772. package/src/x_ite/Components/Rendering/TriangleFanSet.js +10 -14
  773. package/src/x_ite/Components/Rendering/TriangleSet.js +2 -4
  774. package/src/x_ite/Components/Rendering/TriangleStripSet.js +9 -13
  775. package/src/x_ite/Components/Rendering/X3DColorNode.js +13 -12
  776. package/src/x_ite/Components/Rendering/X3DComposedGeometryNode.js +118 -79
  777. package/src/x_ite/Components/Rendering/X3DCoordinateNode.js +103 -44
  778. package/src/x_ite/Components/Rendering/X3DGeometricPropertyNode.js +2 -4
  779. package/src/x_ite/Components/Rendering/X3DGeometryNode.js +722 -591
  780. package/src/x_ite/Components/Rendering/X3DLineGeometryNode.js +129 -92
  781. package/src/x_ite/Components/Rendering/X3DNormalNode.js +2 -4
  782. package/src/x_ite/Components/Rendering.js +132 -0
  783. package/src/x_ite/Components/RigidBodyPhysics/BallJoint.js +116 -7
  784. package/src/x_ite/Components/RigidBodyPhysics/CollidableOffset.js +199 -11
  785. package/src/x_ite/Components/RigidBodyPhysics/CollidableShape.js +436 -11
  786. package/src/x_ite/Components/RigidBodyPhysics/CollisionCollection.js +118 -10
  787. package/src/x_ite/Components/RigidBodyPhysics/CollisionSensor.js +192 -9
  788. package/src/x_ite/Components/RigidBodyPhysics/CollisionSpace.js +84 -8
  789. package/src/x_ite/Components/RigidBodyPhysics/Contact.js +20 -14
  790. package/src/x_ite/Components/RigidBodyPhysics/DoubleAxisHingeJoint.js +200 -12
  791. package/src/x_ite/Components/RigidBodyPhysics/MotorJoint.js +14 -4
  792. package/src/x_ite/Components/RigidBodyPhysics/RigidBody.js +424 -17
  793. package/src/x_ite/Components/RigidBodyPhysics/RigidBodyCollection.js +295 -19
  794. package/src/x_ite/Components/RigidBodyPhysics/SingleAxisHingeJoint.js +162 -10
  795. package/src/x_ite/Components/RigidBodyPhysics/SliderJoint.js +135 -8
  796. package/src/x_ite/Components/RigidBodyPhysics/UniversalJoint.js +10 -6
  797. package/src/x_ite/Components/RigidBodyPhysics/X3DNBodyCollidableNode.js +93 -9
  798. package/src/x_ite/Components/RigidBodyPhysics/X3DNBodyCollisionSpaceNode.js +5 -8
  799. package/src/x_ite/Components/RigidBodyPhysics/X3DRigidJointNode.js +150 -4
  800. package/src/x_ite/Components/Scripting/Script.js +156 -105
  801. package/src/x_ite/Components/Scripting/X3DScriptNode.js +3 -7
  802. package/src/x_ite/Components/Shaders/ComposedShader.js +38 -53
  803. package/src/x_ite/Components/Shaders/FloatVertexAttribute.js +38 -15
  804. package/src/x_ite/Components/Shaders/Matrix3VertexAttribute.js +32 -14
  805. package/src/x_ite/Components/Shaders/Matrix4VertexAttribute.js +32 -14
  806. package/src/x_ite/Components/Shaders/PackagedShader.js +19 -17
  807. package/src/x_ite/Components/Shaders/ProgramShader.js +2 -4
  808. package/src/x_ite/Components/Shaders/ShaderPart.js +38 -26
  809. package/src/x_ite/Components/Shaders/ShaderProgram.js +16 -14
  810. package/src/x_ite/Components/Shaders/X3DProgrammableShaderObject.js +836 -699
  811. package/src/x_ite/Components/Shaders/X3DShaderNode.js +61 -101
  812. package/src/x_ite/Components/Shaders/X3DVertexAttributeNode.js +2 -4
  813. package/src/x_ite/Components/Shaders.js +102 -0
  814. package/src/x_ite/Components/Shape/Appearance.js +179 -69
  815. package/src/x_ite/Components/Shape/FillProperties.js +65 -8
  816. package/src/x_ite/Components/Shape/LineProperties.js +29 -9
  817. package/src/x_ite/Components/Shape/Material.js +50 -64
  818. package/src/x_ite/Components/Shape/PointProperties.js +162 -0
  819. package/src/x_ite/Components/Shape/Shape.js +116 -68
  820. package/src/x_ite/Components/Shape/TwoSidedMaterial.js +56 -62
  821. package/src/x_ite/Components/Shape/UnlitMaterial.js +109 -0
  822. package/src/x_ite/Components/Shape/X3DAppearanceChildNode.js +2 -4
  823. package/src/x_ite/Components/Shape/X3DAppearanceNode.js +14 -11
  824. package/src/x_ite/Components/Shape/X3DMaterialNode.js +17 -6
  825. package/src/x_ite/Components/Shape/X3DOneSidedMaterialNode.js +111 -0
  826. package/src/x_ite/Components/Shape/X3DShapeNode.js +54 -29
  827. package/src/x_ite/Components/Shape.js +108 -0
  828. package/src/x_ite/Components/Sound/AudioClip.js +47 -57
  829. package/src/x_ite/Components/Sound/Sound.js +177 -83
  830. package/src/x_ite/Components/Sound/X3DSoundNode.js +2 -4
  831. package/src/x_ite/Components/Sound/X3DSoundSourceNode.js +38 -24
  832. package/src/x_ite/Components/Sound.js +81 -0
  833. package/src/x_ite/Components/Text/FontStyle.js +4 -6
  834. package/src/x_ite/Components/Text/Text.js +21 -18
  835. package/src/x_ite/Components/Text/X3DFontStyleNode.js +58 -93
  836. package/src/x_ite/Components/Text.js +78 -0
  837. package/src/x_ite/Components/Texturing/ImageTexture.js +57 -67
  838. package/src/x_ite/Components/Texturing/MovieTexture.js +59 -70
  839. package/src/x_ite/Components/Texturing/MultiTexture.js +238 -15
  840. package/src/x_ite/Components/Texturing/MultiTextureCoordinate.js +85 -8
  841. package/src/x_ite/Components/Texturing/MultiTextureTransform.js +47 -8
  842. package/src/x_ite/Components/Texturing/PixelTexture.js +61 -27
  843. package/src/x_ite/Components/Texturing/TextureCoordinate.js +72 -22
  844. package/src/x_ite/Components/Texturing/TextureCoordinateGenerator.js +69 -11
  845. package/src/x_ite/Components/Texturing/TextureProperties.js +98 -69
  846. package/src/x_ite/Components/Texturing/TextureTransform.js +58 -52
  847. package/src/x_ite/Components/Texturing/X3DSingleTextureCoordinateNode.js +91 -0
  848. package/src/x_ite/Components/Texturing/X3DSingleTextureNode.js +183 -0
  849. package/src/x_ite/Components/Texturing/X3DSingleTextureTransformNode.js +77 -0
  850. package/src/x_ite/Components/Texturing/X3DTexture2DNode.js +42 -97
  851. package/src/x_ite/Components/Texturing/X3DTexture2DNode.js.~1~ +209 -0
  852. package/src/x_ite/Components/Texturing/X3DTextureCoordinateNode.js +4 -12
  853. package/src/x_ite/Components/Texturing/X3DTextureNode.js +10 -71
  854. package/src/x_ite/Components/Texturing/X3DTextureTransformNode.js +5 -14
  855. package/src/x_ite/Components/Texturing.js +120 -0
  856. package/src/x_ite/Components/Texturing3D/ComposedTexture3D.js +90 -8
  857. package/src/x_ite/Components/Texturing3D/ImageTexture3D.js +106 -16
  858. package/src/x_ite/Components/Texturing3D/PixelTexture3D.js +126 -8
  859. package/src/x_ite/Components/Texturing3D/TextureCoordinate3D.js +75 -25
  860. package/src/x_ite/Components/Texturing3D/TextureCoordinate4D.js +74 -24
  861. package/src/x_ite/Components/Texturing3D/TextureTransform3D.js +42 -36
  862. package/src/x_ite/Components/Texturing3D/TextureTransformMatrix3D.js +19 -16
  863. package/src/x_ite/Components/Texturing3D/X3DTexture3DNode.js +110 -8
  864. package/src/x_ite/Components/Time/TimeSensor.js +68 -38
  865. package/src/x_ite/Components/Time/X3DTimeDependentNode.js +29 -29
  866. package/src/x_ite/Components/Time.js +75 -0
  867. package/src/x_ite/Components/VolumeRendering/BlendedVolumeStyle.js +311 -12
  868. package/src/x_ite/Components/VolumeRendering/BoundaryEnhancementVolumeStyle.js +60 -8
  869. package/src/x_ite/Components/VolumeRendering/CartoonVolumeStyle.js +219 -10
  870. package/src/x_ite/Components/VolumeRendering/ComposedVolumeStyle.js +134 -7
  871. package/src/x_ite/Components/VolumeRendering/EdgeEnhancementVolumeStyle.js +88 -9
  872. package/src/x_ite/Components/VolumeRendering/IsoSurfaceVolumeData.js +311 -15
  873. package/src/x_ite/Components/VolumeRendering/OpacityMapVolumeStyle.js +87 -7
  874. package/src/x_ite/Components/VolumeRendering/ProjectionVolumeStyle.js +136 -6
  875. package/src/x_ite/Components/VolumeRendering/SegmentedVolumeData.js +224 -13
  876. package/src/x_ite/Components/VolumeRendering/ShadedVolumeStyle.js +193 -12
  877. package/src/x_ite/Components/VolumeRendering/SilhouetteEnhancementVolumeStyle.js +87 -10
  878. package/src/x_ite/Components/VolumeRendering/ToneMappedVolumeStyle.js +97 -9
  879. package/src/x_ite/Components/VolumeRendering/VolumeData.js +155 -12
  880. package/src/x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode.js +2 -4
  881. package/src/x_ite/Components/VolumeRendering/X3DVolumeDataNode.js +155 -5
  882. package/src/x_ite/Components/VolumeRendering/X3DVolumeRenderStyleNode.js +64 -4
  883. package/src/x_ite/Components/X_ITE/BlendMode.js +206 -0
  884. package/src/x_ite/Components.js +110 -0
  885. package/src/x_ite/Configuration/ComponentInfo.js +21 -15
  886. package/src/x_ite/Configuration/ComponentInfoArray.js +11 -16
  887. package/src/x_ite/Configuration/ProfileInfo.js +10 -10
  888. package/src/x_ite/Configuration/ProfileInfoArray.js +10 -3
  889. package/src/x_ite/Configuration/SupportedComponents.js +312 -303
  890. package/src/x_ite/Configuration/SupportedNodes.js +44 -716
  891. package/src/x_ite/Configuration/SupportedProfiles.js +196 -168
  892. package/src/x_ite/Configuration/UnitInfo.js +22 -8
  893. package/src/x_ite/Configuration/UnitInfoArray.js +2 -3
  894. package/src/x_ite/Configuration/X3DInfoArray.js +46 -26
  895. package/src/x_ite/DEBUG.js +4 -5
  896. package/src/x_ite/Execution/BindableList.js +99 -34
  897. package/src/x_ite/Execution/BindableStack.js +65 -74
  898. package/src/x_ite/Execution/ExportedNode.js +32 -9
  899. package/src/x_ite/Execution/ImportedNode.js +144 -63
  900. package/src/x_ite/Execution/Scene.js +33 -35
  901. package/src/x_ite/Execution/World.js +31 -29
  902. package/src/x_ite/Execution/X3DExecutionContext.js +452 -194
  903. package/src/x_ite/Execution/X3DScene.js +303 -74
  904. package/src/x_ite/{Error.js → Fallback.js} +25 -24
  905. package/src/x_ite/Fields/ArrayFields.js +315 -112
  906. package/src/x_ite/Fields/SFBool.js +11 -10
  907. package/src/x_ite/Fields/SFColor.js +43 -19
  908. package/src/x_ite/Fields/SFColorRGBA.js +40 -18
  909. package/src/x_ite/Fields/SFDouble.js +17 -10
  910. package/src/x_ite/Fields/SFFloat.js +18 -11
  911. package/src/x_ite/Fields/SFImage.js +47 -38
  912. package/src/x_ite/Fields/SFInt32.js +10 -9
  913. package/src/x_ite/Fields/SFMatrix3.js +24 -17
  914. package/src/x_ite/Fields/SFMatrix4.js +24 -17
  915. package/src/x_ite/Fields/SFMatrixPrototypeTemplate.js +15 -8
  916. package/src/x_ite/Fields/SFNode.js +119 -39
  917. package/src/x_ite/Fields/SFNodeCache.js +89 -0
  918. package/src/x_ite/Fields/SFRotation.js +42 -27
  919. package/src/x_ite/Fields/SFString.js +14 -15
  920. package/src/x_ite/Fields/SFTime.js +12 -11
  921. package/src/x_ite/Fields/SFVec2.js +17 -14
  922. package/src/x_ite/Fields/SFVec3.js +23 -17
  923. package/src/x_ite/Fields/SFVec4.js +25 -19
  924. package/src/x_ite/Fields/SFVecPrototypeTemplate.js +51 -19
  925. package/src/x_ite/Fields.js +3 -9
  926. package/src/x_ite/InputOutput/FileLoader.js +264 -181
  927. package/src/x_ite/InputOutput/Generator.js +136 -60
  928. package/src/x_ite/Parser/HTMLSupport.js +3 -596
  929. package/src/x_ite/Parser/JSONParser.js +446 -0
  930. package/src/x_ite/Parser/Parser.js +617 -652
  931. package/src/x_ite/Parser/X3DParser.js +176 -0
  932. package/src/x_ite/Parser/XMLParser.js +359 -94
  933. package/src/x_ite/Prototype/ExternProtoDeclarationArray.js +19 -3
  934. package/src/x_ite/Prototype/ProtoDeclarationArray.js +19 -3
  935. package/src/x_ite/Prototype/X3DExternProtoDeclaration.js +120 -61
  936. package/src/x_ite/Prototype/X3DProtoDeclaration.js +144 -59
  937. package/src/x_ite/Prototype/X3DProtoDeclarationNode.js +16 -18
  938. package/src/x_ite/Rendering/DependentRenderer.js +9 -13
  939. package/src/x_ite/Rendering/{DepthBuffer.js → TextureBuffer.js} +84 -53
  940. package/src/x_ite/Rendering/X3DRenderObject.js +640 -531
  941. package/src/x_ite/Routing/RouteArray.js +38 -16
  942. package/src/x_ite/Routing/X3DRoute.js +67 -68
  943. package/src/x_ite/Routing/X3DRoutingContext.js +6 -6
  944. package/src/x_ite/X3D.js +74 -70
  945. package/src/x_ite.config.js +91 -0
  946. package/src/x_ite.css +175 -53
  947. package/src/x_ite.html +128 -439
  948. package/src/x_ite.js +87 -25
  949. package/tests/{SEE.txt → README.md} +1 -0
  950. package/tests/tests.mdproj +1 -1
  951. package/x_ite.min.html +128 -439
  952. package/.bzrignore +0 -3
  953. package/.npmignore +0 -3
  954. package/AUTHORS.md +0 -6
  955. package/STYLE_GUIDE.md +0 -51
  956. package/X_ITE.sln +0 -56
  957. package/X_ITE.userprefs +0 -13
  958. package/build/build.mdproj +0 -24
  959. package/build/dist.pl +0 -97
  960. package/build/parts/end.frag +0 -10
  961. package/build/parts/start.frag +0 -7
  962. package/dist/LICENCES.txt +0 -344
  963. package/dist/dist.mdproj +0 -45
  964. package/dist/images/logo.128.png +0 -0
  965. package/fonts/fonts.mdproj +0 -29
  966. package/meta/meta.mdproj +0 -35
  967. package/require.build.js +0 -15
  968. package/require.build.min.js +0 -15
  969. package/src/images/logo.128.png +0 -0
  970. package/src/lib/jquery-contextMenu/README.md +0 -355
  971. package/src/lib/jquery-contextMenu/dist/images/cut.png +0 -0
  972. package/src/lib/jquery-contextMenu/dist/images/door.png +0 -0
  973. package/src/lib/jquery-contextMenu/dist/images/page_white_add.png +0 -0
  974. package/src/lib/jquery-contextMenu/dist/images/page_white_copy.png +0 -0
  975. package/src/lib/jquery-contextMenu/dist/images/page_white_delete.png +0 -0
  976. package/src/lib/jquery-contextMenu/dist/images/page_white_edit.png +0 -0
  977. package/src/lib/jquery-contextMenu/dist/images/page_white_paste.png +0 -0
  978. package/src/lib/jquery-contextMenu/dist/jquery.contextMenu.css +0 -155
  979. package/src/lib/jquery-contextMenu/dist/jquery.contextMenu.js +0 -1811
  980. package/src/lib/jquery-contextMenu/dist/jquery.contextMenu.min.css +0 -16
  981. package/src/lib/jquery-contextMenu/dist/jquery.contextMenu.min.css.map +0 -1
  982. package/src/lib/jquery-contextMenu/dist/jquery.contextMenu.min.js +0 -18
  983. package/src/lib/jquery-contextMenu/dist/jquery.contextMenu.min.js.map +0 -1
  984. package/src/lib/jquery-contextMenu/dist/jquery.ui.position.js +0 -517
  985. package/src/lib/jquery-contextMenu/dist/jquery.ui.position.min.js +0 -4
  986. package/src/lib/jquery-contextMenu/package.json +0 -99
  987. package/src/lib/opentype.js/.npmignore +0 -5
  988. package/src/locale/de.mo +0 -0
  989. package/src/locale/fr.mo +0 -0
  990. package/src/require.config.js +0 -51
  991. package/src/src.mdproj +0 -729
  992. package/src/standard/Networking/URI.js +0 -687
  993. package/src/x_ite/Browser/Shaders/BackgroundSphereFragmentShader.fs +0 -29
  994. package/src/x_ite/Browser/Shaders/BackgroundSphereVertexShader.vs +0 -22
  995. package/src/x_ite/Browser/Shaders/Bits/Line3.h +0 -14
  996. package/src/x_ite/Browser/Shaders/Bits/Plane3.h +0 -47
  997. package/src/x_ite/Browser/Shaders/Bits/Random.h +0 -31
  998. package/src/x_ite/Browser/Shaders/Depth.fs +0 -51
  999. package/src/x_ite/Browser/Shaders/Depth.vs +0 -20
  1000. package/src/x_ite/Browser/Shaders/Gouraud.fs +0 -110
  1001. package/src/x_ite/Browser/Shaders/Gouraud.vs +0 -188
  1002. package/src/x_ite/Browser/Shaders/Phong.fs +0 -255
  1003. package/src/x_ite/Browser/Shaders/Phong.vs +0 -38
  1004. package/src/x_ite/Browser/Shaders/PointSet.fs +0 -64
  1005. package/src/x_ite/Browser/Shaders/Wireframe.fs +0 -61
  1006. package/src/x_ite/Browser/Shaders/Wireframe.vs +0 -55
  1007. package/src/x_ite/Components/H-Anim/HAnimHumanoid.js +0 -118
@@ -0,0 +1,1126 @@
1
+ /* -*- Mode: JavaScript; coding: utf-8; tab-width: 3; indent-tabs-mode: tab; c-basic-offset: 3 -*-
2
+ *******************************************************************************
3
+ *
4
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5
+ *
6
+ * Copyright create3000, Scheffelstraße 31a, Leipzig, Germany 2011.
7
+ *
8
+ * All rights reserved. Holger Seelig <holger.seelig@yahoo.de>.
9
+ *
10
+ * The copyright notice above does not evidence any actual of intended
11
+ * publication of such source code, and is an unpublished work by create3000.
12
+ * This material contains CONFIDENTIAL INFORMATION that is the property of
13
+ * create3000.
14
+ *
15
+ * No permission is granted to copy, distribute, or create derivative works from
16
+ * the contents of this software, in whole or in part, without the prior written
17
+ * permission of create3000.
18
+ *
19
+ * NON-MILITARY USE ONLY
20
+ *
21
+ * All create3000 software are effectively free software with a non-military use
22
+ * restriction. It is free. Well commented source is provided. You may reuse the
23
+ * source in any way you please with the exception anything that uses it must be
24
+ * marked to indicate is contains 'non-military use only' components.
25
+ *
26
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
27
+ *
28
+ * Copyright 2015, 2016 Holger Seelig <holger.seelig@yahoo.de>.
29
+ *
30
+ * This file is part of the X_ITE Project.
31
+ *
32
+ * X_ITE is free software: you can redistribute it and/or modify it under the
33
+ * terms of the GNU General Public License version 3 only, as published by the
34
+ * Free Software Foundation.
35
+ *
36
+ * X_ITE is distributed in the hope that it will be useful, but WITHOUT ANY
37
+ * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
38
+ * A PARTICULAR PURPOSE. See the GNU General Public License version 3 for more
39
+ * details (a copy is included in the LICENSE file that accompanied this code).
40
+ *
41
+ * You should have received a copy of the GNU General Public License version 3
42
+ * along with X_ITE. If not, see <http://www.gnu.org/licenses/gpl.html> for a
43
+ * copy of the GPLv3 License.
44
+ *
45
+ * For Silvio, Joy and Adi.
46
+ *
47
+ ******************************************************************************/
48
+
49
+
50
+ define ([
51
+ "dicom-parser",
52
+ "lib/jpeg/jpeg",
53
+ "jpegLossless",
54
+ "CharLS",
55
+ "OpenJPEG",
56
+ "x_ite/DEBUG",
57
+ ],
58
+ function (dicomParser,
59
+ jpeg,
60
+ jpegLossless,
61
+ charLS,
62
+ openJPEG,
63
+ DEBUG)
64
+ {
65
+ "use strict";
66
+
67
+ // Global instances of JPEG libraries.
68
+
69
+ var
70
+ charLS = undefined,
71
+ openJPEG = undefined;
72
+
73
+ // DicomParser
74
+
75
+ function DicomParser ()
76
+ {
77
+ this .dicom = { dicom: false };
78
+ }
79
+
80
+ DicomParser .prototype =
81
+ {
82
+ parse: function (input)
83
+ {
84
+ try
85
+ {
86
+ var inputArray = new Uint8Array (input .length);
87
+
88
+ for (var i = 0, length = input .length; i < length; ++ i)
89
+ inputArray [i] = input .charCodeAt (i);
90
+
91
+ this .dataSet = dicomParser .parseDicom (inputArray);
92
+ this .dicom .dicom = true;
93
+ }
94
+ catch (error)
95
+ {
96
+ console .log (error);
97
+ this .dicom .dicom = false;
98
+ return this .dicom;
99
+ }
100
+
101
+ this .getPhotometricInterpretation ();
102
+ this .getComponents ();
103
+ this .getWidth ();
104
+ this .getHeight ();
105
+ this .getDepth ();
106
+ this .getBitsAllocated ();
107
+ this .getBitsStored ();
108
+ this .getPixelRepresentation ();
109
+ this .getPlanarConfiguration ();
110
+ this .getTansferSyntax ();
111
+ this .getPixelData ();
112
+
113
+ if (DEBUG)
114
+ console .log (this);
115
+
116
+ return this .dicom;
117
+ },
118
+ getPhotometricInterpretation: function ()
119
+ {
120
+ // https://dicom.innolitics.com/ciods/ct-image/image-pixel/00280004
121
+ this .photometricInterpretation = this .dataSet .string ("x00280004");
122
+ },
123
+ getComponents: function ()
124
+ {
125
+ // https://dicom.innolitics.com/ciods/ct-image/image-pixel/00280002
126
+ this .dicom .components = this .dataSet .uint16 ("x00280002");
127
+ },
128
+ getWidth: function ()
129
+ {
130
+ this .dicom .width = this .dataSet .uint16 ("x00280011");
131
+ },
132
+ getHeight: function ()
133
+ {
134
+ this .dicom .height = this .dataSet .uint16 ("x00280010");
135
+ },
136
+ getDepth: function ()
137
+ {
138
+ if (this .dataSet .elements .x00280008)
139
+ {
140
+ this .dicom .depth = this .dataSet .intString ("x00280008");
141
+ }
142
+ else
143
+ this .dicom .depth = 1;
144
+ },
145
+ getBitsAllocated: function ()
146
+ {
147
+ this .bitsAllocated = this .dataSet .uint16 ("x00280100");
148
+ },
149
+ getBitsStored: function ()
150
+ {
151
+ this .bitsStored = this .dataSet .uint16 ("x00280101");
152
+ },
153
+ getPixelRepresentation: function ()
154
+ {
155
+ this .pixelRepresentation = this .dataSet .uint16 ("x00280103") || 0;
156
+ },
157
+ getPlanarConfiguration: function ()
158
+ {
159
+ this .planarConfiguration = this .dataSet .uint16 ("x00280006") || 0;
160
+ },
161
+ getTansferSyntax: function ()
162
+ {
163
+ this .transferSyntax = this .dataSet .string ("x00020010");
164
+ },
165
+ getPixelData: function ()
166
+ {
167
+ var
168
+ dicom = this .dicom,
169
+ pixelElement = this .dataSet .elements .x7fe00010 || this .dataSet .elements .x7fe00008, // pixel or float pixel
170
+ components = this .photometricInterpretation === "PALETTE COLOR" ? 3 : this .dicom .components,
171
+ imageLength = dicom .width * dicom .height * components,
172
+ byteLength = imageLength * dicom .depth,
173
+ bytes = new Uint8Array (byteLength),
174
+ frames = this .getFrames (pixelElement);
175
+
176
+ frames .forEach (function (frame, f)
177
+ {
178
+ // Handle transfer syntax.
179
+
180
+ // https://www.dicomlibrary.com/dicom/transfer-syntax/
181
+
182
+ switch (this .transferSyntax)
183
+ {
184
+ case "1.2.840.10008.1.2": // Implicit VR Little Endian
185
+ case "1.2.840.10008.1.2.1": // Explicit VR Little Endian
186
+ case "1.2.840.10008.1.2.1.99": // Deflated Explicit VR Little Endian
187
+ {
188
+ frame = this .decodeLittleEndian (frame);
189
+ break;
190
+ }
191
+ case "1.2.840.10008.1.2.2": // Explicit VR Big Endian (retired)
192
+ {
193
+ frame = this .decodeBigEndian (frame);
194
+ break;
195
+ }
196
+ case "1.2.840.10008.1.2.5": // RLE Lossless
197
+ {
198
+ frame = this .decodeRLE (frame);
199
+ break;
200
+ }
201
+ case "1.2.840.10008.1.2.4.50": // JPEG Baseline lossy process 1 (8 bit)
202
+ case "1.2.840.10008.1.2.4.51": // JPEG Baseline lossy process 2 & 4 (12 bit)
203
+ {
204
+ frame = this .decodeJPEGBaseline (frame);
205
+ break;
206
+ }
207
+ case "1.2.840.10008.1.2.4.57": // JPEG Lossless, Nonhierarchical (Processes 14)
208
+ case "1.2.840.10008.1.2.4.70": // JPEG Lossless, Nonhierarchical (Processes 14 [Selection 1])
209
+ {
210
+ frame = this .decodeJPEGLossless (frame);
211
+ break;
212
+ }
213
+ case "1.2.840.10008.1.2.4.80": // JPEG-LS Lossless Image Compression
214
+ case "1.2.840.10008.1.2.4.81": // JPEG-LS Lossy (Near-Lossless) Image Compression
215
+ {
216
+ frame = this .decodeJPEGLS (frame);
217
+ break;
218
+ }
219
+ case "1.2.840.10008.1.2.4.90": // JPEG 2000 Lossless
220
+ case "1.2.840.10008.1.2.4.91": // JPEG 2000 Lossy
221
+ {
222
+ frame = this .decodeJPEG2000 (frame);
223
+ break;
224
+ }
225
+ case "1.2.840.10008.1.2.4.52":
226
+ case "1.2.840.10008.1.2.4.53":
227
+ case "1.2.840.10008.1.2.4.54":
228
+ case "1.2.840.10008.1.2.4.55":
229
+ case "1.2.840.10008.1.2.4.56":
230
+ case "1.2.840.10008.1.2.4.58":
231
+ case "1.2.840.10008.1.2.4.59":
232
+ case "1.2.840.10008.1.2.4.60":
233
+ case "1.2.840.10008.1.2.4.61":
234
+ case "1.2.840.10008.1.2.4.62":
235
+ case "1.2.840.10008.1.2.4.63":
236
+ case "1.2.840.10008.1.2.4.64":
237
+ case "1.2.840.10008.1.2.4.65":
238
+ case "1.2.840.10008.1.2.4.66":
239
+ case "1.2.840.10008.1.2.4.92":
240
+ case "1.2.840.10008.1.2.4.93":
241
+ {
242
+ // JPEG
243
+ throw new Error ("DICOM: this JPEG encoding (" + this .transferSyntax + ") is not supported.");
244
+ }
245
+ default:
246
+ {
247
+ throw new Error ("DICOM: unsupported transfer syntax '" + this .transferSyntax + "'.");
248
+ }
249
+ }
250
+
251
+ // Convert to stored type array (int, uint, float, 8/16 bit).
252
+
253
+ frame = this .getTypedArray (frame);
254
+
255
+ // Handle bits stored.
256
+
257
+ if (this .pixelRepresentation === 1 && this .bitsStored !== undefined)
258
+ {
259
+ var shift = 32 - this .bitsStored;
260
+
261
+ for (var i = 0, length = frame .length; i < length; ++ i)
262
+ frame [i] = frame [i] << shift >> shift;
263
+ }
264
+
265
+ // Handle photometric interpretation.
266
+
267
+ switch (this .photometricInterpretation)
268
+ {
269
+ case "MONOCHROME1":
270
+ case "MONOCHROME2":
271
+ {
272
+ break;
273
+ }
274
+ case "RGB":
275
+ case "YBR_RCT":
276
+ case "YBR_ICT":
277
+ case "YBR_FULL_422":
278
+ {
279
+ if (this .planarConfiguration === 1)
280
+ frame = this .convertRGBColorByPlane (frame);
281
+
282
+ break;
283
+ }
284
+ case "YBR_FULL":
285
+ {
286
+ if (this .planarConfiguration === 0)
287
+ frame = this .convertYBRFullByPixel (frame);
288
+ else
289
+ frame = this .convertYBRFullByPlane (frame);
290
+
291
+ break;
292
+ }
293
+ case "PALETTE COLOR":
294
+ {
295
+ frame = this .convertPaletteColor (frame);
296
+ break;
297
+ }
298
+ default:
299
+ {
300
+ throw new Error ("DICOM: unsupported image type '" + this .photometricInterpretation + "'.");
301
+ }
302
+ }
303
+
304
+ // Normalize frame pixel data in the range [0, 255], and assign to image block;
305
+
306
+ frame = this .flipImage (frame, components);
307
+
308
+ var
309
+ normalize = this .getNormalizeOffsetAndFactor (frame),
310
+ b = f * imageLength;
311
+
312
+ for (var i = 0, length = frame .length; i < length; ++ i, ++ b)
313
+ bytes [b] = (frame [i] - normalize .offset) * normalize .factor;
314
+ },
315
+ this);
316
+
317
+ // Invert MONOCHROME1 pixels.
318
+
319
+ if (this .photometricInterpretation === "MONOCHROME1")
320
+ {
321
+ for (var i = 0, length = bytes .length; i < length; ++ i)
322
+ bytes [i] = 255 - bytes [i];
323
+ }
324
+
325
+ // Set Uint8Array.
326
+
327
+ dicom .components = components;
328
+ dicom .data = bytes;
329
+ },
330
+ getFrames: function (pixelElement)
331
+ {
332
+ var frames = [ ];
333
+
334
+ if (pixelElement .encapsulatedPixelData)
335
+ {
336
+ if (pixelElement .basicOffsetTable .length)
337
+ {
338
+ for (var i = 0, length = this .dicom .depth; i < length; ++ i)
339
+ frames .push (dicomParser .readEncapsulatedImageFrame (this .dataSet, pixelElement, i));
340
+ }
341
+ else if (this .dicom .depth !== pixelElement .fragments .length)
342
+ {
343
+ var basicOffsetTable = dicomParser .createJPEGBasicOffsetTable (this .dataSet, pixelElement);
344
+
345
+ for (var i = 0, length = this .dicom .depth; i < length; ++ i)
346
+ frames .push (dicomParser .readEncapsulatedImageFrame (this .dataSet, pixelElement, i, basicOffsetTable));
347
+ }
348
+ else
349
+ {
350
+ for (var i = 0, length = this .dicom .depth; i < length; ++ i)
351
+ frames .push (dicomParser .readEncapsulatedPixelDataFromFragments (this .dataSet, pixelElement, i));
352
+ }
353
+ }
354
+ else
355
+ {
356
+ var pixelsPerFrame = this .dicom .width * this .dicom .height * this .dicom .components;
357
+
358
+ switch (this .bitsAllocated)
359
+ {
360
+ case 1:
361
+ {
362
+ for (var i = 0, length = this .dicom .depth; i < length; ++ i)
363
+ {
364
+ var frameOffset = pixelElement .dataOffset + i * pixelsPerFrame / 8;
365
+
366
+ frames .push (this .unpackBinaryFrame (this .dataSet .byteArray, frameOffset, pixelsPerFrame));
367
+ }
368
+
369
+ this .bitsAllocated = 8;
370
+ break;
371
+ }
372
+ case 8:
373
+ case 16:
374
+ case 32:
375
+ {
376
+ var bytesAllocated = this .bitsAllocated / 8;
377
+
378
+ for (var i = 0, length = this .dicom .depth; i < length; ++ i)
379
+ {
380
+ var frameOffset = pixelElement .dataOffset + i * pixelsPerFrame * bytesAllocated;
381
+
382
+ frames .push (new Uint8Array (this .dataSet .byteArray .buffer, frameOffset, pixelsPerFrame * bytesAllocated));
383
+ }
384
+
385
+ break;
386
+ }
387
+ default:
388
+ throw new Error ("DICOM: unsupported pixel format.");
389
+ }
390
+ }
391
+
392
+ return frames;
393
+ },
394
+ getTypedArray: function (frame)
395
+ {
396
+ switch (this .bitsAllocated)
397
+ {
398
+ case 8:
399
+ return new (this .pixelRepresentation ? Int8Array : Uint8Array) (frame .buffer, frame .byteOffset, frame .length);
400
+ case 16:
401
+ return new (this .pixelRepresentation ? Int16Array : Uint16Array) (frame .buffer, frame .byteOffset, frame .length / 2);
402
+ case 32:
403
+ return new Float32Array (frame .buffer, frame .byteOffset, frame .length / 4);
404
+ default:
405
+ throw new Error ("DICOM: unsupported pixel format.");
406
+ }
407
+ },
408
+ flipImage: function (frame, components)
409
+ {
410
+ var
411
+ width = this .dicom .width,
412
+ height = this .dicom .height,
413
+ out = new (frame .constructor) (frame .length);
414
+
415
+ for (var y = 0; y < height; ++ y)
416
+ {
417
+ var
418
+ inputRow = components * width * (height - 1 - y),
419
+ outputRow = components * width * y;
420
+
421
+ for (var x = 0, w = components * width; x < w; ++ x)
422
+ {
423
+ out [outputRow + x] = frame [inputRow + x];
424
+ }
425
+ }
426
+
427
+ return out;
428
+ },
429
+ getNormalizeOffsetAndFactor: function (data)
430
+ {
431
+ var
432
+ min = Number .POSITIVE_INFINITY,
433
+ max = Number .NEGATIVE_INFINITY;
434
+
435
+ for (var i = 0, length = data .length; i < length; ++ i)
436
+ {
437
+ min = Math .min (min, data [i]);
438
+ max = Math .max (max, data [i]);
439
+ }
440
+
441
+ var diverence = max - min;
442
+
443
+ return { offset: min, factor: diverence ? 1 / diverence * 255 : 0 };
444
+ },
445
+ unpackBinaryFrame: function (byteArray, frameOffset, pixelsPerFrame)
446
+ {
447
+ function isBitSet (byte, bitPos)
448
+ {
449
+ return byte & (1 << bitPos);
450
+ }
451
+
452
+ // Create a new pixel array given the image size
453
+ var pixelData = new Uint8Array (pixelsPerFrame);
454
+
455
+ for (var i = 0; i < pixelsPerFrame; ++ i)
456
+ {
457
+ // Compute byte position
458
+ var bytePos = Math .floor (i / 8);
459
+
460
+ // Get the current byte
461
+ var byte = byteArray [bytePos + frameOffset];
462
+
463
+ // Bit position (0-7) within byte
464
+ var bitPos = (i % 8);
465
+
466
+ // Check whether bit at bitpos is set
467
+ pixelData [i] = isBitSet (byte, bitPos) ? 1 : 0;
468
+ }
469
+
470
+ return pixelData;
471
+ },
472
+ decodeLittleEndian: function (pixelData)
473
+ {
474
+ var
475
+ buffer = pixelData .buffer,
476
+ offset = pixelData .byteOffset,
477
+ length = pixelData .length;
478
+
479
+ if (this .bitsAllocated === 16)
480
+ {
481
+ // if pixel data is not aligned on even boundary, shift it so we can create the 16 bit array
482
+ // buffers on it
483
+
484
+ if (offset % 2)
485
+ {
486
+ buffer = buffer .slice (offset);
487
+ offset = 0;
488
+ }
489
+
490
+ return new Uint8Array (buffer, offset, length);
491
+
492
+ }
493
+ else if (this .bitsAllocated === 32)
494
+ {
495
+ // if pixel data is not aligned on even boundary, shift it
496
+ if (offset % 4)
497
+ {
498
+ buffer = buffer .slice (offset);
499
+ offset = 0;
500
+ }
501
+
502
+ return new Uint8Array (buffer, offset, length);
503
+ }
504
+
505
+ return pixelData;
506
+ },
507
+ decodeBigEndian: function (pixelData)
508
+ {
509
+ function swap16 (value)
510
+ {
511
+ return ((value & 0xFF) << 8) | ((value >> 8) & 0xFF);
512
+ }
513
+
514
+ if (this .bitsAllocated === 16)
515
+ {
516
+ var
517
+ buffer = pixelData .buffer,
518
+ offset = pixelData .byteOffset,
519
+ length = pixelData .length;
520
+
521
+ // if pixel data is not aligned on even boundary, shift it so we can create the 16 bit array
522
+ // buffers on it
523
+
524
+ if (offset % 2)
525
+ {
526
+ buffer = buffer .slice (offset);
527
+ offset = 0;
528
+ }
529
+
530
+ pixelData = new Uint16Array (buffer, offset, length / 2);
531
+
532
+ // Do the byte swap
533
+ for (var i = 0, l = pixelData .length; i < l; ++ i)
534
+ pixelData [i] = swap16 (pixelData [i]);
535
+
536
+ return new Uint8Array (buffer, offset, length);
537
+ }
538
+
539
+ return pixelData;
540
+ },
541
+ decodeRLE: function (pixelData)
542
+ {
543
+ if (this .bitsAllocated === 8)
544
+ {
545
+ if (this .planarConfiguration)
546
+ return this .decodeRLE8Planar (pixelData);
547
+
548
+ return this .decodeRLE8 (pixelData);
549
+ }
550
+
551
+ if (this .bitsAllocated === 16)
552
+ return this .decodeRLE16 (pixelData);
553
+
554
+ throw new Error ("DICOM: unsupported pixel format for RLE.");
555
+ },
556
+ decodeRLE8: function (pixelData)
557
+ {
558
+ const frameData = pixelData;
559
+ const frameSize = this .dicom .width * this .dicom .height;
560
+ const components = this .dicom .components;
561
+ const outFrame = new ArrayBuffer (frameSize * this .dicom .components);
562
+ const header = new DataView (frameData .buffer, frameData .byteOffset);
563
+ const data = new Int8Array(frameData .buffer, frameData .byteOffset);
564
+ const out = new Int8Array (outFrame);
565
+
566
+ let outIndex = 0;
567
+ const numSegments = header .getInt32 (0, true);
568
+
569
+ for (let s = 0; s < numSegments; ++ s)
570
+ {
571
+ outIndex = s;
572
+
573
+ let inIndex = header .getInt32 ((s + 1) * 4, true);
574
+ let maxIndex = header .getInt32 ((s + 2) * 4, true);
575
+
576
+ if (maxIndex === 0)
577
+ maxIndex = frameData.length;
578
+
579
+ const endOfSegment = frameSize * numSegments;
580
+
581
+ while (inIndex < maxIndex)
582
+ {
583
+ const n = data [inIndex ++];
584
+
585
+ if (n >= 0 && n <= 127)
586
+ {
587
+ // copy n bytes
588
+ for (let i = 0; i < n + 1 && outIndex < endOfSegment; ++ i)
589
+ {
590
+ out [outIndex] = data [inIndex ++];
591
+ outIndex += components;
592
+ }
593
+ }
594
+ else if (n <= -1 && n >= -127)
595
+ {
596
+ const value = data [inIndex ++];
597
+
598
+ // run of n bytes
599
+ for (let j = 0; j < -n + 1 && outIndex < endOfSegment; ++ j)
600
+ {
601
+ out [outIndex] = value;
602
+ outIndex += components;
603
+ }
604
+ }
605
+ }
606
+ }
607
+
608
+ return out;
609
+ },
610
+ decodeRLE8Planar: function (pixelData)
611
+ {
612
+ const frameData = pixelData;
613
+ const frameSize = this .dicom .width * this .dicom .height;
614
+ const outFrame = new ArrayBuffer (frameSize * this .dicom .components);
615
+ const header = new DataView (frameData .buffer, frameData .byteOffset);
616
+ const data = new Int8Array (frameData .buffer, frameData .byteOffset);
617
+ const out = new Int8Array (outFrame);
618
+
619
+ let outIndex = 0;
620
+ const numSegments = header .getInt32 (0, true);
621
+
622
+ for (let s = 0; s < numSegments; ++ s)
623
+ {
624
+ outIndex = s * frameSize;
625
+
626
+ let inIndex = header .getInt32 ((s + 1) * 4, true);
627
+ let maxIndex = header .getInt32 ((s + 2) * 4, true);
628
+
629
+ if (maxIndex === 0)
630
+ maxIndex = frameData .length;
631
+
632
+ const endOfSegment = frameSize * numSegments;
633
+
634
+ while (inIndex < maxIndex)
635
+ {
636
+ const n = data [inIndex ++];
637
+
638
+ if (n >= 0 && n <= 127)
639
+ {
640
+ // copy n bytes
641
+ for (let i = 0; i < n + 1 && outIndex < endOfSegment; ++ i)
642
+ {
643
+ out [outIndex] = data [inIndex ++];
644
+ ++ outIndex;
645
+ }
646
+ }
647
+ else if (n <= -1 && n >= -127)
648
+ {
649
+ const value = data[inIndex++];
650
+
651
+ // run of n bytes
652
+ for (let j = 0; j < -n + 1 && outIndex < endOfSegment; ++ j)
653
+ {
654
+ out [outIndex] = value;
655
+ ++ outIndex;
656
+ }
657
+ }
658
+ }
659
+ }
660
+
661
+ return out;
662
+ },
663
+ decodeRLE16: function (pixelData)
664
+ {
665
+ const frameData = pixelData;
666
+ const frameSize = this .dicom .width * this .dicom .height;
667
+ const outFrame = new ArrayBuffer (frameSize * this .dicom .components * 2);
668
+ const header = new DataView (frameData.buffer, frameData.byteOffset);
669
+ const data = new Int8Array (frameData.buffer, frameData.byteOffset);
670
+ const out = new Int8Array (outFrame);
671
+
672
+ const numSegments = header .getInt32 (0, true);
673
+
674
+ for (let s = 0; s < numSegments; ++ s)
675
+ {
676
+ let outIndex = 0;
677
+ const highByte = (s === 0 ? 1 : 0);
678
+
679
+ let inIndex = header .getInt32 ((s + 1) * 4, true);
680
+ let maxIndex = header .getInt32 ((s + 2) * 4, true);
681
+
682
+ if (maxIndex === 0)
683
+ maxIndex = frameData.length;
684
+
685
+ while (inIndex < maxIndex)
686
+ {
687
+ const n = data [inIndex ++];
688
+
689
+ if (n >= 0 && n <= 127)
690
+ {
691
+ for (let i = 0; i < n + 1 && outIndex < frameSize; ++ i)
692
+ {
693
+ out[(outIndex * 2) + highByte] = data[inIndex++];
694
+ ++ outIndex;
695
+ }
696
+ }
697
+ else if (n <= -1 && n >= -127)
698
+ {
699
+ const value = data [inIndex ++];
700
+
701
+ for (let j = 0; j < -n + 1 && outIndex < frameSize; ++ j)
702
+ {
703
+ out [(outIndex * 2) + highByte] = value;
704
+ ++ outIndex;
705
+ }
706
+ }
707
+ }
708
+ }
709
+
710
+ return out;
711
+ },
712
+ decodeJPEGBaseline: function (pixelData)
713
+ {
714
+ var jpeg = new JpegImage ();
715
+
716
+ jpeg .parse (pixelData);
717
+
718
+ jpeg .colorTransform = true; // default is true
719
+
720
+ var data = jpeg .getData (this .dicom .width, this .dicom .height);
721
+
722
+ this .bitsAllocated = 8;
723
+
724
+ return data;
725
+ },
726
+ decodeJPEGLossless: function (pixelData)
727
+ {
728
+ var
729
+ decoder = new jpegLossless .lossless .Decoder (),
730
+ buffer = decoder .decompress (pixelData);
731
+
732
+ return new Uint8Array (buffer);
733
+ },
734
+ decodeJPEGLS: function (pixelData)
735
+ {
736
+ var image = this .jpegLSDecode (pixelData, this .pixelRepresentation === 1);
737
+
738
+ // throw error if not success or too much data
739
+ if (image .result !== 0 && image .result !== 6)
740
+ throw new Error (`DICOM: JPEG-LS decoder failed to decode frame (error code ${image.result}).`);
741
+
742
+ return new Uint8Array (image .pixelData .buffer);
743
+ },
744
+ jpegLSDecode: function (data, isSigned)
745
+ {
746
+ // Init global instance.
747
+ charLS = charLS || CharLS ();
748
+
749
+ // prepare input parameters
750
+ const dataPtr = charLS._malloc(data.length);
751
+
752
+ charLS.writeArrayToMemory(data, dataPtr);
753
+
754
+ // prepare output parameters
755
+ const imagePtrPtr = charLS._malloc(4);
756
+ const imageSizePtr = charLS._malloc(4);
757
+ const widthPtr = charLS._malloc(4);
758
+ const heightPtr = charLS._malloc(4);
759
+ const bitsPerSamplePtr = charLS._malloc(4);
760
+ const stridePtr = charLS._malloc(4);
761
+ const allowedLossyErrorPtr = charLS._malloc(4);
762
+ const componentsPtr = charLS._malloc(4);
763
+ const interleaveModePtr = charLS._malloc(4);
764
+
765
+ // Decode the image
766
+ const result = charLS.ccall(
767
+ 'jpegls_decode',
768
+ 'number',
769
+ ['number', 'number', 'number', 'number', 'number', 'number', 'number', 'number', 'number', 'number', 'number'],
770
+ [dataPtr, data.length, imagePtrPtr, imageSizePtr, widthPtr, heightPtr, bitsPerSamplePtr, stridePtr, componentsPtr, allowedLossyErrorPtr, interleaveModePtr]
771
+ );
772
+
773
+ // Extract result values into object
774
+ const image = {
775
+ result,
776
+ width: charLS.getValue(widthPtr, 'i32'),
777
+ height: charLS.getValue(heightPtr, 'i32'),
778
+ bitsPerSample: charLS.getValue(bitsPerSamplePtr, 'i32'),
779
+ stride: charLS.getValue(stridePtr, 'i32'),
780
+ components: charLS.getValue(componentsPtr, 'i32'),
781
+ allowedLossyError: charLS.getValue(allowedLossyErrorPtr, 'i32'),
782
+ interleaveMode: charLS.getValue(interleaveModePtr, 'i32'),
783
+ pixelData: undefined
784
+ };
785
+
786
+ // Copy image from emscripten heap into appropriate array buffer type
787
+ const imagePtr = charLS.getValue(imagePtrPtr, '*');
788
+
789
+ if (image.bitsPerSample <= 8) {
790
+ image.pixelData = new Uint8Array(image.width * image.height * image.components);
791
+ image.pixelData.set(new Uint8Array(charLS.HEAP8.buffer, imagePtr, image.pixelData.length));
792
+ } else if (isSigned) {
793
+ image.pixelData = new Int16Array(image.width * image.height * image.components);
794
+ image.pixelData.set(new Int16Array(charLS.HEAP16.buffer, imagePtr, image.pixelData.length));
795
+ } else {
796
+ image.pixelData = new Uint16Array(image.width * image.height * image.components);
797
+ image.pixelData.set(new Uint16Array(charLS.HEAP16.buffer, imagePtr, image.pixelData.length));
798
+ }
799
+
800
+ // free memory and return image object
801
+ charLS._free(dataPtr);
802
+ charLS._free(imagePtr);
803
+ charLS._free(imagePtrPtr);
804
+ charLS._free(imageSizePtr);
805
+ charLS._free(widthPtr);
806
+ charLS._free(heightPtr);
807
+ charLS._free(bitsPerSamplePtr);
808
+ charLS._free(stridePtr);
809
+ charLS._free(componentsPtr);
810
+ charLS._free(interleaveModePtr);
811
+
812
+ return image;
813
+ },
814
+ decodeJPEG2000: function (pixelData)
815
+ {
816
+ var
817
+ bytesPerPixel = this .bitsAllocated <= 8 ? 1 : 2,
818
+ signed = this .pixelRepresentation === 1,
819
+ image = this .decodeOpenJPEG (pixelData, bytesPerPixel, signed);
820
+
821
+ if (image .nbChannels > 1)
822
+ this .photometricInterpretation = "RGB";
823
+
824
+ return new Uint8Array (image .pixelData .buffer);
825
+ },
826
+ decodeOpenJPEG: function (data, bytesPerPixel, signed)
827
+ {
828
+ // Init global instance.
829
+ openJPEG = openJPEG || OpenJPEG ();
830
+
831
+ const dataPtr = openJPEG._malloc(data.length);
832
+
833
+ openJPEG.writeArrayToMemory(data, dataPtr);
834
+
835
+ // create param outpout
836
+ const imagePtrPtr = openJPEG._malloc(4);
837
+ const imageSizePtr = openJPEG._malloc(4);
838
+ const imageSizeXPtr = openJPEG._malloc(4);
839
+ const imageSizeYPtr = openJPEG._malloc(4);
840
+ const imageSizeCompPtr = openJPEG._malloc(4);
841
+
842
+ const t0 = new Date().getTime();
843
+ const ret = openJPEG.ccall('jp2_decode', 'number', ['number', 'number', 'number', 'number', 'number', 'number', 'number'],
844
+ [dataPtr, data.length, imagePtrPtr, imageSizePtr, imageSizeXPtr, imageSizeYPtr, imageSizeCompPtr]);
845
+ // add num vomp..etc
846
+
847
+ if (ret !== 0) {
848
+ console.log('[opj_decode] decoding failed!');
849
+ openJPEG._free(dataPtr);
850
+ openJPEG._free(openJPEG.getValue(imagePtrPtr, '*'));
851
+ openJPEG._free(imageSizeXPtr);
852
+ openJPEG._free(imageSizeYPtr);
853
+ openJPEG._free(imageSizePtr);
854
+ openJPEG._free(imageSizeCompPtr);
855
+
856
+ return;
857
+ }
858
+
859
+ const imagePtr = openJPEG.getValue(imagePtrPtr, '*');
860
+
861
+ const image = {
862
+ length: openJPEG.getValue(imageSizePtr, 'i32'),
863
+ sx: openJPEG.getValue(imageSizeXPtr, 'i32'),
864
+ sy: openJPEG.getValue(imageSizeYPtr, 'i32'),
865
+ nbChannels: openJPEG.getValue(imageSizeCompPtr, 'i32'), // hard coded for now
866
+ perf_timetodecode: undefined,
867
+ pixelData: undefined
868
+ };
869
+
870
+ // Copy the data from the EMSCRIPTEN heap into the correct type array
871
+ const length = image.sx * image.sy * image.nbChannels;
872
+ const src32 = new Int32Array(openJPEG.HEAP32.buffer, imagePtr, length);
873
+
874
+ if (bytesPerPixel === 1) {
875
+ if (Uint8Array.from) {
876
+ image.pixelData = Uint8Array.from(src32);
877
+ } else {
878
+ image.pixelData = new Uint8Array(length);
879
+ for (let i = 0; i < length; i++) {
880
+ image.pixelData[i] = src32[i];
881
+ }
882
+ }
883
+ } else if (signed) {
884
+ if (Int16Array.from) {
885
+ image.pixelData = Int16Array.from(src32);
886
+ } else {
887
+ image.pixelData = new Int16Array(length);
888
+ for (let i = 0; i < length; i++) {
889
+ image.pixelData[i] = src32[i];
890
+ }
891
+ }
892
+ } else if (Uint16Array.from) {
893
+ image.pixelData = Uint16Array.from(src32);
894
+ } else {
895
+ image.pixelData = new Uint16Array(length);
896
+ for (let i = 0; i < length; i++) {
897
+ image.pixelData[i] = src32[i];
898
+ }
899
+ }
900
+
901
+ const t1 = new Date().getTime();
902
+
903
+ image.perf_timetodecode = t1 - t0;
904
+
905
+ // free
906
+ openJPEG._free(dataPtr);
907
+ openJPEG._free(imagePtrPtr);
908
+ openJPEG._free(imagePtr);
909
+ openJPEG._free(imageSizePtr);
910
+ openJPEG._free(imageSizeXPtr);
911
+ openJPEG._free(imageSizeYPtr);
912
+ openJPEG._free(imageSizeCompPtr);
913
+
914
+ return image;
915
+ },
916
+ convertRGBColorByPlane: function (pixelData)
917
+ {
918
+ if (pixelData .length % 3 !== 0)
919
+ throw new Error ("DICOM: convertRGBColorByPlane: RGB buffer length must be divisble by 3.");
920
+
921
+ var
922
+ numPixels = pixelData .length / 3,
923
+ rgbIndex = 0,
924
+ rIndex = 0,
925
+ gIndex = numPixels,
926
+ bIndex = numPixels * 2,
927
+ out = new (pixelData .constructor) (pixelData .length);
928
+
929
+ for (var i = 0; i < numPixels; ++ i)
930
+ {
931
+ out [rgbIndex ++] = pixelData [rIndex ++]; // red
932
+ out [rgbIndex ++] = pixelData [gIndex ++]; // green
933
+ out [rgbIndex ++] = pixelData [bIndex ++]; // blue
934
+ }
935
+
936
+ return out;
937
+ },
938
+ convertYBRFullByPixel: function (pixelData)
939
+ {
940
+ if (pixelData .length % 3 !== 0)
941
+ throw new Error ("DICOM: convertYBRFullByPixel: YBR buffer length must be divisble by 3.");
942
+
943
+ console .log (pixelData);
944
+
945
+ var
946
+ numPixels = pixelData .length / 3,
947
+ ybrIndex = 0,
948
+ rgbIndex = 0,
949
+ out = new (pixelData .constructor) (pixelData .length);
950
+
951
+ for (var i = 0; i < numPixels; ++ i)
952
+ {
953
+ var
954
+ y = pixelData [ybrIndex ++],
955
+ cb = pixelData [ybrIndex ++],
956
+ cr = pixelData [ybrIndex ++];
957
+
958
+ out [rgbIndex ++] = y + 1.40200 * (cr - 128); // red
959
+ out [rgbIndex ++] = y - 0.34414 * (cb - 128) - 0.71414 * (cr - 128); // green
960
+ out [rgbIndex ++] = y + 1.77200 * (cb - 128); // blue
961
+ }
962
+
963
+ return out;
964
+ },
965
+ convertYBRFullByPlane: function (pixelData)
966
+ {
967
+ if (pixelData .length % 3 !== 0)
968
+ throw new Error ("DICOM: convertYBRFullByPlane: YBR buffer length must be divisble by 3.");
969
+
970
+ var
971
+ numPixels = pixelData .length / 3,
972
+ rgbIndex = 0,
973
+ yIndex = 0,
974
+ cbIndex = numPixels,
975
+ crIndex = numPixels * 2,
976
+ out = new (pixelData .constructor) (pixelData .length);
977
+
978
+ for (var i = 0; i < numPixels; ++ i)
979
+ {
980
+ var
981
+ y = pixelData [yIndex ++],
982
+ cb = pixelData [cbIndex ++],
983
+ cr = pixelData [crIndex ++];
984
+
985
+ out [rgbIndex++] = y + 1.40200 * (cr - 128); // red
986
+ out [rgbIndex++] = y - 0.34414 * (cb - 128) - 0.71414 * (cr - 128); // green
987
+ out [rgbIndex++] = y + 1.77200 * (cb - 128); // blue
988
+ }
989
+
990
+ return out;
991
+ },
992
+ convertPaletteColor: function (pixelData)
993
+ {
994
+ function convertLUTto8Bit (lut, shift)
995
+ {
996
+ if (lut .cleaned)
997
+ return lut .cleaned;
998
+
999
+ const numEntries = lut .length;
1000
+ const cleanedLUT = new Uint8ClampedArray (numEntries);
1001
+
1002
+ for (let i = 0; i < numEntries; ++i)
1003
+ cleanedLUT [i] = lut [i] >> shift;
1004
+
1005
+ lut .cleaned = cleanedLUT;
1006
+
1007
+ return cleanedLUT;
1008
+ }
1009
+
1010
+ const LUT = this .getLUT ();
1011
+ const numPixels = this .dicom .width * this .dicom .height;
1012
+ const rData = LUT .redPaletteColorLookupTableData;
1013
+ const gData = LUT .greenPaletteColorLookupTableData;
1014
+ const bData = LUT .bluePaletteColorLookupTableData;
1015
+ const len = LUT .redPaletteColorLookupTableData .length;
1016
+
1017
+ let palIndex = 0;
1018
+ let rgbIndex = 0;
1019
+
1020
+ const start = LUT .redPaletteColorLookupTableDescriptor [1];
1021
+ const shift = LUT .redPaletteColorLookupTableDescriptor [2] === 8 ? 0 : 8;
1022
+
1023
+ const rDataCleaned = convertLUTto8Bit (rData, shift);
1024
+ const gDataCleaned = convertLUTto8Bit (gData, shift);
1025
+ const bDataCleaned = convertLUTto8Bit (bData, shift);
1026
+
1027
+ let out = new Uint8Array (pixelData .length * 3);
1028
+
1029
+ for (let i = 0; i < numPixels; ++ i)
1030
+ {
1031
+ let value = pixelData [palIndex++];
1032
+
1033
+ if (value < start)
1034
+ value = 0;
1035
+ else if (value > start + len - 1)
1036
+ value = len - 1;
1037
+ else
1038
+ value -= start;
1039
+
1040
+ out [rgbIndex++] = rDataCleaned [value];
1041
+ out [rgbIndex++] = gDataCleaned [value];
1042
+ out [rgbIndex++] = bDataCleaned [value];
1043
+ }
1044
+
1045
+ return out;
1046
+ },
1047
+ getLUT: function ()
1048
+ {
1049
+ if (this .LUT)
1050
+ return this .LUT;
1051
+
1052
+ this .LUT = { };
1053
+
1054
+ this .populatePaletteColorLut (this .dataSet, this .LUT);
1055
+
1056
+ return this .LUT;
1057
+ },
1058
+ populatePaletteColorLut: function (dataSet, imagePixelModule)
1059
+ {
1060
+ imagePixelModule .redPaletteColorLookupTableDescriptor = this .getLutDescriptor (dataSet, 'x00281101');
1061
+ imagePixelModule .greenPaletteColorLookupTableDescriptor = this .getLutDescriptor (dataSet, 'x00281102');
1062
+ imagePixelModule .bluePaletteColorLookupTableDescriptor = this .getLutDescriptor (dataSet, 'x00281103');
1063
+
1064
+ // The first Palette Color Lookup Table Descriptor value is the number of entries in the lookup table.
1065
+ // When the number of table entries is equal to 2ˆ16 then this value shall be 0.
1066
+ // See http://dicom.nema.org/MEDICAL/DICOM/current/output/chtml/part03/sect_C.7.6.3.html#sect_C.7.6.3.1.5
1067
+ if (imagePixelModule .redPaletteColorLookupTableDescriptor [0] === 0)
1068
+ {
1069
+ imagePixelModule .redPaletteColorLookupTableDescriptor [0] = 65536;
1070
+ imagePixelModule .greenPaletteColorLookupTableDescriptor [0] = 65536;
1071
+ imagePixelModule .bluePaletteColorLookupTableDescriptor [0] = 65536;
1072
+ }
1073
+
1074
+ // The third Palette Color Lookup Table Descriptor value specifies the number of bits for each entry in the Lookup Table Data.
1075
+ // It shall take the value of 8 or 16.
1076
+ // The LUT Data shall be stored in a format equivalent to 8 bits allocated when the number of bits for each entry is 8, and 16 bits allocated when the number of bits for each entry is 16, where in both cases the high bit is equal to bits allocated-1.
1077
+ // The third value shall be identical for each of the Red, Green and Blue Palette Color Lookup Table Descriptors.
1078
+ //
1079
+ // Note: Some implementations have encoded 8 bit entries with 16 bits allocated, padding the high bits;
1080
+ // this can be detected by comparing the number of entries specified in the LUT Descriptor with the actual value length of the LUT Data entry.
1081
+ // The value length in bytes should equal the number of entries if bits allocated is 8, and be twice as long if bits allocated is 16.
1082
+ const numLutEntries = imagePixelModule .redPaletteColorLookupTableDescriptor [0];
1083
+ const lutData = dataSet .elements .x00281201;
1084
+ const lutBitsAllocated = lutData .length === numLutEntries ? 8 : 16;
1085
+
1086
+ // If the descriptors do not appear to have the correct values, correct them
1087
+ if (imagePixelModule.redPaletteColorLookupTableDescriptor [2] !== lutBitsAllocated)
1088
+ {
1089
+ imagePixelModule .redPaletteColorLookupTableDescriptor [2] = lutBitsAllocated;
1090
+ imagePixelModule .greenPaletteColorLookupTableDescriptor [2] = lutBitsAllocated;
1091
+ imagePixelModule .bluePaletteColorLookupTableDescriptor [2] = lutBitsAllocated;
1092
+ }
1093
+
1094
+ imagePixelModule .redPaletteColorLookupTableData = this .getLutData (dataSet, 'x00281201', imagePixelModule .redPaletteColorLookupTableDescriptor);
1095
+ imagePixelModule .greenPaletteColorLookupTableData = this .getLutData (dataSet, 'x00281202', imagePixelModule .greenPaletteColorLookupTableDescriptor);
1096
+ imagePixelModule .bluePaletteColorLookupTableData = this .getLutData (dataSet, 'x00281203', imagePixelModule .bluePaletteColorLookupTableDescriptor);
1097
+ },
1098
+ getLutDescriptor: function (dataSet, tag)
1099
+ {
1100
+ if (! dataSet .elements [tag] || dataSet .elements [tag] .length !== 6)
1101
+ return;
1102
+
1103
+ return [dataSet .uint16 (tag, 0), dataSet .uint16 (tag, 1), dataSet .uint16 (tag, 2)];
1104
+ },
1105
+ getLutData: function (lutDataSet, tag, lutDescriptor)
1106
+ {
1107
+ const lut = [];
1108
+ const lutData = lutDataSet .elements [tag];
1109
+
1110
+ for (let i = 0; i < lutDescriptor [0]; ++ i)
1111
+ {
1112
+ // Output range is always unsigned
1113
+ if (lutDescriptor [2] === 16)
1114
+ lut [i] = lutDataSet .uint16 (tag, i);
1115
+ else
1116
+ lut [i] = lutDataSet .byteArray [i + lutData .dataOffset];
1117
+ }
1118
+
1119
+ return lut;
1120
+ },
1121
+ };
1122
+
1123
+ // ftp://medical.nema.org/medical/dicom/DataSets/WG04/
1124
+
1125
+ return DicomParser;
1126
+ });