x_ite 4.2.17 → 4.7.7

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 (903) hide show
  1. package/.github/ISSUE_TEMPLATE/bug_report.md +38 -0
  2. package/.vscode/launch.json +15 -0
  3. package/.vscode/settings.json +12 -0
  4. package/.vscode/tasks.json +25 -0
  5. package/Makefile +27 -10
  6. package/README.md +13 -145
  7. package/build/bin/dist.pl +65 -8
  8. package/build/bin/version-number.pl +25 -0
  9. package/build/bin/version.pl +54 -14
  10. package/build/components/annotation.build.js +15 -0
  11. package/build/components/cad-geometry.build.js +15 -0
  12. package/build/components/cube-map-texturing.build.js +15 -0
  13. package/build/components/dis.build.js +15 -0
  14. package/build/components/event-utilities.build.js +15 -0
  15. package/build/components/geometry2d.build.js +15 -0
  16. package/build/components/geospatial.build.js +15 -0
  17. package/build/components/h-anim.build.js +15 -0
  18. package/build/components/key-device-sensor.build.js +15 -0
  19. package/build/components/layout.build.js +15 -0
  20. package/build/components/nurbs.build.js +15 -0
  21. package/build/components/particle-systems.build.js +15 -0
  22. package/build/components/picking.build.js +15 -0
  23. package/build/components/projective-texture-mapping.build.js +15 -0
  24. package/build/components/rigid-body-physics.build.js +15 -0
  25. package/build/components/scripting.build.js +15 -0
  26. package/build/components/texturing-3d.build.js +15 -0
  27. package/build/components/volume-rendering.build.js +15 -0
  28. package/build/components/x_ite.build.js +15 -0
  29. package/build/parts/default.end.frag.js +3 -0
  30. package/build/parts/default.start.frag.js +15 -0
  31. package/build/parts/x_ite.end.frag.js +25 -0
  32. package/build/parts/x_ite.start.frag.js +16 -0
  33. package/build/x_ite.build.js +5 -2
  34. package/dist/{components/texturing-3d.js → assets/components/annotation.js} +341 -263
  35. package/dist/assets/components/annotation.min.js +1 -0
  36. package/dist/{components → assets/components}/cad-geometry.js +180 -76
  37. package/dist/assets/components/cad-geometry.min.js +1 -0
  38. package/dist/assets/components/cube-map-texturing.js +1222 -0
  39. package/dist/assets/components/cube-map-texturing.min.js +1 -0
  40. package/dist/assets/components/dis.js +918 -0
  41. package/dist/assets/components/dis.min.js +1 -0
  42. package/dist/assets/components/event-utilities.js +1124 -0
  43. package/dist/assets/components/event-utilities.min.js +1 -0
  44. package/dist/assets/components/geometry2d.js +2200 -0
  45. package/dist/assets/components/geometry2d.min.js +1 -0
  46. package/dist/{components → assets/components}/geospatial.js +364 -269
  47. package/dist/assets/components/geospatial.min.js +2 -0
  48. package/dist/{components → assets/components}/h-anim.js +224 -62
  49. package/dist/assets/components/h-anim.min.js +1 -0
  50. package/dist/assets/components/key-device-sensor.js +860 -0
  51. package/dist/assets/components/key-device-sensor.min.js +1 -0
  52. package/dist/assets/components/layout.js +2018 -0
  53. package/dist/assets/components/layout.min.js +1 -0
  54. package/dist/{components → assets/components}/nurbs.js +632 -348
  55. package/dist/assets/components/nurbs.min.js +2 -0
  56. package/dist/{components → assets/components}/particle-systems.js +514 -476
  57. package/dist/assets/components/particle-systems.min.js +2 -0
  58. package/dist/assets/components/picking.js +2491 -0
  59. package/dist/assets/components/picking.min.js +1 -0
  60. package/dist/assets/components/projective-texture-mapping.js +823 -0
  61. package/dist/assets/components/projective-texture-mapping.min.js +1 -0
  62. package/dist/assets/components/rigid-body-physics.js +4579 -0
  63. package/dist/assets/components/rigid-body-physics.min.js +59 -0
  64. package/dist/assets/components/scripting.js +816 -0
  65. package/dist/assets/components/scripting.min.js +1 -0
  66. package/dist/assets/components/texturing-3d.js +10064 -0
  67. package/dist/assets/components/texturing-3d.min.js +48 -0
  68. package/dist/assets/components/volume-rendering.js +3976 -0
  69. package/dist/assets/components/volume-rendering.min.js +3 -0
  70. package/dist/assets/components/x_ite.js +295 -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 +15 -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 +107 -0
  151. package/dist/assets/shaders/webgl1/Phong.fs +837 -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 +538 -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 +108 -0
  165. package/dist/assets/shaders/webgl2/Phong.fs +1013 -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 +693 -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 +167 -49
  175. package/dist/x_ite.js +66263 -60020
  176. package/dist/x_ite.min.js +41 -41
  177. package/dist/x_ite.zip +0 -0
  178. package/docs/404.md +5 -0
  179. package/docs/Accessing-the-External-Browser.md +319 -0
  180. package/docs/Browser-Support.md +47 -0
  181. package/docs/Custom-Shaders.md +896 -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 +1295 -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 +1033 -0
  194. package/docs/reference/Browser-Services.md +361 -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 +342 -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 +3 -3
  239. package/package.json +43 -28
  240. package/src/assets/components/annotation.js +87 -0
  241. package/src/{components → assets/components}/cad-geometry.js +0 -0
  242. package/src/{x_ite/Components/CubeMapTexturing.js → assets/components/cube-map-texturing.js} +15 -21
  243. package/src/assets/components/dis.js +84 -0
  244. package/src/{x_ite/Components/EventUtilities.js → assets/components/event-utilities.js} +20 -26
  245. package/src/{x_ite/Components/Geometry2D.js → assets/components/geometry2d.js} +22 -25
  246. package/src/{components → assets/components}/geospatial.js +0 -0
  247. package/src/{components → assets/components}/h-anim.js +9 -7
  248. package/src/{x_ite/Components/KeyDeviceSensor.js → assets/components/key-device-sensor.js} +17 -20
  249. package/src/{x_ite/Components/Layout.js → assets/components/layout.js} +20 -23
  250. package/src/{components → assets/components}/nurbs.js +0 -0
  251. package/src/{components → assets/components}/particle-systems.js +1 -1
  252. package/src/assets/components/picking.js +87 -0
  253. package/src/assets/components/projective-texture-mapping.js +75 -0
  254. package/src/{components → assets/components}/rigid-body-physics.js +7 -2
  255. package/src/{x_ite/Components/Scripting.js → assets/components/scripting.js} +13 -19
  256. package/src/{components → assets/components}/texturing-3d.js +12 -13
  257. package/src/assets/components/volume-rendering.js +118 -0
  258. package/src/{x_ite/Components/X_ITE.js → assets/components/x_ite.js} +12 -30
  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 +21 -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 +147 -0
  339. package/src/assets/shaders/webgl1/Phong.fs +172 -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 +86 -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/{x_ite/Browser/Shaders/Include/Pack.h → assets/shaders/webgl1/include/Pack.glsl} +0 -1
  351. package/src/assets/shaders/webgl1/include/Perlin.glsl +40 -0
  352. package/src/{x_ite/Browser/Shaders/Include/Shadow.h → assets/shaders/webgl1/include/Shadow.glsl} +33 -33
  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 +148 -0
  360. package/src/assets/shaders/webgl2/Phong.fs +170 -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 +85 -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 +33 -12
  376. package/src/dummy.js +1 -0
  377. package/src/example.html +8 -7
  378. package/src/examples.js +21 -3
  379. package/src/lib/ammojs/AmmoJS.js +58 -0
  380. package/src/lib/ammojs/Makefile +4 -0
  381. package/src/lib/ammojs/ammo.idl +72 -1
  382. package/src/lib/ammojs/ammo.js +25 -21
  383. package/src/lib/jpeg/jpeg.js +1019 -0
  384. package/src/lib/nurbs/extras/sample.js +137 -80
  385. package/src/locale/de.po +18 -73
  386. package/src/locale/fr.po +18 -74
  387. package/src/spinner.css +18 -6
  388. package/src/standard/Geospatial/Geodetic.js +43 -43
  389. package/src/standard/Geospatial/ReferenceEllipsoids.js +1 -1
  390. package/src/standard/Geospatial/UniversalTransverseMercator.js +42 -42
  391. package/src/standard/Math/Algorithm.js +22 -39
  392. package/src/standard/Math/Algorithms/Bezier.js +147 -0
  393. package/src/standard/Math/Algorithms/MergeSort.js +2 -2
  394. package/src/standard/Math/Algorithms/PartialSort.js +6 -6
  395. package/src/standard/Math/Algorithms/QuickSort.js +8 -6
  396. package/src/standard/Math/Algorithms/SAT.js +4 -8
  397. package/src/standard/Math/Algorithms/eigendecomposition.js +37 -33
  398. package/src/standard/Math/Geometry/Box2.js +84 -56
  399. package/src/standard/Math/Geometry/Box3.js +400 -358
  400. package/src/standard/Math/Geometry/Camera.js +19 -16
  401. package/src/standard/Math/Geometry/Cylinder3.js +13 -13
  402. package/src/standard/Math/Geometry/Line3.js +34 -34
  403. package/src/standard/Math/Geometry/Plane3.js +15 -15
  404. package/src/standard/Math/Geometry/Sphere3.js +122 -105
  405. package/src/standard/Math/Geometry/Spheroid3.js +1 -1
  406. package/src/standard/Math/Geometry/Triangle2.js +5 -5
  407. package/src/standard/Math/Geometry/Triangle3.js +12 -14
  408. package/src/standard/Math/Geometry/ViewVolume.js +303 -106
  409. package/src/standard/Math/Numbers/Color3.js +26 -23
  410. package/src/standard/Math/Numbers/Color4.js +9 -9
  411. package/src/standard/Math/Numbers/Complex.js +13 -17
  412. package/src/standard/Math/Numbers/Matrix2.js +20 -13
  413. package/src/standard/Math/Numbers/Matrix3.js +129 -205
  414. package/src/standard/Math/Numbers/Matrix4.js +136 -257
  415. package/src/standard/Math/Numbers/Quaternion.js +49 -138
  416. package/src/standard/Math/Numbers/Rotation4.js +42 -55
  417. package/src/standard/Math/Numbers/Vector2.js +32 -115
  418. package/src/standard/Math/Numbers/Vector3.js +46 -151
  419. package/src/standard/Math/Numbers/Vector4.js +44 -163
  420. package/src/standard/Math/Utility/BVH.js +21 -20
  421. package/src/standard/Math/Utility/MatrixStack.js +4 -4
  422. package/src/standard/Networking/BinaryTransport.js +8 -8
  423. package/src/standard/Time/MicroTime.js +81 -0
  424. package/src/standard/Utility/DataStorage.js +11 -14
  425. package/src/standard/Utility/MapUtilities.js +69 -0
  426. package/src/standard/Utility/ObjectCache.js +2 -3
  427. package/src/standard/Utility/Shuffle.js +5 -6
  428. package/src/tests.js +84 -5
  429. package/src/x_ite/Base/Events.js +9 -10
  430. package/src/x_ite/Base/X3DChildObject.js +20 -16
  431. package/src/x_ite/Base/X3DEventObject.js +3 -7
  432. package/src/x_ite/Base/X3DObject.js +44 -27
  433. package/src/x_ite/Basic/FieldDefinitionArray.js +11 -4
  434. package/src/x_ite/Basic/X3DBaseNode.js +427 -246
  435. package/src/x_ite/Basic/X3DField.js +48 -69
  436. package/src/x_ite/Basic/X3DFieldDefinition.js +0 -4
  437. package/src/x_ite/Basic/X3DObjectArrayField.js +102 -108
  438. package/src/x_ite/Basic/X3DTypedArrayField.js +194 -163
  439. package/src/x_ite/Bits/TraverseType.js +2 -5
  440. package/src/x_ite/Bits/X3DConstants.js +11 -2
  441. package/src/x_ite/Browser/Core/BrowserOptions.js +89 -68
  442. package/src/x_ite/Browser/Core/BrowserTimings.js +21 -29
  443. package/src/x_ite/Browser/Core/ContextMenu.js +139 -60
  444. package/src/x_ite/Browser/Core/Notification.js +3 -3
  445. package/src/x_ite/Browser/Core/PrimitiveQuality.js +3 -7
  446. package/src/x_ite/Browser/Core/Shading.js +3 -7
  447. package/src/x_ite/Browser/Core/TextureQuality.js +3 -7
  448. package/src/x_ite/Browser/Core/X3DCoreContext.js +398 -58
  449. package/src/x_ite/Browser/Core/X3DCoreContext.js.~1~ +714 -0
  450. package/src/x_ite/Browser/EnvironmentalEffects/X3DEnvironmentalEffectsContext.js +17 -28
  451. package/src/x_ite/Browser/Followers/X3DArrayChaserTemplate.js +5 -14
  452. package/src/x_ite/Browser/Followers/X3DArrayFollowerTemplate.js +81 -28
  453. package/src/x_ite/Browser/Geometry2D/Disk2DOptions.js +53 -44
  454. package/src/x_ite/Browser/Geometry2D/X3DGeometry2DContext.js +51 -12
  455. package/src/x_ite/Browser/Geometry3D/X3DGeometry3DContext.js +8 -9
  456. package/src/x_ite/Browser/Grouping/X3DGroupingContext.js +98 -0
  457. package/src/x_ite/Browser/KeyDeviceSensor/X3DKeyDeviceSensorContext.js +14 -206
  458. package/src/x_ite/Browser/Layout/ScreenText.js +226 -254
  459. package/src/x_ite/Browser/Layout/X3DLayoutContext.js +13 -11
  460. package/src/x_ite/Browser/Lighting/X3DLightingContext.js +15 -9
  461. package/src/x_ite/Browser/NURBS/NURBS.js +84 -72
  462. package/src/x_ite/Browser/Navigation/ExamineViewer.js +125 -83
  463. package/src/x_ite/Browser/Navigation/FlyViewer.js +14 -9
  464. package/src/x_ite/Browser/Navigation/LookAtViewer.js +60 -40
  465. package/src/x_ite/Browser/Navigation/NoneViewer.js +12 -1
  466. package/src/x_ite/Browser/Navigation/PlaneViewer.js +39 -20
  467. package/src/x_ite/Browser/Navigation/WalkViewer.js +21 -6
  468. package/src/x_ite/Browser/Navigation/X3DFlyViewer.js +110 -85
  469. package/src/x_ite/Browser/Navigation/X3DNavigationContext.js +11 -6
  470. package/src/x_ite/Browser/Navigation/X3DViewer.js +73 -48
  471. package/src/x_ite/Browser/Networking/X3DNetworkingContext.js +18 -24
  472. package/src/x_ite/Browser/Networking/urls.js +31 -16
  473. package/src/x_ite/Browser/ParticleSystems/X3DParticleSystemsContext.js +5 -6
  474. package/src/x_ite/Browser/Picking/IntersectionType.js +63 -0
  475. package/src/x_ite/Browser/Picking/MatchCriterion.js +64 -0
  476. package/src/x_ite/Browser/Picking/SortOrder.js +65 -0
  477. package/src/x_ite/Browser/Picking/VolumePicker.js +197 -0
  478. package/src/x_ite/Browser/Picking/X3DPickingContext.js +130 -0
  479. package/src/x_ite/Browser/PointingDeviceSensor/PointingDevice.js +26 -20
  480. package/src/x_ite/Browser/PointingDeviceSensor/X3DPointingDeviceSensorContext.js +17 -10
  481. package/src/x_ite/Browser/Rendering/X3DRenderingContext.js +38 -27
  482. package/src/x_ite/Browser/RigidBodyPhysics/AppliedParametersType.js +70 -0
  483. package/src/x_ite/Browser/Shaders/Shader.js +112 -92
  484. package/src/x_ite/Browser/Shaders/ShaderSource.js +140 -0
  485. package/src/x_ite/Browser/Shaders/ShaderTest.js +92 -77
  486. package/src/x_ite/Browser/Shaders/X3DShadersContext.js +134 -74
  487. package/src/x_ite/Browser/Shape/AlphaMode.js +65 -0
  488. package/src/x_ite/Browser/Shape/LineStipples.xcf +0 -0
  489. package/src/x_ite/Browser/Shape/X3DShapeContext.js +108 -4
  490. package/src/x_ite/Browser/Text/PolygonText.js +153 -170
  491. package/src/x_ite/Browser/Text/TextAlignment.js +3 -7
  492. package/src/x_ite/Browser/Text/X3DTextContext.js +38 -30
  493. package/src/x_ite/Browser/Text/X3DTextGeometry.js +49 -74
  494. package/src/x_ite/Browser/Texturing/MultiTextureFunctionType.js +64 -0
  495. package/src/x_ite/Browser/Texturing/MultiTextureModeType.js +81 -0
  496. package/src/x_ite/Browser/Texturing/MultiTextureSourceType.js +65 -0
  497. package/src/x_ite/Browser/Texturing/TextureCoordinateGeneratorModeType.js +73 -0
  498. package/src/x_ite/Browser/Texturing/X3DTexturingContext.js +147 -45
  499. package/src/x_ite/Browser/Texturing3D/DICOMParser.js +1126 -0
  500. package/src/x_ite/Browser/Texturing3D/NRRDParser.js +686 -0
  501. package/src/x_ite/Browser/Time/X3DTimeContext.js +20 -17
  502. package/src/x_ite/Browser/VERSION.js +1 -1
  503. package/src/x_ite/Browser/VolumeRendering/VolumeStyle.fs +120 -0
  504. package/src/x_ite/Browser/VolumeRendering/VolumeStyle.vs +28 -0
  505. package/src/x_ite/Browser/VolumeRendering/X3DVolumeRenderingContext.js +114 -0
  506. package/src/x_ite/Browser/X3DBrowser.js +282 -224
  507. package/src/x_ite/Browser/X3DBrowserContext.js +60 -27
  508. package/src/x_ite/Components/Annotation/AnnotationLayer.js +108 -0
  509. package/src/x_ite/Components/Annotation/AnnotationTarget.js +101 -0
  510. package/src/x_ite/Components/Annotation/GroupAnnotation.js +112 -0
  511. package/src/x_ite/Components/Annotation/IconAnnotation.js +110 -0
  512. package/src/x_ite/Components/Annotation/TextAnnotation.js +102 -0
  513. package/src/x_ite/Components/Annotation/URLAnnotation.js +101 -0
  514. package/src/x_ite/Components/Annotation/X3DAnnotationNode.js +76 -0
  515. package/src/x_ite/Components/CADGeometry/CADAssembly.js +4 -4
  516. package/src/x_ite/Components/CADGeometry/CADFace.js +135 -30
  517. package/src/x_ite/Components/CADGeometry/CADLayer.js +3 -18
  518. package/src/x_ite/Components/CADGeometry/CADPart.js +4 -8
  519. package/src/x_ite/Components/CADGeometry/IndexedQuadSet.js +18 -10
  520. package/src/x_ite/Components/Core/WorldInfo.js +16 -6
  521. package/src/x_ite/Components/Core/X3DBindableNode.js +4 -33
  522. package/src/x_ite/Components/Core/X3DChildNode.js +14 -1
  523. package/src/x_ite/Components/Core/X3DNode.js +0 -63
  524. package/src/x_ite/Components/Core/X3DPrototypeInstance.js +128 -168
  525. package/src/x_ite/Components/Core.js +6 -9
  526. package/src/x_ite/Components/CubeMapTexturing/ComposedCubeMapTexture.js +38 -46
  527. package/src/x_ite/Components/CubeMapTexturing/GeneratedCubeMapTexture.js +31 -30
  528. package/src/x_ite/Components/CubeMapTexturing/ImageCubeMapTexture.js +42 -57
  529. package/src/x_ite/Components/CubeMapTexturing/X3DEnvironmentTextureNode.js +36 -48
  530. package/src/x_ite/Components/DIS/EspduTransform.js +12 -6
  531. package/src/x_ite/Components/DIS/ReceiverPdu.js +12 -6
  532. package/src/x_ite/Components/DIS/SignalPdu.js +12 -6
  533. package/src/x_ite/Components/DIS/TransmitterPdu.js +12 -6
  534. package/src/x_ite/Components/EnvironmentalEffects/Fog.js +5 -16
  535. package/src/x_ite/Components/EnvironmentalEffects/FogCoordinate.js +55 -3
  536. package/src/x_ite/Components/EnvironmentalEffects/LocalFog.js +3 -5
  537. package/src/x_ite/Components/EnvironmentalEffects/X3DBackgroundNode.js +116 -116
  538. package/src/x_ite/Components/EnvironmentalEffects/X3DFogObject.js +5 -6
  539. package/src/x_ite/Components/EnvironmentalEffects.js +6 -9
  540. package/src/x_ite/Components/EnvironmentalSensor/ProximitySensor.js +116 -117
  541. package/src/x_ite/Components/EnvironmentalSensor/TransformSensor.js +169 -49
  542. package/src/x_ite/Components/EnvironmentalSensor/VisibilitySensor.js +31 -27
  543. package/src/x_ite/Components/EnvironmentalSensor/X3DEnvironmentalSensorNode.js +12 -5
  544. package/src/x_ite/Components/EnvironmentalSensor.js +6 -9
  545. package/src/x_ite/Components/Followers/ColorChaser.js +1 -3
  546. package/src/x_ite/Components/Followers/ColorDamper.js +1 -3
  547. package/src/x_ite/Components/Followers/CoordinateChaser.js +1 -7
  548. package/src/x_ite/Components/Followers/CoordinateDamper.js +0 -6
  549. package/src/x_ite/Components/Followers/OrientationChaser.js +7 -3
  550. package/src/x_ite/Components/Followers/OrientationDamper.js +7 -3
  551. package/src/x_ite/Components/Followers/PositionChaser.js +1 -3
  552. package/src/x_ite/Components/Followers/PositionChaser2D.js +1 -3
  553. package/src/x_ite/Components/Followers/PositionDamper.js +1 -3
  554. package/src/x_ite/Components/Followers/PositionDamper2D.js +1 -3
  555. package/src/x_ite/Components/Followers/ScalarChaser.js +1 -3
  556. package/src/x_ite/Components/Followers/ScalarDamper.js +1 -3
  557. package/src/x_ite/Components/Followers/TexCoordChaser2D.js +1 -7
  558. package/src/x_ite/Components/Followers/TexCoordDamper2D.js +1 -7
  559. package/src/x_ite/Components/Followers/X3DChaserNode.js +20 -18
  560. package/src/x_ite/Components/Followers/X3DDamperNode.js +5 -7
  561. package/src/x_ite/Components/Followers/X3DFollowerNode.js +5 -7
  562. package/src/x_ite/Components/Followers.js +6 -9
  563. package/src/x_ite/Components/Geometry2D/Arc2D.js +10 -14
  564. package/src/x_ite/Components/Geometry2D/ArcClose2D.js +87 -86
  565. package/src/x_ite/Components/Geometry2D/Circle2D.js +1 -3
  566. package/src/x_ite/Components/Geometry2D/Disk2D.js +43 -58
  567. package/src/x_ite/Components/Geometry2D/Polyline2D.js +4 -8
  568. package/src/x_ite/Components/Geometry2D/Polypoint2D.js +3 -5
  569. package/src/x_ite/Components/Geometry2D/TriangleSet2D.js +20 -16
  570. package/src/x_ite/Components/Geometry3D/Cone.js +1 -3
  571. package/src/x_ite/Components/Geometry3D/Cylinder.js +3 -5
  572. package/src/x_ite/Components/Geometry3D/ElevationGrid.js +35 -17
  573. package/src/x_ite/Components/Geometry3D/Extrusion.js +125 -107
  574. package/src/x_ite/Components/Geometry3D/IndexedFaceSet.js +164 -142
  575. package/src/x_ite/Components/Geometry3D/Sphere.js +3 -5
  576. package/src/x_ite/Components/Geometry3D.js +6 -9
  577. package/src/x_ite/Components/Geospatial/GeoElevationGrid.js +7 -7
  578. package/src/x_ite/Components/Geospatial/GeoLOD.js +207 -124
  579. package/src/x_ite/Components/Geospatial/GeoLocation.js +6 -6
  580. package/src/x_ite/Components/Geospatial/GeoProximitySensor.js +5 -3
  581. package/src/x_ite/Components/Geospatial/GeoTransform.js +9 -9
  582. package/src/x_ite/Components/Geospatial/GeoViewpoint.js +27 -27
  583. package/src/x_ite/Components/Grouping/Group.js +3 -3
  584. package/src/x_ite/Components/Grouping/StaticGroup.js +49 -56
  585. package/src/x_ite/Components/Grouping/Switch.js +171 -21
  586. package/src/x_ite/Components/Grouping/Transform.js +3 -3
  587. package/src/x_ite/Components/Grouping/X3DBoundedObject.js +68 -15
  588. package/src/x_ite/Components/Grouping/X3DGroupingNode.js +339 -180
  589. package/src/x_ite/Components/Grouping/X3DTransformMatrix3DNode.js +51 -25
  590. package/src/x_ite/Components/Grouping/X3DTransformNode.js +2 -4
  591. package/src/x_ite/Components/Grouping.js +6 -9
  592. package/src/x_ite/Components/{H-Anim → HAnim}/HAnimDisplacer.js +4 -4
  593. package/src/x_ite/Components/{H-Anim → HAnim}/HAnimHumanoid.js +24 -14
  594. package/src/x_ite/Components/{H-Anim → HAnim}/HAnimJoint.js +44 -20
  595. package/src/x_ite/Components/HAnim/HAnimMotion.js +113 -0
  596. package/src/x_ite/Components/{H-Anim → HAnim}/HAnimSegment.js +6 -4
  597. package/src/x_ite/Components/{H-Anim → HAnim}/HAnimSite.js +4 -4
  598. package/src/x_ite/Components/Interpolation/OrientationInterpolator.js +8 -7
  599. package/src/x_ite/Components/Interpolation/SquadOrientationInterpolator.js +4 -3
  600. package/src/x_ite/Components/Interpolation.js +6 -9
  601. package/src/x_ite/Components/KeyDeviceSensor/X3DKeyDeviceSensorNode.js +1 -3
  602. package/src/x_ite/Components/Layering/Layer.js +12 -2
  603. package/src/x_ite/Components/Layering/LayerSet.js +4 -6
  604. package/src/x_ite/Components/Layering/Viewport.js +8 -8
  605. package/src/x_ite/Components/Layering/X3DLayerNode.js +67 -62
  606. package/src/x_ite/Components/Layering.js +6 -9
  607. package/src/x_ite/Components/Layout/LayoutGroup.js +18 -15
  608. package/src/x_ite/Components/Layout/LayoutLayer.js +10 -5
  609. package/src/x_ite/Components/Layout/ScreenFontStyle.js +12 -14
  610. package/src/x_ite/Components/Layout/ScreenGroup.js +25 -31
  611. package/src/x_ite/Components/Lighting/DirectionalLight.js +27 -22
  612. package/src/x_ite/Components/Lighting/PointLight.js +26 -29
  613. package/src/x_ite/Components/Lighting/SpotLight.js +29 -24
  614. package/src/x_ite/Components/Lighting/X3DLightNode.js +85 -66
  615. package/src/x_ite/Components/Lighting.js +6 -9
  616. package/src/x_ite/Components/NURBS/Contour2D.js +45 -1
  617. package/src/x_ite/Components/NURBS/ContourPolyline2D.js +53 -25
  618. package/src/x_ite/Components/NURBS/NurbsCurve.js +21 -24
  619. package/src/x_ite/Components/NURBS/NurbsCurve2D.js +44 -25
  620. package/src/x_ite/Components/NURBS/NurbsOrientationInterpolator.js +19 -21
  621. package/src/x_ite/Components/NURBS/NurbsPositionInterpolator.js +18 -20
  622. package/src/x_ite/Components/NURBS/NurbsSet.js +17 -6
  623. package/src/x_ite/Components/NURBS/NurbsSweptSurface.js +2 -2
  624. package/src/x_ite/Components/NURBS/NurbsSwungSurface.js +2 -2
  625. package/src/x_ite/Components/NURBS/NurbsTextureCoordinate.js +15 -16
  626. package/src/x_ite/Components/NURBS/NurbsTrimmedSurface.js +38 -1
  627. package/src/x_ite/Components/NURBS/X3DNurbsSurfaceGeometryNode.js +116 -43
  628. package/src/x_ite/Components/Navigation/Billboard.js +12 -11
  629. package/src/x_ite/Components/Navigation/Collision.js +10 -8
  630. package/src/x_ite/Components/Navigation/LOD.js +207 -59
  631. package/src/x_ite/Components/Navigation/NavigationInfo.js +29 -43
  632. package/src/x_ite/Components/Navigation/OrthoViewpoint.js +99 -18
  633. package/src/x_ite/Components/Navigation/Viewpoint.js +15 -15
  634. package/src/x_ite/Components/Navigation/ViewpointGroup.js +12 -5
  635. package/src/x_ite/Components/Navigation/X3DViewpointNode.js +137 -148
  636. package/src/x_ite/Components/Navigation.js +6 -9
  637. package/src/x_ite/Components/Networking/Anchor.js +22 -24
  638. package/src/x_ite/Components/Networking/Inline.js +63 -44
  639. package/src/x_ite/Components/Networking/X3DUrlObject.js +88 -8
  640. package/src/x_ite/Components/Networking.js +6 -9
  641. package/src/x_ite/Components/ParticleSystems/BoundedPhysicsModel.js +2 -2
  642. package/src/x_ite/Components/ParticleSystems/ParticleSystem.js +215 -199
  643. package/src/x_ite/Components/ParticleSystems/PolylineEmitter.js +44 -39
  644. package/src/x_ite/Components/ParticleSystems/SurfaceEmitter.js +48 -46
  645. package/src/x_ite/Components/ParticleSystems/VolumeEmitter.js +121 -117
  646. package/src/x_ite/Components/ParticleSystems/WindPhysicsModel.js +21 -18
  647. package/src/x_ite/Components/ParticleSystems/X3DParticleEmitterNode.js +20 -22
  648. package/src/x_ite/Components/Picking/LinePickSensor.js +251 -6
  649. package/src/x_ite/Components/Picking/PickableGroup.js +120 -7
  650. package/src/x_ite/Components/Picking/PointPickSensor.js +260 -8
  651. package/src/x_ite/Components/Picking/PrimitivePickSensor.js +174 -4
  652. package/src/x_ite/Components/Picking/VolumePickSensor.js +150 -4
  653. package/src/x_ite/Components/Picking/X3DPickSensorNode.js +377 -4
  654. package/src/x_ite/Components/Picking/X3DPickableObject.js +21 -1
  655. package/src/x_ite/Components/PointingDeviceSensor/CylinderSensor.js +26 -11
  656. package/src/x_ite/Components/PointingDeviceSensor.js +6 -9
  657. package/src/x_ite/Components/ProjectiveTextureMapping/TextureProjectorParallel.js +282 -0
  658. package/src/x_ite/Components/ProjectiveTextureMapping/TextureProjectorPerspective.js +227 -0
  659. package/src/x_ite/Components/ProjectiveTextureMapping/X3DTextureProjectorNode.js +217 -0
  660. package/src/x_ite/Components/Rendering/ClipPlane.js +8 -10
  661. package/src/x_ite/Components/Rendering/Color.js +22 -13
  662. package/src/x_ite/Components/Rendering/ColorRGBA.js +28 -16
  663. package/src/x_ite/Components/Rendering/IndexedLineSet.js +52 -33
  664. package/src/x_ite/Components/Rendering/IndexedTriangleFanSet.js +17 -14
  665. package/src/x_ite/Components/Rendering/IndexedTriangleSet.js +9 -4
  666. package/src/x_ite/Components/Rendering/IndexedTriangleStripSet.js +17 -17
  667. package/src/x_ite/Components/Rendering/LineSet.js +44 -27
  668. package/src/x_ite/Components/Rendering/Normal.js +20 -4
  669. package/src/x_ite/Components/Rendering/PointSet.js +38 -16
  670. package/src/x_ite/Components/Rendering/TriangleFanSet.js +7 -9
  671. package/src/x_ite/Components/Rendering/TriangleStripSet.js +6 -8
  672. package/src/x_ite/Components/Rendering/X3DColorNode.js +16 -1
  673. package/src/x_ite/Components/Rendering/X3DComposedGeometryNode.js +80 -55
  674. package/src/x_ite/Components/Rendering/X3DCoordinateNode.js +11 -13
  675. package/src/x_ite/Components/Rendering/X3DGeometryNode.js +622 -477
  676. package/src/x_ite/Components/Rendering/X3DLineGeometryNode.js +159 -90
  677. package/src/x_ite/Components/Rendering.js +6 -9
  678. package/src/x_ite/Components/RigidBodyPhysics/BallJoint.js +8 -10
  679. package/src/x_ite/Components/RigidBodyPhysics/CollidableOffset.js +142 -26
  680. package/src/x_ite/Components/RigidBodyPhysics/CollidableShape.js +312 -128
  681. package/src/x_ite/Components/RigidBodyPhysics/CollisionCollection.js +91 -7
  682. package/src/x_ite/Components/RigidBodyPhysics/CollisionSensor.js +189 -4
  683. package/src/x_ite/Components/RigidBodyPhysics/CollisionSpace.js +82 -4
  684. package/src/x_ite/Components/RigidBodyPhysics/Contact.js +1 -1
  685. package/src/x_ite/Components/RigidBodyPhysics/DoubleAxisHingeJoint.js +49 -37
  686. package/src/x_ite/Components/RigidBodyPhysics/RigidBody.js +45 -39
  687. package/src/x_ite/Components/RigidBodyPhysics/RigidBodyCollection.js +41 -34
  688. package/src/x_ite/Components/RigidBodyPhysics/SingleAxisHingeJoint.js +25 -20
  689. package/src/x_ite/Components/RigidBodyPhysics/SliderJoint.js +8 -10
  690. package/src/x_ite/Components/RigidBodyPhysics/X3DNBodyCollidableNode.js +15 -16
  691. package/src/x_ite/Components/RigidBodyPhysics/X3DNBodyCollisionSpaceNode.js +2 -4
  692. package/src/x_ite/Components/Scripting/Script.js +147 -101
  693. package/src/x_ite/Components/Scripting/X3DScriptNode.js +2 -4
  694. package/src/x_ite/Components/Shaders/ComposedShader.js +17 -19
  695. package/src/x_ite/Components/Shaders/FloatVertexAttribute.js +9 -3
  696. package/src/x_ite/Components/Shaders/Matrix3VertexAttribute.js +10 -3
  697. package/src/x_ite/Components/Shaders/Matrix4VertexAttribute.js +10 -3
  698. package/src/x_ite/Components/Shaders/PackagedShader.js +18 -14
  699. package/src/x_ite/Components/Shaders/ShaderPart.js +30 -18
  700. package/src/x_ite/Components/Shaders/ShaderProgram.js +15 -11
  701. package/src/x_ite/Components/Shaders/X3DProgrammableShaderObject.js +681 -558
  702. package/src/x_ite/Components/Shaders/X3DShaderNode.js +48 -12
  703. package/src/x_ite/Components/Shaders.js +15 -18
  704. package/src/x_ite/Components/Shape/Appearance.js +153 -77
  705. package/src/x_ite/Components/Shape/FillProperties.js +63 -4
  706. package/src/x_ite/Components/Shape/LineProperties.js +27 -5
  707. package/src/x_ite/Components/Shape/Material.js +48 -62
  708. package/src/x_ite/Components/Shape/PointProperties.js +162 -0
  709. package/src/x_ite/Components/Shape/Shape.js +86 -39
  710. package/src/x_ite/Components/Shape/TwoSidedMaterial.js +53 -59
  711. package/src/x_ite/Components/Shape/UnlitMaterial.js +109 -0
  712. package/src/x_ite/Components/Shape/X3DAppearanceNode.js +9 -6
  713. package/src/x_ite/Components/Shape/X3DMaterialNode.js +16 -3
  714. package/src/x_ite/Components/Shape/X3DOneSidedMaterialNode.js +111 -0
  715. package/src/x_ite/Components/Shape/X3DShapeNode.js +41 -17
  716. package/src/x_ite/Components/Shape.js +22 -16
  717. package/src/x_ite/Components/Sound/AudioClip.js +36 -50
  718. package/src/x_ite/Components/Sound/Sound.js +36 -36
  719. package/src/x_ite/Components/Sound/X3DSoundSourceNode.js +18 -6
  720. package/src/x_ite/Components/Sound.js +6 -9
  721. package/src/x_ite/Components/Text/FontStyle.js +10 -12
  722. package/src/x_ite/Components/Text/Text.js +6 -6
  723. package/src/x_ite/Components/Text/X3DFontStyleNode.js +56 -87
  724. package/src/x_ite/Components/Text.js +6 -9
  725. package/src/x_ite/Components/Texturing/ImageTexture.js +48 -63
  726. package/src/x_ite/Components/Texturing/MovieTexture.js +42 -56
  727. package/src/x_ite/Components/Texturing/MultiTexture.js +236 -11
  728. package/src/x_ite/Components/Texturing/MultiTextureCoordinate.js +73 -6
  729. package/src/x_ite/Components/Texturing/MultiTextureTransform.js +45 -4
  730. package/src/x_ite/Components/Texturing/PixelTexture.js +45 -11
  731. package/src/x_ite/Components/Texturing/TextureCoordinate.js +32 -17
  732. package/src/x_ite/Components/Texturing/TextureCoordinateGenerator.js +68 -8
  733. package/src/x_ite/Components/Texturing/TextureProperties.js +96 -65
  734. package/src/x_ite/Components/Texturing/TextureTransform.js +55 -47
  735. package/src/x_ite/Components/Texturing/X3DSingleTextureCoordinateNode.js +91 -0
  736. package/src/x_ite/Components/Texturing/X3DSingleTextureNode.js +183 -0
  737. package/src/x_ite/Components/Texturing/X3DSingleTextureTransformNode.js +77 -0
  738. package/src/x_ite/Components/Texturing/X3DTexture2DNode.js +42 -95
  739. package/src/x_ite/Components/Texturing/X3DTexture2DNode.js.~1~ +209 -0
  740. package/src/x_ite/Components/Texturing/X3DTextureCoordinateNode.js +3 -17
  741. package/src/x_ite/Components/Texturing/X3DTextureNode.js +6 -67
  742. package/src/x_ite/Components/Texturing/X3DTextureTransformNode.js +4 -11
  743. package/src/x_ite/Components/Texturing.js +31 -25
  744. package/src/x_ite/Components/Texturing3D/ComposedTexture3D.js +88 -4
  745. package/src/x_ite/Components/Texturing3D/ImageTexture3D.js +105 -13
  746. package/src/x_ite/Components/Texturing3D/PixelTexture3D.js +124 -4
  747. package/src/x_ite/Components/Texturing3D/TextureCoordinate3D.js +35 -18
  748. package/src/x_ite/Components/Texturing3D/TextureCoordinate4D.js +35 -18
  749. package/src/x_ite/Components/Texturing3D/TextureTransform3D.js +41 -31
  750. package/src/x_ite/Components/Texturing3D/TextureTransformMatrix3D.js +18 -11
  751. package/src/x_ite/Components/Texturing3D/X3DTexture3DNode.js +110 -6
  752. package/src/x_ite/Components/Time/TimeSensor.js +23 -19
  753. package/src/x_ite/Components/Time/X3DTimeDependentNode.js +11 -7
  754. package/src/x_ite/Components/Time.js +6 -9
  755. package/src/x_ite/Components/VolumeRendering/BlendedVolumeStyle.js +309 -8
  756. package/src/x_ite/Components/VolumeRendering/BoundaryEnhancementVolumeStyle.js +58 -4
  757. package/src/x_ite/Components/VolumeRendering/CartoonVolumeStyle.js +217 -6
  758. package/src/x_ite/Components/VolumeRendering/ComposedVolumeStyle.js +132 -3
  759. package/src/x_ite/Components/VolumeRendering/EdgeEnhancementVolumeStyle.js +86 -5
  760. package/src/x_ite/Components/VolumeRendering/IsoSurfaceVolumeData.js +309 -11
  761. package/src/x_ite/Components/VolumeRendering/OpacityMapVolumeStyle.js +85 -3
  762. package/src/x_ite/Components/VolumeRendering/ProjectionVolumeStyle.js +134 -2
  763. package/src/x_ite/Components/VolumeRendering/SegmentedVolumeData.js +222 -9
  764. package/src/x_ite/Components/VolumeRendering/ShadedVolumeStyle.js +191 -8
  765. package/src/x_ite/Components/VolumeRendering/SilhouetteEnhancementVolumeStyle.js +85 -6
  766. package/src/x_ite/Components/VolumeRendering/ToneMappedVolumeStyle.js +95 -5
  767. package/src/x_ite/Components/VolumeRendering/VolumeData.js +153 -8
  768. package/src/x_ite/Components/VolumeRendering/X3DVolumeDataNode.js +155 -3
  769. package/src/x_ite/Components/VolumeRendering/X3DVolumeRenderStyleNode.js +62 -0
  770. package/src/x_ite/Components/X_ITE/BlendMode.js +51 -51
  771. package/src/x_ite/Components.js +11 -16
  772. package/src/x_ite/Configuration/ComponentInfo.js +12 -6
  773. package/src/x_ite/Configuration/ComponentInfoArray.js +4 -7
  774. package/src/x_ite/Configuration/ProfileInfo.js +10 -6
  775. package/src/x_ite/Configuration/SupportedComponents.js +66 -40
  776. package/src/x_ite/Configuration/SupportedNodes.js +22 -6
  777. package/src/x_ite/Configuration/SupportedProfiles.js +91 -89
  778. package/src/x_ite/Configuration/UnitInfo.js +12 -2
  779. package/src/x_ite/Configuration/X3DInfoArray.js +37 -18
  780. package/src/x_ite/Execution/BindableList.js +63 -38
  781. package/src/x_ite/Execution/BindableStack.js +63 -71
  782. package/src/x_ite/Execution/ExportedNode.js +25 -2
  783. package/src/x_ite/Execution/ImportedNode.js +122 -39
  784. package/src/x_ite/Execution/Scene.js +22 -14
  785. package/src/x_ite/Execution/World.js +22 -19
  786. package/src/x_ite/Execution/X3DExecutionContext.js +381 -221
  787. package/src/x_ite/Execution/X3DScene.js +213 -53
  788. package/src/x_ite/{Error.js → Fallback.js} +26 -29
  789. package/src/x_ite/Fields/ArrayFields.js +176 -57
  790. package/src/x_ite/Fields/SFBool.js +6 -5
  791. package/src/x_ite/Fields/SFColor.js +24 -21
  792. package/src/x_ite/Fields/SFColorRGBA.js +23 -23
  793. package/src/x_ite/Fields/SFDouble.js +6 -5
  794. package/src/x_ite/Fields/SFFloat.js +7 -6
  795. package/src/x_ite/Fields/SFImage.js +37 -36
  796. package/src/x_ite/Fields/SFInt32.js +5 -4
  797. package/src/x_ite/Fields/SFMatrix3.js +19 -15
  798. package/src/x_ite/Fields/SFMatrix4.js +19 -15
  799. package/src/x_ite/Fields/SFMatrixPrototypeTemplate.js +10 -2
  800. package/src/x_ite/Fields/SFNode.js +105 -53
  801. package/src/x_ite/Fields/SFNodeCache.js +93 -0
  802. package/src/x_ite/Fields/SFRotation.js +31 -27
  803. package/src/x_ite/Fields/SFString.js +9 -8
  804. package/src/x_ite/Fields/SFTime.js +6 -5
  805. package/src/x_ite/Fields/SFVec2.js +17 -13
  806. package/src/x_ite/Fields/SFVec3.js +21 -17
  807. package/src/x_ite/Fields/SFVec4.js +24 -20
  808. package/src/x_ite/Fields/SFVecPrototypeTemplate.js +8 -4
  809. package/src/x_ite/Fields.js +2 -6
  810. package/src/x_ite/InputOutput/FileLoader.js +174 -190
  811. package/src/x_ite/InputOutput/Generator.js +133 -104
  812. package/src/x_ite/Parser/HTMLSupport.js +3 -596
  813. package/src/x_ite/Parser/JSONParser.js +348 -245
  814. package/src/x_ite/Parser/Parser.js +314 -303
  815. package/src/x_ite/Parser/X3DParser.js +41 -20
  816. package/src/x_ite/Parser/XMLParser.js +178 -60
  817. package/src/x_ite/Prototype/ExternProtoDeclarationArray.js +17 -0
  818. package/src/x_ite/Prototype/ProtoDeclarationArray.js +17 -0
  819. package/src/x_ite/Prototype/X3DExternProtoDeclaration.js +104 -44
  820. package/src/x_ite/Prototype/X3DProtoDeclaration.js +111 -42
  821. package/src/x_ite/Prototype/X3DProtoDeclarationNode.js +16 -14
  822. package/src/x_ite/Rendering/DependentRenderer.js +7 -9
  823. package/src/x_ite/Rendering/TextureBuffer.js +24 -19
  824. package/src/x_ite/Rendering/X3DRenderObject.js +455 -428
  825. package/src/x_ite/Routing/RouteArray.js +34 -11
  826. package/src/x_ite/Routing/X3DRoute.js +60 -60
  827. package/src/x_ite/Routing/X3DRoutingContext.js +6 -6
  828. package/src/x_ite/X3D.js +30 -37
  829. package/src/x_ite.config.js +40 -5
  830. package/src/x_ite.css +165 -45
  831. package/src/x_ite.html +49 -29
  832. package/src/x_ite.js +86 -25
  833. package/x_ite.min.html +49 -22
  834. package/.bzrignore +0 -3
  835. package/AUTHORS.md +0 -6
  836. package/STYLE_GUIDE.md +0 -51
  837. package/X_ITE.sln +0 -54
  838. package/X_ITE.userprefs +0 -14
  839. package/build/build.mdproj +0 -47
  840. package/build/cad-geometry.build.js +0 -15
  841. package/build/geospatial.build.js +0 -15
  842. package/build/h-anim.build.js +0 -15
  843. package/build/nurbs.build.js +0 -15
  844. package/build/particle-systems.build.js +0 -15
  845. package/build/parts/cad-geometry.end.frag +0 -2
  846. package/build/parts/cad-geometry.start.frag +0 -6
  847. package/build/parts/geospatial.end.frag +0 -2
  848. package/build/parts/geospatial.start.frag +0 -6
  849. package/build/parts/h-anim.end.frag +0 -2
  850. package/build/parts/h-anim.start.frag +0 -6
  851. package/build/parts/nurbs.end.frag +0 -2
  852. package/build/parts/nurbs.start.frag +0 -6
  853. package/build/parts/particle-systems.end.frag +0 -2
  854. package/build/parts/particle-systems.start.frag +0 -6
  855. package/build/parts/rigid-body-physics.end.frag +0 -2
  856. package/build/parts/rigid-body-physics.start.frag +0 -6
  857. package/build/parts/texturing-3d.end.frag +0 -2
  858. package/build/parts/texturing-3d.start.frag +0 -6
  859. package/build/parts/x_ite.end.frag +0 -9
  860. package/build/parts/x_ite.start.frag +0 -6
  861. package/build/rigid-body-physics.build.js +0 -15
  862. package/build/texturing-3d.build.js +0 -15
  863. package/dist/components/README +0 -3
  864. package/dist/components/cad-geometry.min.js +0 -1
  865. package/dist/components/geospatial.min.js +0 -2
  866. package/dist/components/h-anim.min.js +0 -1
  867. package/dist/components/nurbs.min.js +0 -2
  868. package/dist/components/particle-systems.min.js +0 -2
  869. package/dist/components/rigid-body-physics.js +0 -3761
  870. package/dist/components/rigid-body-physics.min.js +0 -56
  871. package/dist/components/texturing-3d.min.js +0 -1
  872. package/dist/dist.mdproj +0 -61
  873. package/dist/images/logo.128.png +0 -0
  874. package/fonts/fonts.mdproj +0 -29
  875. package/meta/meta.mdproj +0 -35
  876. package/src/components/cad-geometry.config.js +0 -56
  877. package/src/components/geospatial.config.js +0 -56
  878. package/src/components/h-anim.config.js +0 -56
  879. package/src/components/nurbs.config.js +0 -61
  880. package/src/components/particle-systems.config.js +0 -56
  881. package/src/components/rigid-body-physics.config.js +0 -61
  882. package/src/components/texturing-3d.config.js +0 -56
  883. package/src/images/logo.128.png +0 -0
  884. package/src/locale/de.mo +0 -0
  885. package/src/locale/fr.mo +0 -0
  886. package/src/src.mdproj +0 -698
  887. package/src/standard/Networking/URI.js +0 -785
  888. package/src/test.x3d +0 -225
  889. package/src/x_ite/Browser/Shaders/Background.fs +0 -31
  890. package/src/x_ite/Browser/Shaders/Background.vs +0 -23
  891. package/src/x_ite/Browser/Shaders/Depth.fs +0 -32
  892. package/src/x_ite/Browser/Shaders/Depth.vs +0 -21
  893. package/src/x_ite/Browser/Shaders/Gouraud.fs +0 -135
  894. package/src/x_ite/Browser/Shaders/Gouraud.vs +0 -145
  895. package/src/x_ite/Browser/Shaders/Phong.fs +0 -269
  896. package/src/x_ite/Browser/Shaders/Phong.vs +0 -47
  897. package/src/x_ite/Browser/Shaders/PointSet.fs +0 -86
  898. package/src/x_ite/Browser/Shaders/Types.h +0 -55
  899. package/src/x_ite/Browser/Shaders/Wireframe.fs +0 -82
  900. package/src/x_ite/Browser/Shaders/Wireframe.vs +0 -61
  901. package/src/x_ite/Components/DIS.js +0 -91
  902. package/src/x_ite/Components/Picking.js +0 -94
  903. package/src/x_ite/Components/VolumeRendering.js +0 -121
@@ -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
+ });