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,1019 @@
1
+ // jshint ignore: start
2
+
3
+ /* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- /
4
+ /* vim: set shiftwidth=2 tabstop=2 autoindent cindent expandtab: */
5
+ /*
6
+ Copyright 2011 notmasteryet
7
+
8
+ Licensed under the Apache License, Version 2.0 (the "License");
9
+ you may not use this file except in compliance with the License.
10
+ You may obtain a copy of the License at
11
+
12
+ http://www.apache.org/licenses/LICENSE-2.0
13
+
14
+ Unless required by applicable law or agreed to in writing, software
15
+ distributed under the License is distributed on an "AS IS" BASIS,
16
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
+ See the License for the specific language governing permissions and
18
+ limitations under the License.
19
+ */
20
+
21
+ // - The JPEG specification can be found in the ITU CCITT Recommendation T.81
22
+ // (www.w3.org/Graphics/JPEG/itu-t81.pdf)
23
+ // - The JFIF specification can be found in the JPEG File Interchange Format
24
+ // (www.w3.org/Graphics/JPEG/jfif3.pdf)
25
+ // - The Adobe Application-Specific JPEG markers in the Supporting the DCT Filters
26
+ // in PostScript Level 2, Technical Note #5116
27
+ // (partners.adobe.com/public/developer/en/ps/sdk/5116.DCT_Filter.pdf)
28
+
29
+ var ColorSpace = {Unkown: 0, Grayscale: 1, AdobeRGB: 2, RGB: 3, CYMK: 4};
30
+ var JpegImage = (function jpegImage() {
31
+ "use strict";
32
+ var dctZigZag = new Int32Array([
33
+ 0,
34
+ 1, 8,
35
+ 16, 9, 2,
36
+ 3, 10, 17, 24,
37
+ 32, 25, 18, 11, 4,
38
+ 5, 12, 19, 26, 33, 40,
39
+ 48, 41, 34, 27, 20, 13, 6,
40
+ 7, 14, 21, 28, 35, 42, 49, 56,
41
+ 57, 50, 43, 36, 29, 22, 15,
42
+ 23, 30, 37, 44, 51, 58,
43
+ 59, 52, 45, 38, 31,
44
+ 39, 46, 53, 60,
45
+ 61, 54, 47,
46
+ 55, 62,
47
+ 63
48
+ ]);
49
+
50
+ var dctCos1 = 4017; // cos(pi/16)
51
+ var dctSin1 = 799; // sin(pi/16)
52
+ var dctCos3 = 3406; // cos(3*pi/16)
53
+ var dctSin3 = 2276; // sin(3*pi/16)
54
+ var dctCos6 = 1567; // cos(6*pi/16)
55
+ var dctSin6 = 3784; // sin(6*pi/16)
56
+ var dctSqrt2 = 5793; // sqrt(2)
57
+ var dctSqrt1d2 = 2896; // sqrt(2) / 2
58
+
59
+ function constructor() {
60
+ }
61
+
62
+ function buildHuffmanTable(codeLengths, values) {
63
+ var k = 0, code = [], i, j, length = 16;
64
+ while (length > 0 && !codeLengths[length - 1])
65
+ length--;
66
+ code.push({children: [], index: 0});
67
+ var p = code[0], q;
68
+ for (i = 0; i < length; i++) {
69
+ for (j = 0; j < codeLengths[i]; j++) {
70
+ p = code.pop();
71
+ p.children[p.index] = values[k];
72
+ while (p.index > 0) {
73
+ p = code.pop();
74
+ }
75
+ p.index++;
76
+ code.push(p);
77
+ while (code.length <= i) {
78
+ code.push(q = {children: [], index: 0});
79
+ p.children[p.index] = q.children;
80
+ p = q;
81
+ }
82
+ k++;
83
+ }
84
+ if (i + 1 < length) {
85
+ // p here points to last code
86
+ code.push(q = {children: [], index: 0});
87
+ p.children[p.index] = q.children;
88
+ p = q;
89
+ }
90
+ }
91
+ return code[0].children;
92
+ }
93
+
94
+ function getBlockBufferOffset(component, row, col) {
95
+ return 64 * ((component.blocksPerLine + 1) * row + col);
96
+ }
97
+
98
+ function decodeScan(data, offset,
99
+ frame, components, resetInterval,
100
+ spectralStart, spectralEnd,
101
+ successivePrev, successive) {
102
+ var precision = frame.precision;
103
+ var samplesPerLine = frame.samplesPerLine;
104
+ var scanLines = frame.scanLines;
105
+ var mcusPerLine = frame.mcusPerLine;
106
+ var progressive = frame.progressive;
107
+ var maxH = frame.maxH, maxV = frame.maxV;
108
+
109
+ var startOffset = offset, bitsData = 0, bitsCount = 0;
110
+
111
+ function readBit() {
112
+ if (bitsCount > 0) {
113
+ bitsCount--;
114
+ return (bitsData >> bitsCount) & 1;
115
+ }
116
+ bitsData = data[offset++];
117
+ if (bitsData == 0xFF) {
118
+ var nextByte = data[offset++];
119
+ if (nextByte) {
120
+ throw "unexpected marker: " + ((bitsData << 8) | nextByte).toString(16);
121
+ }
122
+ // unstuff 0
123
+ }
124
+ bitsCount = 7;
125
+ return bitsData >>> 7;
126
+ }
127
+
128
+ function decodeHuffman(tree) {
129
+ var node = tree;
130
+ var bit;
131
+ while ((bit = readBit()) !== null) {
132
+ node = node[bit];
133
+ if (typeof node === 'number')
134
+ return node;
135
+ if (typeof node !== 'object')
136
+ throw "invalid huffman sequence";
137
+ }
138
+ return null;
139
+ }
140
+
141
+ function receive(length) {
142
+ var n = 0;
143
+ while (length > 0) {
144
+ var bit = readBit();
145
+ if (bit === null)
146
+ return;
147
+ n = (n << 1) | bit;
148
+ length--;
149
+ }
150
+ return n;
151
+ }
152
+
153
+ function receiveAndExtend(length) {
154
+ var n = receive(length);
155
+ if (n >= 1 << (length - 1))
156
+ return n;
157
+ return n + (-1 << length) + 1;
158
+ }
159
+
160
+ function decodeBaseline(component, offset) {
161
+ var t = decodeHuffman(component.huffmanTableDC);
162
+ var diff = t === 0 ? 0 : receiveAndExtend(t);
163
+ component.blockData[offset] = (component.pred += diff);
164
+ var k = 1;
165
+ while (k < 64) {
166
+ var rs = decodeHuffman(component.huffmanTableAC);
167
+ var s = rs & 15, r = rs >> 4;
168
+ if (s === 0) {
169
+ if (r < 15)
170
+ break;
171
+ k += 16;
172
+ continue;
173
+ }
174
+ k += r;
175
+ var z = dctZigZag[k];
176
+ component.blockData[offset + z] = receiveAndExtend(s);
177
+ k++;
178
+ }
179
+ }
180
+
181
+ function decodeDCFirst(component, offset) {
182
+ var t = decodeHuffman(component.huffmanTableDC);
183
+ var diff = t === 0 ? 0 : (receiveAndExtend(t) << successive);
184
+ component.blockData[offset] = (component.pred += diff);
185
+ }
186
+
187
+ function decodeDCSuccessive(component, offset) {
188
+ component.blockData[offset] |= readBit() << successive;
189
+ }
190
+
191
+ var eobrun = 0;
192
+ function decodeACFirst(component, offset) {
193
+ if (eobrun > 0) {
194
+ eobrun--;
195
+ return;
196
+ }
197
+ var k = spectralStart, e = spectralEnd;
198
+ while (k <= e) {
199
+ var rs = decodeHuffman(component.huffmanTableAC);
200
+ var s = rs & 15, r = rs >> 4;
201
+ if (s === 0) {
202
+ if (r < 15) {
203
+ eobrun = receive(r) + (1 << r) - 1;
204
+ break;
205
+ }
206
+ k += 16;
207
+ continue;
208
+ }
209
+ k += r;
210
+ var z = dctZigZag[k];
211
+ component.blockData[offset + z] = receiveAndExtend(s) * (1 << successive);
212
+ k++;
213
+ }
214
+ }
215
+
216
+ var successiveACState = 0, successiveACNextValue;
217
+ function decodeACSuccessive(component, offset) {
218
+ var k = spectralStart, e = spectralEnd, r = 0;
219
+ while (k <= e) {
220
+ var z = dctZigZag[k];
221
+ switch (successiveACState) {
222
+ case 0: // initial state
223
+ var rs = decodeHuffman(component.huffmanTableAC);
224
+ var s = rs & 15;
225
+ r = rs >> 4;
226
+ if (s === 0) {
227
+ if (r < 15) {
228
+ eobrun = receive(r) + (1 << r);
229
+ successiveACState = 4;
230
+ } else {
231
+ r = 16;
232
+ successiveACState = 1;
233
+ }
234
+ } else {
235
+ if (s !== 1)
236
+ throw "invalid ACn encoding";
237
+ successiveACNextValue = receiveAndExtend(s);
238
+ successiveACState = r ? 2 : 3;
239
+ }
240
+ continue;
241
+ case 1: // skipping r zero items
242
+ case 2:
243
+ if (component.blockData[offset + z]) {
244
+ component.blockData[offset + z] += (readBit() << successive);
245
+ } else {
246
+ r--;
247
+ if (r === 0)
248
+ successiveACState = successiveACState == 2 ? 3 : 0;
249
+ }
250
+ break;
251
+ case 3: // set value for a zero item
252
+ if (component.blockData[offset + z]) {
253
+ component.blockData[offset + z] += (readBit() << successive);
254
+ } else {
255
+ component.blockData[offset + z] = successiveACNextValue << successive;
256
+ successiveACState = 0;
257
+ }
258
+ break;
259
+ case 4: // eob
260
+ if (component.blockData[offset + z]) {
261
+ component.blockData[offset + z] += (readBit() << successive);
262
+ }
263
+ break;
264
+ }
265
+ k++;
266
+ }
267
+ if (successiveACState === 4) {
268
+ eobrun--;
269
+ if (eobrun === 0)
270
+ successiveACState = 0;
271
+ }
272
+ }
273
+
274
+ function decodeMcu(component, decode, mcu, row, col) {
275
+ var mcuRow = (mcu / mcusPerLine) | 0;
276
+ var mcuCol = mcu % mcusPerLine;
277
+ var blockRow = mcuRow * component.v + row;
278
+ var blockCol = mcuCol * component.h + col;
279
+ var offset = getBlockBufferOffset(component, blockRow, blockCol);
280
+ decode(component, offset);
281
+ }
282
+
283
+ function decodeBlock(component, decode, mcu) {
284
+ var blockRow = (mcu / component.blocksPerLine) | 0;
285
+ var blockCol = mcu % component.blocksPerLine;
286
+ var offset = getBlockBufferOffset(component, blockRow, blockCol);
287
+ decode(component, offset);
288
+ }
289
+
290
+ var componentsLength = components.length;
291
+ var component, i, j, k, n;
292
+ var decodeFn;
293
+ if (progressive) {
294
+ if (spectralStart === 0)
295
+ decodeFn = successivePrev === 0 ? decodeDCFirst : decodeDCSuccessive;
296
+ else
297
+ decodeFn = successivePrev === 0 ? decodeACFirst : decodeACSuccessive;
298
+ } else {
299
+ decodeFn = decodeBaseline;
300
+ }
301
+
302
+ var mcu = 0, marker;
303
+ var mcuExpected;
304
+ if (componentsLength == 1) {
305
+ mcuExpected = components[0].blocksPerLine * components[0].blocksPerColumn;
306
+ } else {
307
+ mcuExpected = mcusPerLine * frame.mcusPerColumn;
308
+ }
309
+ if (!resetInterval) {
310
+ resetInterval = mcuExpected;
311
+ }
312
+
313
+ var h, v;
314
+ while (mcu < mcuExpected) {
315
+ // reset interval stuff
316
+ for (i = 0; i < componentsLength; i++) {
317
+ components[i].pred = 0;
318
+ }
319
+ eobrun = 0;
320
+
321
+ if (componentsLength == 1) {
322
+ component = components[0];
323
+ for (n = 0; n < resetInterval; n++) {
324
+ decodeBlock(component, decodeFn, mcu);
325
+ mcu++;
326
+ }
327
+ } else {
328
+ for (n = 0; n < resetInterval; n++) {
329
+ for (i = 0; i < componentsLength; i++) {
330
+ component = components[i];
331
+ h = component.h;
332
+ v = component.v;
333
+ for (j = 0; j < v; j++) {
334
+ for (k = 0; k < h; k++) {
335
+ decodeMcu(component, decodeFn, mcu, j, k);
336
+ }
337
+ }
338
+ }
339
+ mcu++;
340
+ }
341
+ }
342
+
343
+ // find marker
344
+ bitsCount = 0;
345
+ marker = (data[offset] << 8) | data[offset + 1];
346
+ if (marker <= 0xFF00) {
347
+ throw "marker was not found";
348
+ }
349
+
350
+ if (marker >= 0xFFD0 && marker <= 0xFFD7) { // RSTx
351
+ offset += 2;
352
+ } else {
353
+ break;
354
+ }
355
+ }
356
+
357
+ return offset - startOffset;
358
+ }
359
+
360
+ // A port of poppler's IDCT method which in turn is taken from:
361
+ // Christoph Loeffler, Adriaan Ligtenberg, George S. Moschytz,
362
+ // "Practical Fast 1-D DCT Algorithms with 11 Multiplications",
363
+ // IEEE Intl. Conf. on Acoustics, Speech & Signal Processing, 1989,
364
+ // 988-991.
365
+ function quantizeAndInverse(component, blockBufferOffset, p) {
366
+ var qt = component.quantizationTable;
367
+ var v0, v1, v2, v3, v4, v5, v6, v7, t;
368
+ var i;
369
+
370
+ // dequant
371
+ for (i = 0; i < 64; i++) {
372
+ p[i] = component.blockData[blockBufferOffset + i] * qt[i];
373
+ }
374
+
375
+ // inverse DCT on rows
376
+ for (i = 0; i < 8; ++i) {
377
+ var row = 8 * i;
378
+
379
+ // check for all-zero AC coefficients
380
+ if (p[1 + row] === 0 && p[2 + row] === 0 && p[3 + row] === 0 &&
381
+ p[4 + row] === 0 && p[5 + row] === 0 && p[6 + row] === 0 &&
382
+ p[7 + row] === 0) {
383
+ t = (dctSqrt2 * p[0 + row] + 512) >> 10;
384
+ p[0 + row] = t;
385
+ p[1 + row] = t;
386
+ p[2 + row] = t;
387
+ p[3 + row] = t;
388
+ p[4 + row] = t;
389
+ p[5 + row] = t;
390
+ p[6 + row] = t;
391
+ p[7 + row] = t;
392
+ continue;
393
+ }
394
+
395
+ // stage 4
396
+ v0 = (dctSqrt2 * p[0 + row] + 128) >> 8;
397
+ v1 = (dctSqrt2 * p[4 + row] + 128) >> 8;
398
+ v2 = p[2 + row];
399
+ v3 = p[6 + row];
400
+ v4 = (dctSqrt1d2 * (p[1 + row] - p[7 + row]) + 128) >> 8;
401
+ v7 = (dctSqrt1d2 * (p[1 + row] + p[7 + row]) + 128) >> 8;
402
+ v5 = p[3 + row] << 4;
403
+ v6 = p[5 + row] << 4;
404
+
405
+ // stage 3
406
+ t = (v0 - v1 + 1) >> 1;
407
+ v0 = (v0 + v1 + 1) >> 1;
408
+ v1 = t;
409
+ t = (v2 * dctSin6 + v3 * dctCos6 + 128) >> 8;
410
+ v2 = (v2 * dctCos6 - v3 * dctSin6 + 128) >> 8;
411
+ v3 = t;
412
+ t = (v4 - v6 + 1) >> 1;
413
+ v4 = (v4 + v6 + 1) >> 1;
414
+ v6 = t;
415
+ t = (v7 + v5 + 1) >> 1;
416
+ v5 = (v7 - v5 + 1) >> 1;
417
+ v7 = t;
418
+
419
+ // stage 2
420
+ t = (v0 - v3 + 1) >> 1;
421
+ v0 = (v0 + v3 + 1) >> 1;
422
+ v3 = t;
423
+ t = (v1 - v2 + 1) >> 1;
424
+ v1 = (v1 + v2 + 1) >> 1;
425
+ v2 = t;
426
+ t = (v4 * dctSin3 + v7 * dctCos3 + 2048) >> 12;
427
+ v4 = (v4 * dctCos3 - v7 * dctSin3 + 2048) >> 12;
428
+ v7 = t;
429
+ t = (v5 * dctSin1 + v6 * dctCos1 + 2048) >> 12;
430
+ v5 = (v5 * dctCos1 - v6 * dctSin1 + 2048) >> 12;
431
+ v6 = t;
432
+
433
+ // stage 1
434
+ p[0 + row] = v0 + v7;
435
+ p[7 + row] = v0 - v7;
436
+ p[1 + row] = v1 + v6;
437
+ p[6 + row] = v1 - v6;
438
+ p[2 + row] = v2 + v5;
439
+ p[5 + row] = v2 - v5;
440
+ p[3 + row] = v3 + v4;
441
+ p[4 + row] = v3 - v4;
442
+ }
443
+
444
+ // inverse DCT on columns
445
+ for (i = 0; i < 8; ++i) {
446
+ var col = i;
447
+
448
+ // check for all-zero AC coefficients
449
+ if (p[1 * 8 + col] === 0 && p[2 * 8 + col] === 0 && p[3 * 8 + col] === 0 &&
450
+ p[4 * 8 + col] === 0 && p[5 * 8 + col] === 0 && p[6 * 8 + col] === 0 &&
451
+ p[7 * 8 + col] === 0) {
452
+ t = (dctSqrt2 * p[i + 0] + 8192) >> 14;
453
+ p[0 * 8 + col] = t;
454
+ p[1 * 8 + col] = t;
455
+ p[2 * 8 + col] = t;
456
+ p[3 * 8 + col] = t;
457
+ p[4 * 8 + col] = t;
458
+ p[5 * 8 + col] = t;
459
+ p[6 * 8 + col] = t;
460
+ p[7 * 8 + col] = t;
461
+ continue;
462
+ }
463
+
464
+ // stage 4
465
+ v0 = (dctSqrt2 * p[0 * 8 + col] + 2048) >> 12;
466
+ v1 = (dctSqrt2 * p[4 * 8 + col] + 2048) >> 12;
467
+ v2 = p[2 * 8 + col];
468
+ v3 = p[6 * 8 + col];
469
+ v4 = (dctSqrt1d2 * (p[1 * 8 + col] - p[7 * 8 + col]) + 2048) >> 12;
470
+ v7 = (dctSqrt1d2 * (p[1 * 8 + col] + p[7 * 8 + col]) + 2048) >> 12;
471
+ v5 = p[3 * 8 + col];
472
+ v6 = p[5 * 8 + col];
473
+
474
+ // stage 3
475
+ t = (v0 - v1 + 1) >> 1;
476
+ v0 = (v0 + v1 + 1) >> 1;
477
+ v1 = t;
478
+ t = (v2 * dctSin6 + v3 * dctCos6 + 2048) >> 12;
479
+ v2 = (v2 * dctCos6 - v3 * dctSin6 + 2048) >> 12;
480
+ v3 = t;
481
+ t = (v4 - v6 + 1) >> 1;
482
+ v4 = (v4 + v6 + 1) >> 1;
483
+ v6 = t;
484
+ t = (v7 + v5 + 1) >> 1;
485
+ v5 = (v7 - v5 + 1) >> 1;
486
+ v7 = t;
487
+
488
+ // stage 2
489
+ t = (v0 - v3 + 1) >> 1;
490
+ v0 = (v0 + v3 + 1) >> 1;
491
+ v3 = t;
492
+ t = (v1 - v2 + 1) >> 1;
493
+ v1 = (v1 + v2 + 1) >> 1;
494
+ v2 = t;
495
+ t = (v4 * dctSin3 + v7 * dctCos3 + 2048) >> 12;
496
+ v4 = (v4 * dctCos3 - v7 * dctSin3 + 2048) >> 12;
497
+ v7 = t;
498
+ t = (v5 * dctSin1 + v6 * dctCos1 + 2048) >> 12;
499
+ v5 = (v5 * dctCos1 - v6 * dctSin1 + 2048) >> 12;
500
+ v6 = t;
501
+
502
+ // stage 1
503
+ p[0 * 8 + col] = v0 + v7;
504
+ p[7 * 8 + col] = v0 - v7;
505
+ p[1 * 8 + col] = v1 + v6;
506
+ p[6 * 8 + col] = v1 - v6;
507
+ p[2 * 8 + col] = v2 + v5;
508
+ p[5 * 8 + col] = v2 - v5;
509
+ p[3 * 8 + col] = v3 + v4;
510
+ p[4 * 8 + col] = v3 - v4;
511
+ }
512
+
513
+ // convert to 8-bit integers
514
+ for (i = 0; i < 64; ++i) {
515
+ var index = blockBufferOffset + i;
516
+ var q = p[i];
517
+ q = (q <= -2056 / component.bitConversion) ? 0 :
518
+ (q >= 2024 / component.bitConversion) ? 255 / component.bitConversion :
519
+ (q + 2056 / component.bitConversion) >> 4;
520
+ component.blockData[index] = q;
521
+ }
522
+ }
523
+
524
+ function buildComponentData(frame, component) {
525
+ var lines = [];
526
+ var blocksPerLine = component.blocksPerLine;
527
+ var blocksPerColumn = component.blocksPerColumn;
528
+ var samplesPerLine = blocksPerLine << 3;
529
+ var computationBuffer = new Int32Array(64);
530
+
531
+ var i, j, ll = 0;
532
+ for (var blockRow = 0; blockRow < blocksPerColumn; blockRow++) {
533
+ for (var blockCol = 0; blockCol < blocksPerLine; blockCol++) {
534
+ var offset = getBlockBufferOffset(component, blockRow, blockCol);
535
+ quantizeAndInverse(component, offset, computationBuffer);
536
+ }
537
+ }
538
+ return component.blockData;
539
+ }
540
+
541
+ function clampToUint8(a) {
542
+ return a <= 0 ? 0 : a >= 255 ? 255 : a | 0;
543
+ }
544
+
545
+ constructor.prototype = {
546
+ load: function load(path) {
547
+ var handleData = (function (data) {
548
+ this.parse(data);
549
+ if (this.onload)
550
+ this.onload();
551
+ }).bind(this);
552
+
553
+ if (path.indexOf("data:") > -1) {
554
+ var offset = path.indexOf("base64,") + 7;
555
+ var data = atob(path.substring(offset));
556
+ var arr = new Uint8Array(data.length);
557
+ for (var i = data.length - 1; i >= 0; i--) {
558
+ arr[i] = data.charCodeAt(i);
559
+ }
560
+ handleData(data);
561
+ } else {
562
+ var xhr = new XMLHttpRequest();
563
+ xhr.open("GET", path, true);
564
+ xhr.responseType = "arraybuffer";
565
+ xhr.onload = (function () {
566
+ // TODO catch parse error
567
+ var data = new Uint8Array(xhr.response);
568
+ handleData(data);
569
+ }).bind(this);
570
+ xhr.send(null);
571
+ }
572
+ },
573
+ parse: function parse(data) {
574
+
575
+ function readUint16() {
576
+ var value = (data[offset] << 8) | data[offset + 1];
577
+ offset += 2;
578
+ return value;
579
+ }
580
+
581
+ function readDataBlock() {
582
+ var length = readUint16();
583
+ var array = data.subarray(offset, offset + length - 2);
584
+ offset += array.length;
585
+ return array;
586
+ }
587
+
588
+ function prepareComponents(frame) {
589
+ var mcusPerLine = Math.ceil(frame.samplesPerLine / 8 / frame.maxH);
590
+ var mcusPerColumn = Math.ceil(frame.scanLines / 8 / frame.maxV);
591
+ for (var i = 0; i < frame.components.length; i++) {
592
+ component = frame.components[i];
593
+ var blocksPerLine = Math.ceil(Math.ceil(frame.samplesPerLine / 8) * component.h / frame.maxH);
594
+ var blocksPerColumn = Math.ceil(Math.ceil(frame.scanLines / 8) * component.v / frame.maxV);
595
+ var blocksPerLineForMcu = mcusPerLine * component.h;
596
+ var blocksPerColumnForMcu = mcusPerColumn * component.v;
597
+
598
+ var blocksBufferSize = 64 * blocksPerColumnForMcu * (blocksPerLineForMcu + 1);
599
+ component.blockData = new Int16Array(blocksBufferSize);
600
+ component.blocksPerLine = blocksPerLine;
601
+ component.blocksPerColumn = blocksPerColumn;
602
+ }
603
+ frame.mcusPerLine = mcusPerLine;
604
+ frame.mcusPerColumn = mcusPerColumn;
605
+ }
606
+
607
+ var offset = 0, length = data.length;
608
+ var jfif = null;
609
+ var adobe = null;
610
+ var pixels = null;
611
+ var frame, resetInterval;
612
+ var quantizationTables = [];
613
+ var huffmanTablesAC = [], huffmanTablesDC = [];
614
+ var fileMarker = readUint16();
615
+ if (fileMarker != 0xFFD8) { // SOI (Start of Image)
616
+ throw "SOI not found";
617
+ }
618
+
619
+ fileMarker = readUint16();
620
+ while (fileMarker != 0xFFD9) { // EOI (End of image)
621
+ var i, j, l;
622
+ switch (fileMarker) {
623
+ case 0xFFE0: // APP0 (Application Specific)
624
+ case 0xFFE1: // APP1
625
+ case 0xFFE2: // APP2
626
+ case 0xFFE3: // APP3
627
+ case 0xFFE4: // APP4
628
+ case 0xFFE5: // APP5
629
+ case 0xFFE6: // APP6
630
+ case 0xFFE7: // APP7
631
+ case 0xFFE8: // APP8
632
+ case 0xFFE9: // APP9
633
+ case 0xFFEA: // APP10
634
+ case 0xFFEB: // APP11
635
+ case 0xFFEC: // APP12
636
+ case 0xFFED: // APP13
637
+ case 0xFFEE: // APP14
638
+ case 0xFFEF: // APP15
639
+ case 0xFFFE: // COM (Comment)
640
+ var appData = readDataBlock();
641
+
642
+ if (fileMarker === 0xFFE0) {
643
+ if (appData[0] === 0x4A && appData[1] === 0x46 && appData[2] === 0x49 &&
644
+ appData[3] === 0x46 && appData[4] === 0) { // 'JFIF\x00'
645
+ jfif = {
646
+ version: {major: appData[5], minor: appData[6]},
647
+ densityUnits: appData[7],
648
+ xDensity: (appData[8] << 8) | appData[9],
649
+ yDensity: (appData[10] << 8) | appData[11],
650
+ thumbWidth: appData[12],
651
+ thumbHeight: appData[13],
652
+ thumbData: appData.subarray(14, 14 + 3 * appData[12] * appData[13])
653
+ };
654
+ }
655
+ }
656
+ // TODO APP1 - Exif
657
+ if (fileMarker === 0xFFEE) {
658
+ if (appData[0] === 0x41 && appData[1] === 0x64 && appData[2] === 0x6F &&
659
+ appData[3] === 0x62 && appData[4] === 0x65 && appData[5] === 0) { // 'Adobe\x00'
660
+ adobe = {
661
+ version: appData[6],
662
+ flags0: (appData[7] << 8) | appData[8],
663
+ flags1: (appData[9] << 8) | appData[10],
664
+ transformCode: appData[11]
665
+ };
666
+ }
667
+ }
668
+ break;
669
+
670
+ case 0xFFDB: // DQT (Define Quantization Tables)
671
+ var quantizationTablesLength = readUint16();
672
+ var quantizationTablesEnd = quantizationTablesLength + offset - 2;
673
+ while (offset < quantizationTablesEnd) {
674
+ var quantizationTableSpec = data[offset++];
675
+ var tableData = new Int32Array(64);
676
+ if ((quantizationTableSpec >> 4) === 0) { // 8 bit values
677
+ for (j = 0; j < 64; j++) {
678
+ var z = dctZigZag[j];
679
+ tableData[z] = data[offset++];
680
+ }
681
+ } else if ((quantizationTableSpec >> 4) === 1) { //16 bit
682
+ for (j = 0; j < 64; j++) {
683
+ var zz = dctZigZag[j];
684
+ tableData[zz] = readUint16();
685
+ }
686
+ } else
687
+ throw "DQT: invalid table spec";
688
+ quantizationTables[quantizationTableSpec & 15] = tableData;
689
+ }
690
+ break;
691
+
692
+ case 0xFFC0: // SOF0 (Start of Frame, Baseline DCT)
693
+ case 0xFFC1: // SOF1 (Start of Frame, Extended DCT)
694
+ case 0xFFC2: // SOF2 (Start of Frame, Progressive DCT)
695
+ if (frame) {
696
+ throw "Only single frame JPEGs supported";
697
+ }
698
+ readUint16(); // skip data length
699
+ frame = {};
700
+ frame.extended = (fileMarker === 0xFFC1);
701
+ frame.progressive = (fileMarker === 0xFFC2);
702
+ frame.precision = data[offset++];
703
+ frame.scanLines = readUint16();
704
+ frame.samplesPerLine = readUint16();
705
+ frame.components = [];
706
+ frame.componentIds = {};
707
+ var componentsCount = data[offset++], componentId;
708
+ var maxH = 0, maxV = 0;
709
+ for (i = 0; i < componentsCount; i++) {
710
+ componentId = data[offset];
711
+ var h = data[offset + 1] >> 4;
712
+ var v = data[offset + 1] & 15;
713
+ if (maxH < h)
714
+ maxH = h;
715
+ if (maxV < v)
716
+ maxV = v;
717
+ var qId = data[offset + 2];
718
+ l = frame.components.push({
719
+ h: h,
720
+ v: v,
721
+ quantizationTable: quantizationTables[qId],
722
+ quantizationTableId: qId,
723
+ bitConversion: 255 / ((1 << frame.precision) - 1)
724
+ });
725
+ frame.componentIds[componentId] = l - 1;
726
+ offset += 3;
727
+ }
728
+ frame.maxH = maxH;
729
+ frame.maxV = maxV;
730
+ prepareComponents(frame);
731
+ break;
732
+
733
+ case 0xFFC4: // DHT (Define Huffman Tables)
734
+ var huffmanLength = readUint16();
735
+ for (i = 2; i < huffmanLength; ) {
736
+ var huffmanTableSpec = data[offset++];
737
+ var codeLengths = new Uint8Array(16);
738
+ var codeLengthSum = 0;
739
+ for (j = 0; j < 16; j++, offset++)
740
+ codeLengthSum += (codeLengths[j] = data[offset]);
741
+ var huffmanValues = new Uint8Array(codeLengthSum);
742
+ for (j = 0; j < codeLengthSum; j++, offset++)
743
+ huffmanValues[j] = data[offset];
744
+ i += 17 + codeLengthSum;
745
+
746
+ ((huffmanTableSpec >> 4) === 0 ?
747
+ huffmanTablesDC : huffmanTablesAC)[huffmanTableSpec & 15] =
748
+ buildHuffmanTable(codeLengths, huffmanValues);
749
+ }
750
+ break;
751
+
752
+ case 0xFFDD: // DRI (Define Restart Interval)
753
+ readUint16(); // skip data length
754
+ resetInterval = readUint16();
755
+ break;
756
+
757
+ case 0xFFDA: // SOS (Start of Scan)
758
+ var scanLength = readUint16();
759
+ var selectorsCount = data[offset++];
760
+ var components = [], component;
761
+ for (i = 0; i < selectorsCount; i++) {
762
+ var componentIndex = frame.componentIds[data[offset++]];
763
+ component = frame.components[componentIndex];
764
+ var tableSpec = data[offset++];
765
+ component.huffmanTableDC = huffmanTablesDC[tableSpec >> 4];
766
+ component.huffmanTableAC = huffmanTablesAC[tableSpec & 15];
767
+ components.push(component);
768
+ }
769
+ var spectralStart = data[offset++];
770
+ var spectralEnd = data[offset++];
771
+ var successiveApproximation = data[offset++];
772
+ var processed = decodeScan(data, offset,
773
+ frame, components, resetInterval,
774
+ spectralStart, spectralEnd,
775
+ successiveApproximation >> 4, successiveApproximation & 15);
776
+ offset += processed;
777
+ break;
778
+ case 0xFFFF: // Fill bytes
779
+ if (data[offset] !== 0xFF) { // Avoid skipping a valid marker.
780
+ offset--;
781
+ }
782
+ break;
783
+ default:
784
+ if (data[offset - 3] == 0xFF &&
785
+ data[offset - 2] >= 0xC0 && data[offset - 2] <= 0xFE) {
786
+ // could be incorrect encoding -- last 0xFF byte of the previous
787
+ // block was eaten by the encoder
788
+ offset -= 3;
789
+ break;
790
+ }
791
+ throw "unknown JPEG marker " + fileMarker.toString(16);
792
+ }
793
+ fileMarker = readUint16();
794
+ }
795
+
796
+ this.width = frame.samplesPerLine;
797
+ this.height = frame.scanLines;
798
+ this.jfif = jfif;
799
+ this.adobe = adobe;
800
+ this.components = [];
801
+ switch (frame.components.length)
802
+ {
803
+ case 1:
804
+ this.colorspace = ColorSpace.Grayscale;
805
+ break;
806
+ case 3:
807
+ if (this.adobe)
808
+ this.colorspace = ColorSpace.AdobeRGB;
809
+ else
810
+ this.colorspace = ColorSpace.RGB;
811
+ break;
812
+ case 4:
813
+ this.colorspace = ColorSpace.CYMK;
814
+ break;
815
+ default:
816
+ this.colorspace = ColorSpace.Unknown;
817
+ }
818
+ for (var i = 0; i < frame.components.length; i++) {
819
+ var component = frame.components[i];
820
+ if (!component.quantizationTable && component.quantizationTableId !== null)
821
+ component.quantizationTable = quantizationTables[component.quantizationTableId];
822
+ this.components.push({
823
+ output: buildComponentData(frame, component),
824
+ scaleX: component.h / frame.maxH,
825
+ scaleY: component.v / frame.maxV,
826
+ blocksPerLine: component.blocksPerLine,
827
+ blocksPerColumn: component.blocksPerColumn,
828
+ bitConversion: component.bitConversion
829
+ });
830
+ }
831
+ },
832
+ getData16: function getData16(width, height) {
833
+ if (this.components.length !== 1)
834
+ throw 'Unsupported color mode';
835
+ var scaleX = this.width / width, scaleY = this.height / height;
836
+
837
+ var component, componentScaleX, componentScaleY;
838
+ var x, y, i;
839
+ var offset = 0;
840
+ var numComponents = this.components.length;
841
+ var dataLength = width * height * numComponents;
842
+ var data = new Uint16Array(dataLength);
843
+ var componentLine;
844
+
845
+ // lineData is reused for all components. Assume first component is
846
+ // the biggest
847
+ var lineData = new Uint16Array((this.components[0].blocksPerLine << 3) *
848
+ this.components[0].blocksPerColumn * 8);
849
+
850
+ // First construct image data ...
851
+ for (i = 0; i < numComponents; i++) {
852
+ component = this.components[i];
853
+ var blocksPerLine = component.blocksPerLine;
854
+ var blocksPerColumn = component.blocksPerColumn;
855
+ var samplesPerLine = blocksPerLine << 3;
856
+
857
+ var j, k, ll = 0;
858
+ var lineOffset = 0;
859
+ for (var blockRow = 0; blockRow < blocksPerColumn; blockRow++) {
860
+ var scanLine = blockRow << 3;
861
+ for (var blockCol = 0; blockCol < blocksPerLine; blockCol++) {
862
+ var bufferOffset = getBlockBufferOffset(component, blockRow, blockCol);
863
+ var offset = 0, sample = blockCol << 3;
864
+ for (j = 0; j < 8; j++) {
865
+ var lineOffset = (scanLine + j) * samplesPerLine;
866
+ for (k = 0; k < 8; k++) {
867
+ lineData[lineOffset + sample + k] =
868
+ component.output[bufferOffset + offset++];
869
+ }
870
+ }
871
+ }
872
+ }
873
+
874
+ componentScaleX = component.scaleX * scaleX;
875
+ componentScaleY = component.scaleY * scaleY;
876
+ offset = i;
877
+
878
+ var cx, cy;
879
+ var index;
880
+ for (y = 0; y < height; y++) {
881
+ for (x = 0; x < width; x++) {
882
+ cy = 0 | (y * componentScaleY);
883
+ cx = 0 | (x * componentScaleX);
884
+ index = cy * samplesPerLine + cx;
885
+ data[offset] = lineData[index];
886
+ offset += numComponents;
887
+ }
888
+ }
889
+ }
890
+ return data;
891
+ },
892
+ getData: function getData(width, height) {
893
+ var scaleX = this.width / width, scaleY = this.height / height;
894
+
895
+ var component, componentScaleX, componentScaleY;
896
+ var x, y, i;
897
+ var offset = 0;
898
+ var Y, Cb, Cr, K, C, M, Ye, R, G, B;
899
+ var colorTransform;
900
+ var numComponents = this.components.length;
901
+ var dataLength = width * height * numComponents;
902
+ var data = new Uint8Array(dataLength);
903
+ var componentLine;
904
+
905
+ // lineData is reused for all components. Assume first component is
906
+ // the biggest
907
+ var lineData = new Uint8Array((this.components[0].blocksPerLine << 3) *
908
+ this.components[0].blocksPerColumn * 8);
909
+
910
+ // First construct image data ...
911
+ for (i = 0; i < numComponents; i++) {
912
+ component = this.components[i];
913
+ var blocksPerLine = component.blocksPerLine;
914
+ var blocksPerColumn = component.blocksPerColumn;
915
+ var samplesPerLine = blocksPerLine << 3;
916
+
917
+ var j, k, ll = 0;
918
+ var lineOffset = 0;
919
+ for (var blockRow = 0; blockRow < blocksPerColumn; blockRow++) {
920
+ var scanLine = blockRow << 3;
921
+ for (var blockCol = 0; blockCol < blocksPerLine; blockCol++) {
922
+ var bufferOffset = getBlockBufferOffset(component, blockRow, blockCol);
923
+ var offset = 0, sample = blockCol << 3;
924
+ for (j = 0; j < 8; j++) {
925
+ var lineOffset = (scanLine + j) * samplesPerLine;
926
+ for (k = 0; k < 8; k++) {
927
+ lineData[lineOffset + sample + k] =
928
+ component.output[bufferOffset + offset++] * component.bitConversion;
929
+ }
930
+ }
931
+ }
932
+ }
933
+
934
+ componentScaleX = component.scaleX * scaleX;
935
+ componentScaleY = component.scaleY * scaleY;
936
+ offset = i;
937
+
938
+ var cx, cy;
939
+ var index;
940
+ for (y = 0; y < height; y++) {
941
+ for (x = 0; x < width; x++) {
942
+ cy = 0 | (y * componentScaleY);
943
+ cx = 0 | (x * componentScaleX);
944
+ index = cy * samplesPerLine + cx;
945
+ data[offset] = lineData[index];
946
+ offset += numComponents;
947
+ }
948
+ }
949
+ }
950
+
951
+ // ... then transform colors, if necessary
952
+ switch (numComponents) {
953
+ case 1:
954
+ case 2:
955
+ break;
956
+ // no color conversion for one or two compoenents
957
+
958
+ case 3:
959
+ // The default transform for three components is true
960
+ colorTransform = true;
961
+ // The adobe transform marker overrides any previous setting
962
+ if (this.adobe && this.adobe.transformCode)
963
+ colorTransform = true;
964
+ else if (typeof this.colorTransform !== 'undefined')
965
+ colorTransform = !!this.colorTransform;
966
+
967
+ if (colorTransform) {
968
+ for (i = 0; i < dataLength; i += numComponents) {
969
+ Y = data[i ];
970
+ Cb = data[i + 1];
971
+ Cr = data[i + 2];
972
+
973
+ R = clampToUint8(Y - 179.456 + 1.402 * Cr);
974
+ G = clampToUint8(Y + 135.459 - 0.344 * Cb - 0.714 * Cr);
975
+ B = clampToUint8(Y - 226.816 + 1.772 * Cb);
976
+
977
+ data[i ] = R;
978
+ data[i + 1] = G;
979
+ data[i + 2] = B;
980
+ }
981
+ }
982
+ break;
983
+ case 4:
984
+ if (!this.adobe)
985
+ throw 'Unsupported color mode (4 components)';
986
+ // The default transform for four components is false
987
+ colorTransform = false;
988
+ // The adobe transform marker overrides any previous setting
989
+ if (this.adobe && this.adobe.transformCode)
990
+ colorTransform = true;
991
+ else if (typeof this.colorTransform !== 'undefined')
992
+ colorTransform = !!this.colorTransform;
993
+
994
+ if (colorTransform) {
995
+ for (i = 0; i < dataLength; i += numComponents) {
996
+ Y = data[i];
997
+ Cb = data[i + 1];
998
+ Cr = data[i + 2];
999
+
1000
+ C = clampToUint8(434.456 - Y - 1.402 * Cr);
1001
+ M = clampToUint8(119.541 - Y + 0.344 * Cb + 0.714 * Cr);
1002
+ Y = clampToUint8(481.816 - Y - 1.772 * Cb);
1003
+
1004
+ data[i ] = C;
1005
+ data[i + 1] = M;
1006
+ data[i + 2] = Y;
1007
+ // K is unchanged
1008
+ }
1009
+ }
1010
+ break;
1011
+ default:
1012
+ throw 'Unsupported color mode';
1013
+ }
1014
+ return data;
1015
+ }
1016
+ };
1017
+
1018
+ return constructor;
1019
+ })();