x_ite 8.4.3 → 8.5.3

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 (568) hide show
  1. package/.vscode/settings.json +5 -1
  2. package/Makefile +0 -3
  3. package/build/bin/components.js +173 -0
  4. package/build/bin/tags.pl +28 -0
  5. package/build/bin/tests.pl +80 -2
  6. package/build/bin/version.pl +12 -7
  7. package/dist/assets/components/Annotation.js +13 -13
  8. package/dist/assets/components/Annotation.min.js +1 -1
  9. package/dist/assets/components/CADGeometry.js +13 -13
  10. package/dist/assets/components/CADGeometry.min.js +1 -1
  11. package/dist/assets/components/CubeMapTexturing.js +28 -29
  12. package/dist/assets/components/CubeMapTexturing.min.js +1 -1
  13. package/dist/assets/components/DIS.js +13 -13
  14. package/dist/assets/components/DIS.min.js +1 -1
  15. package/dist/assets/components/EventUtilities.js +9 -9
  16. package/dist/assets/components/EventUtilities.min.js +1 -1
  17. package/dist/assets/components/Geometry2D.js +19 -19
  18. package/dist/assets/components/Geometry2D.min.js +1 -1
  19. package/dist/assets/components/Geospatial.js +33 -33
  20. package/dist/assets/components/Geospatial.min.js +1 -1
  21. package/dist/assets/components/HAnim.js +63 -42
  22. package/dist/assets/components/HAnim.min.js +1 -1
  23. package/dist/assets/components/KeyDeviceSensor.js +8 -8
  24. package/dist/assets/components/KeyDeviceSensor.min.js +1 -1
  25. package/dist/assets/components/Layout.js +37 -29
  26. package/dist/assets/components/Layout.min.js +1 -1
  27. package/dist/assets/components/NURBS.js +29 -31
  28. package/dist/assets/components/NURBS.min.js +1 -1
  29. package/dist/assets/components/ParticleSystems.js +23 -23
  30. package/dist/assets/components/ParticleSystems.min.js +1 -1
  31. package/dist/assets/components/Picking.js +19 -19
  32. package/dist/assets/components/Picking.min.js +1 -1
  33. package/dist/assets/components/RigidBodyPhysics.js +24 -19
  34. package/dist/assets/components/RigidBodyPhysics.min.js +1 -1
  35. package/dist/assets/components/Scripting.js +30 -30
  36. package/dist/assets/components/Scripting.min.js +1 -1
  37. package/dist/assets/components/Text.js +172 -594
  38. package/dist/assets/components/Text.min.js +1 -1
  39. package/dist/assets/components/TextureProjector.js +31 -47
  40. package/dist/assets/components/TextureProjector.min.js +1 -1
  41. package/dist/assets/components/Texturing3D.js +367 -346
  42. package/dist/assets/components/Texturing3D.min.js +1 -1
  43. package/dist/assets/components/VolumeRendering.js +19 -19
  44. package/dist/assets/components/VolumeRendering.min.js +1 -1
  45. package/dist/assets/components/X_ITE.js +9 -9
  46. package/dist/assets/components/X_ITE.min.js +1 -1
  47. package/dist/x_ite.css +1 -1
  48. package/dist/x_ite.js +12174 -3553
  49. package/dist/x_ite.min.js +1 -1
  50. package/dist/x_ite.zip +0 -0
  51. package/docs/_config.yml +5 -136
  52. package/docs/_data/nav/components-CADGeometry.yml +14 -0
  53. package/docs/_data/nav/components-Core.yml +16 -0
  54. package/docs/_data/nav/components-CubeMapTexturing.yml +8 -0
  55. package/docs/_data/nav/components-DIS.yml +14 -0
  56. package/docs/_data/nav/components-EnvironmentalEffects.yml +12 -0
  57. package/docs/_data/nav/components-EnvironmentalSensor.yml +8 -0
  58. package/docs/_data/nav/components-EventUtilities.yml +16 -0
  59. package/docs/_data/nav/components-Followers.yml +30 -0
  60. package/docs/_data/nav/components-Geometry2D.yml +18 -0
  61. package/docs/_data/nav/components-Geometry3D.yml +16 -0
  62. package/docs/_data/nav/components-Geospatial.yml +24 -0
  63. package/docs/_data/nav/components-Grouping.yml +10 -0
  64. package/docs/_data/nav/components-HAnim.yml +14 -0
  65. package/docs/_data/nav/components-Interpolation.yml +28 -0
  66. package/docs/_data/nav/components-KeyDeviceSensor.yml +6 -0
  67. package/docs/_data/nav/components-Layering.yml +8 -0
  68. package/docs/_data/nav/components-Layout.yml +12 -0
  69. package/docs/_data/nav/components-Lighting.yml +10 -0
  70. package/docs/_data/nav/components-NURBS.yml +30 -0
  71. package/docs/_data/nav/components-Navigation.yml +16 -0
  72. package/docs/_data/nav/components-Networking.yml +8 -0
  73. package/docs/_data/nav/components-ParticleSystems.yml +22 -0
  74. package/docs/_data/nav/components-Picking.yml +12 -0
  75. package/docs/_data/nav/components-PointingDeviceSensor.yml +10 -0
  76. package/docs/_data/nav/components-Rendering.yml +30 -0
  77. package/docs/_data/nav/components-RigidBodyPhysics.yml +30 -0
  78. package/docs/_data/nav/components-Scripting.yml +4 -0
  79. package/docs/_data/nav/components-Shaders.yml +18 -0
  80. package/docs/_data/nav/components-Shape.yml +22 -0
  81. package/docs/_data/nav/components-Sound.yml +44 -0
  82. package/docs/_data/nav/components-Text.yml +6 -0
  83. package/docs/_data/nav/components-TextureProjector.yml +6 -0
  84. package/docs/_data/nav/components-Texturing.yml +22 -0
  85. package/docs/_data/nav/components-Texturing3D.yml +18 -0
  86. package/docs/_data/nav/components-Time.yml +4 -0
  87. package/docs/_data/nav/components-VolumeRendering.yml +28 -0
  88. package/docs/_data/nav/components-X_ITE.yml +4 -0
  89. package/docs/_data/nav/main.yml +26 -0
  90. package/docs/_data/nav/reference.yml +18 -0
  91. package/docs/_data/nav/tutorials-animation-sensors-and-geometry.yml +18 -0
  92. package/docs/_data/nav/tutorials-basic.yml +6 -0
  93. package/docs/_data/nav/tutorials-optimize-your-scene.yml +6 -0
  94. package/docs/_data/nav/tutorials-scripts-and-prototypes.yml +12 -0
  95. package/docs/_data/nav/tutorials-shapes-geometry-and-appearance.yml +16 -0
  96. package/docs/_data/nav/tutorials-textures-lights-and-environment.yml +20 -0
  97. package/docs/_includes/nav.html +2 -2
  98. package/docs/_includes/scripts.html +2 -1
  99. package/docs/_posts/accessing-the-external-browser.md +1 -1
  100. package/docs/_posts/browser-support.md +1 -1
  101. package/docs/_posts/components/CADGeometry/CADAssembly.md +83 -0
  102. package/docs/_posts/components/CADGeometry/CADFace.md +70 -0
  103. package/docs/_posts/components/CADGeometry/CADLayer.md +84 -0
  104. package/docs/_posts/components/CADGeometry/CADPart.md +117 -0
  105. package/docs/_posts/components/CADGeometry/IndexedQuadSet.md +125 -0
  106. package/docs/_posts/components/CADGeometry/QuadSet.md +113 -0
  107. package/docs/_posts/components/Core/MetadataBoolean.md +90 -0
  108. package/docs/_posts/components/Core/MetadataDouble.md +67 -0
  109. package/docs/_posts/components/Core/MetadataFloat.md +67 -0
  110. package/docs/_posts/components/Core/MetadataInteger.md +66 -0
  111. package/docs/_posts/components/Core/MetadataSet.md +63 -0
  112. package/docs/_posts/components/Core/MetadataString.md +66 -0
  113. package/docs/_posts/components/Core/WorldInfo.md +54 -0
  114. package/docs/_posts/components/CubeMapTexturing/ComposedCubeMapTexture.md +76 -0
  115. package/docs/_posts/components/CubeMapTexturing/GeneratedCubeMapTexture.md +65 -0
  116. package/docs/_posts/components/CubeMapTexturing/ImageCubeMapTexture.md +66 -0
  117. package/docs/_posts/components/DIS/DISEntityManager.md +73 -0
  118. package/docs/_posts/components/DIS/DISEntityTypeMapping.md +88 -0
  119. package/docs/_posts/components/DIS/EspduTransform.md +416 -0
  120. package/docs/_posts/components/DIS/ReceiverPdu.md +168 -0
  121. package/docs/_posts/components/DIS/SignalPdu.md +168 -0
  122. package/docs/_posts/components/DIS/TransmitterPdu.md +232 -0
  123. package/docs/_posts/components/EnvironmentalEffects/Background.md +189 -0
  124. package/docs/_posts/components/EnvironmentalEffects/Fog.md +97 -0
  125. package/docs/_posts/components/EnvironmentalEffects/FogCoordinate.md +40 -0
  126. package/docs/_posts/components/EnvironmentalEffects/LocalFog.md +84 -0
  127. package/docs/_posts/components/EnvironmentalEffects/TextureBackground.md +142 -0
  128. package/docs/_posts/components/EnvironmentalSensor/ProximitySensor.md +90 -0
  129. package/docs/_posts/components/EnvironmentalSensor/TransformSensor.md +91 -0
  130. package/docs/_posts/components/EnvironmentalSensor/VisibilitySensor.md +73 -0
  131. package/docs/_posts/components/EventUtilities/BooleanFilter.md +62 -0
  132. package/docs/_posts/components/EventUtilities/BooleanSequencer.md +86 -0
  133. package/docs/_posts/components/EventUtilities/BooleanToggle.md +46 -0
  134. package/docs/_posts/components/EventUtilities/BooleanTrigger.md +47 -0
  135. package/docs/_posts/components/EventUtilities/IntegerSequencer.md +90 -0
  136. package/docs/_posts/components/EventUtilities/IntegerTrigger.md +51 -0
  137. package/docs/_posts/components/EventUtilities/TimeTrigger.md +47 -0
  138. package/docs/_posts/components/Followers/ColorChaser.md +77 -0
  139. package/docs/_posts/components/Followers/ColorDamper.md +85 -0
  140. package/docs/_posts/components/Followers/CoordinateChaser.md +76 -0
  141. package/docs/_posts/components/Followers/CoordinateDamper.md +80 -0
  142. package/docs/_posts/components/Followers/OrientationChaser.md +72 -0
  143. package/docs/_posts/components/Followers/OrientationDamper.md +80 -0
  144. package/docs/_posts/components/Followers/PositionChaser.md +72 -0
  145. package/docs/_posts/components/Followers/PositionChaser2D.md +72 -0
  146. package/docs/_posts/components/Followers/PositionDamper.md +80 -0
  147. package/docs/_posts/components/Followers/PositionDamper2D.md +80 -0
  148. package/docs/_posts/components/Followers/ScalarChaser.md +76 -0
  149. package/docs/_posts/components/Followers/ScalarDamper.md +80 -0
  150. package/docs/_posts/components/Followers/TexCoordChaser2D.md +72 -0
  151. package/docs/_posts/components/Followers/TexCoordDamper2D.md +80 -0
  152. package/docs/_posts/components/Geometry2D/Arc2D.md +71 -0
  153. package/docs/_posts/components/Geometry2D/ArcClose2D.md +91 -0
  154. package/docs/_posts/components/Geometry2D/Circle2D.md +55 -0
  155. package/docs/_posts/components/Geometry2D/Disk2D.md +75 -0
  156. package/docs/_posts/components/Geometry2D/Polyline2D.md +54 -0
  157. package/docs/_posts/components/Geometry2D/Polypoint2D.md +54 -0
  158. package/docs/_posts/components/Geometry2D/Rectangle2D.md +66 -0
  159. package/docs/_posts/components/Geometry2D/TriangleSet2D.md +66 -0
  160. package/docs/_posts/components/Geometry3D/Box.md +66 -0
  161. package/docs/_posts/components/Geometry3D/Cone.md +90 -0
  162. package/docs/_posts/components/Geometry3D/Cylinder.md +98 -0
  163. package/docs/_posts/components/Geometry3D/ElevationGrid.md +162 -0
  164. package/docs/_posts/components/Geometry3D/Extrusion.md +170 -0
  165. package/docs/_posts/components/Geometry3D/IndexedFaceSet.md +208 -0
  166. package/docs/_posts/components/Geometry3D/Sphere.md +66 -0
  167. package/docs/_posts/components/Geospatial/GeoCoordinate.md +65 -0
  168. package/docs/_posts/components/Geospatial/GeoElevationGrid.md +180 -0
  169. package/docs/_posts/components/Geospatial/GeoLOD.md +128 -0
  170. package/docs/_posts/components/Geospatial/GeoLocation.md +93 -0
  171. package/docs/_posts/components/Geospatial/GeoMetadata.md +75 -0
  172. package/docs/_posts/components/Geospatial/GeoOrigin.md +69 -0
  173. package/docs/_posts/components/Geospatial/GeoPositionInterpolator.md +95 -0
  174. package/docs/_posts/components/Geospatial/GeoProximitySensor.md +109 -0
  175. package/docs/_posts/components/Geospatial/GeoTouchSensor.md +108 -0
  176. package/docs/_posts/components/Geospatial/GeoTransform.md +121 -0
  177. package/docs/_posts/components/Geospatial/GeoViewpoint.md +126 -0
  178. package/docs/_posts/components/Grouping/Group.md +75 -0
  179. package/docs/_posts/components/Grouping/StaticGroup.md +65 -0
  180. package/docs/_posts/components/Grouping/Switch.md +89 -0
  181. package/docs/_posts/components/Grouping/Transform.md +126 -0
  182. package/docs/_posts/components/HAnim/HAnimDisplacer.md +89 -0
  183. package/docs/_posts/components/HAnim/HAnimHumanoid.md +136 -0
  184. package/docs/_posts/components/HAnim/HAnimJoint.md +165 -0
  185. package/docs/_posts/components/HAnim/HAnimMotion.md +68 -0
  186. package/docs/_posts/components/HAnim/HAnimSegment.md +107 -0
  187. package/docs/_posts/components/HAnim/HAnimSite.md +108 -0
  188. package/docs/_posts/components/Interpolation/ColorInterpolator.md +73 -0
  189. package/docs/_posts/components/Interpolation/CoordinateInterpolator.md +76 -0
  190. package/docs/_posts/components/Interpolation/CoordinateInterpolator2D.md +73 -0
  191. package/docs/_posts/components/Interpolation/EaseInEaseOut.md +67 -0
  192. package/docs/_posts/components/Interpolation/NormalInterpolator.md +68 -0
  193. package/docs/_posts/components/Interpolation/OrientationInterpolator.md +72 -0
  194. package/docs/_posts/components/Interpolation/PositionInterpolator.md +72 -0
  195. package/docs/_posts/components/Interpolation/PositionInterpolator2D.md +77 -0
  196. package/docs/_posts/components/Interpolation/ScalarInterpolator.md +76 -0
  197. package/docs/_posts/components/Interpolation/SplinePositionInterpolator.md +93 -0
  198. package/docs/_posts/components/Interpolation/SplinePositionInterpolator2D.md +93 -0
  199. package/docs/_posts/components/Interpolation/SplineScalarInterpolator.md +106 -0
  200. package/docs/_posts/components/Interpolation/SquadOrientationInterpolator.md +78 -0
  201. package/docs/_posts/components/KeyDeviceSensor/KeySensor.md +78 -0
  202. package/docs/_posts/components/KeyDeviceSensor/StringSensor.md +70 -0
  203. package/docs/_posts/components/Layering/Layer.md +67 -0
  204. package/docs/_posts/components/Layering/LayerSet.md +78 -0
  205. package/docs/_posts/components/Layering/Viewport.md +80 -0
  206. package/docs/_posts/components/Layout/Layout.md +107 -0
  207. package/docs/_posts/components/Layout/LayoutGroup.md +85 -0
  208. package/docs/_posts/components/Layout/LayoutLayer.md +74 -0
  209. package/docs/_posts/components/Layout/ScreenFontStyle.md +137 -0
  210. package/docs/_posts/components/Layout/ScreenGroup.md +71 -0
  211. package/docs/_posts/components/Lighting/DirectionalLight.md +100 -0
  212. package/docs/_posts/components/Lighting/EnvironmentLight.md +91 -0
  213. package/docs/_posts/components/Lighting/PointLight.md +103 -0
  214. package/docs/_posts/components/Lighting/SpotLight.md +132 -0
  215. package/docs/_posts/components/NURBS/Contour2D.md +57 -0
  216. package/docs/_posts/components/NURBS/ContourPolyline2D.md +46 -0
  217. package/docs/_posts/components/NURBS/CoordinateDouble.md +47 -0
  218. package/docs/_posts/components/NURBS/NurbsCurve.md +71 -0
  219. package/docs/_posts/components/NURBS/NurbsCurve2D.md +66 -0
  220. package/docs/_posts/components/NURBS/NurbsOrientationInterpolator.md +70 -0
  221. package/docs/_posts/components/NURBS/NurbsPatchSurface.md +106 -0
  222. package/docs/_posts/components/NURBS/NurbsPositionInterpolator.md +70 -0
  223. package/docs/_posts/components/NURBS/NurbsSet.md +66 -0
  224. package/docs/_posts/components/NURBS/NurbsSurfaceInterpolator.md +90 -0
  225. package/docs/_posts/components/NURBS/NurbsSweptSurface.md +69 -0
  226. package/docs/_posts/components/NURBS/NurbsSwungSurface.md +65 -0
  227. package/docs/_posts/components/NURBS/NurbsTextureCoordinate.md +77 -0
  228. package/docs/_posts/components/NURBS/NurbsTrimmedSurface.md +114 -0
  229. package/docs/_posts/components/Navigation/Billboard.md +88 -0
  230. package/docs/_posts/components/Navigation/Collision.md +102 -0
  231. package/docs/_posts/components/Navigation/LOD.md +99 -0
  232. package/docs/_posts/components/Navigation/NavigationInfo.md +122 -0
  233. package/docs/_posts/components/Navigation/OrthoViewpoint.md +117 -0
  234. package/docs/_posts/components/Navigation/Viewpoint.md +117 -0
  235. package/docs/_posts/components/Navigation/ViewpointGroup.md +80 -0
  236. package/docs/_posts/components/Networking/Anchor.md +111 -0
  237. package/docs/_posts/components/Networking/Inline.md +115 -0
  238. package/docs/_posts/components/Networking/LoadSensor.md +91 -0
  239. package/docs/_posts/components/ParticleSystems/BoundedPhysicsModel.md +54 -0
  240. package/docs/_posts/components/ParticleSystems/ConeEmitter.md +76 -0
  241. package/docs/_posts/components/ParticleSystems/ExplosionEmitter.md +72 -0
  242. package/docs/_posts/components/ParticleSystems/ForcePhysicsModel.md +58 -0
  243. package/docs/_posts/components/ParticleSystems/ParticleSystem.md +177 -0
  244. package/docs/_posts/components/ParticleSystems/PointEmitter.md +76 -0
  245. package/docs/_posts/components/ParticleSystems/PolylineEmitter.md +94 -0
  246. package/docs/_posts/components/ParticleSystems/SurfaceEmitter.md +90 -0
  247. package/docs/_posts/components/ParticleSystems/VolumeEmitter.md +90 -0
  248. package/docs/_posts/components/ParticleSystems/WindPhysicsModel.md +68 -0
  249. package/docs/_posts/components/Picking/LinePickSensor.md +125 -0
  250. package/docs/_posts/components/Picking/PickableGroup.md +93 -0
  251. package/docs/_posts/components/Picking/PointPickSensor.md +112 -0
  252. package/docs/_posts/components/Picking/PrimitivePickSensor.md +114 -0
  253. package/docs/_posts/components/Picking/VolumePickSensor.md +107 -0
  254. package/docs/_posts/components/PointingDeviceSensor/CylinderSensor.md +122 -0
  255. package/docs/_posts/components/PointingDeviceSensor/PlaneSensor.md +114 -0
  256. package/docs/_posts/components/PointingDeviceSensor/SphereSensor.md +89 -0
  257. package/docs/_posts/components/PointingDeviceSensor/TouchSensor.md +87 -0
  258. package/docs/_posts/components/Rendering/ClipPlane.md +67 -0
  259. package/docs/_posts/components/Rendering/Color.md +56 -0
  260. package/docs/_posts/components/Rendering/ColorRGBA.md +61 -0
  261. package/docs/_posts/components/Rendering/Coordinate.md +45 -0
  262. package/docs/_posts/components/Rendering/IndexedLineSet.md +128 -0
  263. package/docs/_posts/components/Rendering/IndexedTriangleFanSet.md +128 -0
  264. package/docs/_posts/components/Rendering/IndexedTriangleSet.md +128 -0
  265. package/docs/_posts/components/Rendering/IndexedTriangleStripSet.md +116 -0
  266. package/docs/_posts/components/Rendering/LineSet.md +85 -0
  267. package/docs/_posts/components/Rendering/Normal.md +41 -0
  268. package/docs/_posts/components/Rendering/PointSet.md +76 -0
  269. package/docs/_posts/components/Rendering/TriangleFanSet.md +112 -0
  270. package/docs/_posts/components/Rendering/TriangleSet.md +108 -0
  271. package/docs/_posts/components/Rendering/TriangleStripSet.md +116 -0
  272. package/docs/_posts/components/RigidBodyPhysics/BallJoint.md +78 -0
  273. package/docs/_posts/components/RigidBodyPhysics/CollidableOffset.md +75 -0
  274. package/docs/_posts/components/RigidBodyPhysics/CollidableShape.md +83 -0
  275. package/docs/_posts/components/RigidBodyPhysics/CollisionCollection.md +90 -0
  276. package/docs/_posts/components/RigidBodyPhysics/CollisionSensor.md +65 -0
  277. package/docs/_posts/components/RigidBodyPhysics/CollisionSpace.md +70 -0
  278. package/docs/_posts/components/RigidBodyPhysics/Contact.md +117 -0
  279. package/docs/_posts/components/RigidBodyPhysics/DoubleAxisHingeJoint.md +162 -0
  280. package/docs/_posts/components/RigidBodyPhysics/MotorJoint.md +183 -0
  281. package/docs/_posts/components/RigidBodyPhysics/RigidBody.md +175 -0
  282. package/docs/_posts/components/RigidBodyPhysics/RigidBodyCollection.md +120 -0
  283. package/docs/_posts/components/RigidBodyPhysics/SingleAxisHingeJoint.md +108 -0
  284. package/docs/_posts/components/RigidBodyPhysics/SliderJoint.md +106 -0
  285. package/docs/_posts/components/RigidBodyPhysics/UniversalJoint.md +119 -0
  286. package/docs/_posts/components/Scripting/Script.md +81 -0
  287. package/docs/_posts/components/Shaders/ComposedShader.md +81 -0
  288. package/docs/_posts/components/Shaders/FloatVertexAttribute.md +65 -0
  289. package/docs/_posts/components/Shaders/Matrix3VertexAttribute.md +53 -0
  290. package/docs/_posts/components/Shaders/Matrix4VertexAttribute.md +53 -0
  291. package/docs/_posts/components/Shaders/PackagedShader.md +77 -0
  292. package/docs/_posts/components/Shaders/ProgramShader.md +71 -0
  293. package/docs/_posts/components/Shaders/ShaderPart.md +76 -0
  294. package/docs/_posts/components/Shaders/ShaderProgram.md +68 -0
  295. package/docs/_posts/components/Shape/AcousticProperties.md +52 -0
  296. package/docs/_posts/components/Shape/Appearance.md +123 -0
  297. package/docs/_posts/components/Shape/FillProperties.md +67 -0
  298. package/docs/_posts/components/Shape/LineProperties.md +63 -0
  299. package/docs/_posts/components/Shape/Material.md +217 -0
  300. package/docs/_posts/components/Shape/PhysicalMaterial.md +173 -0
  301. package/docs/_posts/components/Shape/PointProperties.md +84 -0
  302. package/docs/_posts/components/Shape/Shape.md +63 -0
  303. package/docs/_posts/components/Shape/TwoSidedMaterial.md +149 -0
  304. package/docs/_posts/components/Shape/UnlitMaterial.md +115 -0
  305. package/docs/_posts/components/Sound/Analyser.md +72 -0
  306. package/docs/_posts/components/Sound/AudioClip.md +139 -0
  307. package/docs/_posts/components/Sound/AudioDestination.md +52 -0
  308. package/docs/_posts/components/Sound/BiquadFilter.md +70 -0
  309. package/docs/_posts/components/Sound/BufferAudioSource.md +86 -0
  310. package/docs/_posts/components/Sound/ChannelMerger.md +46 -0
  311. package/docs/_posts/components/Sound/ChannelSelector.md +48 -0
  312. package/docs/_posts/components/Sound/ChannelSplitter.md +48 -0
  313. package/docs/_posts/components/Sound/Convolver.md +66 -0
  314. package/docs/_posts/components/Sound/Delay.md +66 -0
  315. package/docs/_posts/components/Sound/DynamicsCompressor.md +74 -0
  316. package/docs/_posts/components/Sound/Gain.md +62 -0
  317. package/docs/_posts/components/Sound/ListenerPointSource.md +62 -0
  318. package/docs/_posts/components/Sound/MicrophoneSource.md +54 -0
  319. package/docs/_posts/components/Sound/OscillatorSource.md +58 -0
  320. package/docs/_posts/components/Sound/PeriodicWave.md +42 -0
  321. package/docs/_posts/components/Sound/Sound.md +92 -0
  322. package/docs/_posts/components/Sound/SpatialSound.md +68 -0
  323. package/docs/_posts/components/Sound/StreamAudioDestination.md +52 -0
  324. package/docs/_posts/components/Sound/StreamAudioSource.md +54 -0
  325. package/docs/_posts/components/Sound/WaveShaper.md +66 -0
  326. package/docs/_posts/components/Text/FontStyle.md +145 -0
  327. package/docs/_posts/components/Text/Text.md +102 -0
  328. package/docs/_posts/components/TextureProjector/TextureProjector.md +52 -0
  329. package/docs/_posts/components/TextureProjector/TextureProjectorParallel.md +52 -0
  330. package/docs/_posts/components/Texturing/ImageTexture.md +134 -0
  331. package/docs/_posts/components/Texturing/MovieTexture.md +221 -0
  332. package/docs/_posts/components/Texturing/MultiTexture.md +100 -0
  333. package/docs/_posts/components/Texturing/MultiTextureCoordinate.md +47 -0
  334. package/docs/_posts/components/Texturing/MultiTextureTransform.md +47 -0
  335. package/docs/_posts/components/Texturing/PixelTexture.md +80 -0
  336. package/docs/_posts/components/Texturing/TextureCoordinate.md +52 -0
  337. package/docs/_posts/components/Texturing/TextureCoordinateGenerator.md +64 -0
  338. package/docs/_posts/components/Texturing/TextureProperties.md +137 -0
  339. package/docs/_posts/components/Texturing/TextureTransform.md +73 -0
  340. package/docs/_posts/components/Texturing3D/ComposedTexture3D.md +76 -0
  341. package/docs/_posts/components/Texturing3D/ImageTexture3D.md +132 -0
  342. package/docs/_posts/components/Texturing3D/ImageTextureAtlas.md +131 -0
  343. package/docs/_posts/components/Texturing3D/PixelTexture3D.md +75 -0
  344. package/docs/_posts/components/Texturing3D/TextureCoordinate3D.md +53 -0
  345. package/docs/_posts/components/Texturing3D/TextureCoordinate4D.md +52 -0
  346. package/docs/_posts/components/Texturing3D/TextureTransform3D.md +69 -0
  347. package/docs/_posts/components/Texturing3D/TextureTransformMatrix3D.md +57 -0
  348. package/docs/_posts/components/Time/TimeSensor.md +136 -0
  349. package/docs/_posts/components/VolumeRendering/BlendedVolumeStyle.md +92 -0
  350. package/docs/_posts/components/VolumeRendering/BoundaryEnhancementVolumeStyle.md +53 -0
  351. package/docs/_posts/components/VolumeRendering/CartoonVolumeStyle.md +83 -0
  352. package/docs/_posts/components/VolumeRendering/ComposedVolumeStyle.md +51 -0
  353. package/docs/_posts/components/VolumeRendering/EdgeEnhancementVolumeStyle.md +67 -0
  354. package/docs/_posts/components/VolumeRendering/IsoSurfaceVolumeData.md +99 -0
  355. package/docs/_posts/components/VolumeRendering/OpacityMapVolumeStyle.md +51 -0
  356. package/docs/_posts/components/VolumeRendering/ProjectionVolumeStyle.md +48 -0
  357. package/docs/_posts/components/VolumeRendering/SegmentedVolumeData.md +80 -0
  358. package/docs/_posts/components/VolumeRendering/ShadedVolumeStyle.md +75 -0
  359. package/docs/_posts/components/VolumeRendering/SilhouetteEnhancementVolumeStyle.md +63 -0
  360. package/docs/_posts/components/VolumeRendering/ToneMappedVolumeStyle.md +71 -0
  361. package/docs/_posts/components/VolumeRendering/VolumeData.md +71 -0
  362. package/docs/_posts/components/X_ITE/BlendMode.md +94 -0
  363. package/docs/_posts/custom-shaders.md +9 -4
  364. package/docs/_posts/dom-integration.md +1 -6
  365. package/docs/_posts/features.md +2 -2
  366. package/docs/_posts/getting-started.md +100 -57
  367. package/docs/_posts/glossary.md +1 -1
  368. package/docs/_posts/how-to-configure-your-web-server.md +1 -1
  369. package/docs/_posts/reference/browser-services.md +78 -18
  370. package/docs/_posts/reference/constants-services.md +1 -1
  371. package/docs/_posts/reference/ecmascript-object-and-function-definitions.md +1 -1
  372. package/docs/_posts/reference/field-services-and-objects.md +8 -8
  373. package/docs/_posts/reference/prototype-services.md +7 -7
  374. package/docs/_posts/reference/route-services.md +1 -1
  375. package/docs/_posts/reference/scene-services.md +5 -5
  376. package/docs/_posts/reference/script-node-authoring-interface.md +1 -1
  377. package/docs/_posts/report-a-bug.md +1 -1
  378. package/docs/_posts/setup-a-localhost-server.md +5 -1
  379. package/docs/_posts/supported-nodes.md +239 -238
  380. package/docs/_posts/tutorials/adding-backgrounds.md +3 -3
  381. package/docs/_posts/tutorials/adding-fog.md +2 -2
  382. package/docs/_posts/tutorials/adding-sound.md +19 -19
  383. package/docs/_posts/tutorials/animating-transforms.md +17 -17
  384. package/docs/_posts/tutorials/basic-nodes.md +30 -30
  385. package/docs/_posts/tutorials/building-a-x3d-world.md +3 -3
  386. package/docs/_posts/tutorials/building-elevation-grids.md +7 -7
  387. package/docs/_posts/tutorials/building-extruded-shapes.md +7 -7
  388. package/docs/_posts/tutorials/building-primitive-shapes.md +13 -13
  389. package/docs/_posts/tutorials/building-shapes-out-of-points-lines-and-faces.md +21 -21
  390. package/docs/_posts/tutorials/controlling-appearance-with-materials.md +7 -7
  391. package/docs/_posts/tutorials/controlling-color-on-coordinate-based-geometry.md +11 -11
  392. package/docs/_posts/tutorials/controlling-detail.md +4 -4
  393. package/docs/_posts/tutorials/controlling-how-textures-are-mapped.md +7 -7
  394. package/docs/_posts/tutorials/controlling-navigation.md +3 -3
  395. package/docs/_posts/tutorials/controlling-shading-on-coordinate-based-geometry.md +13 -13
  396. package/docs/_posts/tutorials/controlling-the-viewpoint.md +3 -3
  397. package/docs/_posts/tutorials/creating-new-node-types.md +4 -4
  398. package/docs/_posts/tutorials/grouping-nodes.md +13 -13
  399. package/docs/_posts/tutorials/hello-world.md +1 -1
  400. package/docs/_posts/tutorials/improving-performance.md +1 -1
  401. package/docs/_posts/tutorials/increasing-rendering-speed.md +1 -1
  402. package/docs/_posts/tutorials/introducing-animation.md +10 -10
  403. package/docs/_posts/tutorials/introducing-script-use.md +3 -3
  404. package/docs/_posts/tutorials/introducing-x3d.md +1 -1
  405. package/docs/_posts/tutorials/lighting-your-world.md +4 -4
  406. package/docs/_posts/tutorials/mapping-textures.md +7 -7
  407. package/docs/_posts/tutorials/naming-nodes.md +1 -1
  408. package/docs/_posts/tutorials/overview.md +1 -1
  409. package/docs/_posts/tutorials/providing-information-about-your-world.md +2 -2
  410. package/docs/_posts/tutorials/sensing-the-viewer.md +15 -15
  411. package/docs/_posts/tutorials/sensing-viewer-actions.md +10 -10
  412. package/docs/_posts/tutorials/transforming-shapes.md +4 -4
  413. package/docs/_posts/tutorials/writing-program-scripts-with-ecmascript.md +5 -5
  414. package/docs/_posts/what's-new.md +40 -2
  415. package/docs/_tabs/components.md +383 -0
  416. package/docs/_tabs/imprint.md +1 -1
  417. package/docs/_tabs/laboratory.md +38 -6
  418. package/docs/_tabs/playground.html +22 -66
  419. package/docs/_tabs/reference.md +2 -1
  420. package/docs/_tabs/tags.md +1 -1
  421. package/docs/_tabs/tutorials.md +1 -1
  422. package/docs/assets/X3D/Michroma-Regular.ttf +0 -0
  423. package/docs/assets/X3D/peakpx.jpg +0 -0
  424. package/docs/assets/X3D/teaser.x3d +55 -0
  425. package/docs/assets/css/style.scss +120 -11
  426. package/docs/assets/img/laboratory/blend-mode.png +0 -0
  427. package/docs/assets/img/laboratory/dicom-nrrd.png +0 -0
  428. package/docs/assets/img/laboratory/earthquake.png +0 -0
  429. package/docs/assets/img/laboratory/gltf.png +0 -0
  430. package/docs/assets/img/laboratory/l-system.png +0 -0
  431. package/docs/assets/js/autoupdate.js +25 -0
  432. package/docs/laboratory/gltf-sample-viewer.html +318 -0
  433. package/docs/laboratory/x3d-visual-blend-mode-editor.html +1 -0
  434. package/package.json +9 -2
  435. package/src/assets/components/Texturing3D.js +5 -3
  436. package/src/assets/shaders/Types.glsl.js +5 -5
  437. package/src/assets/shaders/webgl1/PBR.fs.js +1 -1
  438. package/src/assets/shaders/webgl1/include/Colors.glsl.js +5 -7
  439. package/src/assets/shaders/webgl1/include/Fragment.glsl.js +4 -0
  440. package/src/assets/shaders/webgl1/include/Hatch.glsl.js +1 -1
  441. package/src/assets/shaders/webgl1/include/Texture.glsl.js +3 -3
  442. package/src/assets/shaders/webgl2/include/Colors.glsl.js +5 -7
  443. package/src/assets/shaders/webgl2/include/Hatch.glsl.js +1 -1
  444. package/src/assets/shaders/webgl2/include/Particle.glsl.js +2 -2
  445. package/src/assets/shaders/webgl2/include/Texture.glsl.js +2 -2
  446. package/src/bookmarks.js +12 -8
  447. package/src/examples.js +3 -0
  448. package/src/lib/jquery.js +20 -0
  449. package/src/lib/libgif/libgif.js +1004 -0
  450. package/src/lib/libtess.js +1 -0
  451. package/src/lib/nurbs/extras/sample.js +5 -7
  452. package/src/standard/Math/Algorithms/Bezier.js +175 -33
  453. package/src/standard/Math/Geometry/Box2.js +15 -55
  454. package/src/standard/Math/Geometry/Box3.js +19 -66
  455. package/src/standard/Math/Geometry/Triangle3.js +14 -79
  456. package/src/standard/Math/Numbers/Color3.js +4 -0
  457. package/src/standard/Math/Numbers/Color4.js +4 -0
  458. package/src/standard/Math/Numbers/Matrix3.js +11 -3
  459. package/src/standard/Math/Numbers/Matrix4.js +9 -6
  460. package/src/standard/Math/Numbers/Rotation4.js +72 -65
  461. package/src/tests.js +3 -0
  462. package/src/x_ite/Base/X3DArrayField.js +0 -2
  463. package/src/x_ite/Base/X3DInfoArray.js +2 -2
  464. package/src/x_ite/Base/X3DObjectArrayField.js +19 -0
  465. package/src/x_ite/Base/X3DTypedArrayField.js +149 -0
  466. package/src/x_ite/Browser/Core/BrowserOptions.js +108 -64
  467. package/src/x_ite/Browser/Core/Context.js +1 -1
  468. package/src/x_ite/Browser/Core/ContextMenu.js +2 -2
  469. package/src/x_ite/Browser/Core/Notification.js +1 -1
  470. package/src/x_ite/Browser/Core/RenderingProperties.js +4 -0
  471. package/src/x_ite/Browser/Core/X3DCoreContext.js +99 -54
  472. package/src/x_ite/Browser/Navigation/ExamineViewer.js +4 -14
  473. package/src/x_ite/Browser/Navigation/LookAtViewer.js +3 -13
  474. package/src/x_ite/Browser/Navigation/PlaneViewer.js +3 -12
  475. package/src/x_ite/Browser/Navigation/X3DFlyViewer.js +25 -22
  476. package/src/x_ite/Browser/Navigation/X3DViewer.js +12 -3
  477. package/src/x_ite/Browser/Networking/X3DNetworkingContext.js +2 -2
  478. package/src/x_ite/Browser/PointingDeviceSensor/PointingDevice.js +19 -15
  479. package/src/x_ite/Browser/Rendering/X3DRenderingContext.js +30 -10
  480. package/src/x_ite/Browser/Shaders/X3DShadersContext.js +1 -1
  481. package/src/x_ite/Browser/Shape/X3DShapeContext.js +30 -3
  482. package/src/x_ite/Browser/Text/PolygonText.js +137 -134
  483. package/src/x_ite/Browser/Texturing/GifMedia.js +113 -0
  484. package/src/x_ite/Browser/Texturing3D/DICOMParser.js +1 -6
  485. package/src/x_ite/Browser/Texturing3D/NRRDParser.js +81 -310
  486. package/src/x_ite/Browser/VERSION.js +1 -1
  487. package/src/x_ite/Browser/X3DBrowser.js +162 -122
  488. package/src/x_ite/Browser/X3DBrowserContext.js +7 -5
  489. package/src/x_ite/Components/Core/WorldInfo.js +3 -3
  490. package/src/x_ite/Components/Core/X3DNode.js +7 -7
  491. package/src/x_ite/Components/Core/X3DPrototypeInstance.js +1 -1
  492. package/src/x_ite/Components/CubeMapTexturing/ImageCubeMapTexture.js +2 -3
  493. package/src/x_ite/Components/Geometry3D/Extrusion.js +27 -23
  494. package/src/x_ite/Components/Geometry3D/IndexedFaceSet.js +10 -19
  495. package/src/x_ite/Components/Grouping/X3DBoundedObject.js +1 -3
  496. package/src/x_ite/Components/HAnim/HAnimHumanoid.js +39 -15
  497. package/src/x_ite/Components/HAnim/HAnimJoint.js +6 -9
  498. package/src/x_ite/Components/Layering/X3DLayerNode.js +21 -2
  499. package/src/x_ite/Components/Layout/Layout.js +4 -2
  500. package/src/x_ite/Components/Layout/ScreenFontStyle.js +6 -0
  501. package/src/x_ite/Components/Lighting/DirectionalLight.js +4 -11
  502. package/src/x_ite/Components/Lighting/EnvironmentLight.js +1 -1
  503. package/src/x_ite/Components/Lighting/PointLight.js +4 -11
  504. package/src/x_ite/Components/Lighting/SpotLight.js +4 -11
  505. package/src/x_ite/Components/Lighting/X3DLightNode.js +7 -9
  506. package/src/x_ite/Components/Navigation/OrthoViewpoint.js +2 -2
  507. package/src/x_ite/Components/Navigation/X3DViewpointNode.js +14 -6
  508. package/src/x_ite/Components/Networking/Inline.js +48 -59
  509. package/src/x_ite/Components/Networking/X3DUrlObject.js +1 -1
  510. package/src/x_ite/Components/PointingDeviceSensor/CylinderSensor.js +2 -2
  511. package/src/x_ite/Components/Rendering/X3DLineGeometryNode.js +7 -13
  512. package/src/x_ite/Components/Rendering/X3DPointGeometryNode.js +4 -2
  513. package/src/x_ite/Components/RigidBodyPhysics/RigidBody.js +4 -2
  514. package/src/x_ite/Components/Scripting/Script.js +2 -2
  515. package/src/x_ite/Components/Shaders/ShaderPart.js +1 -1
  516. package/src/x_ite/Components/Shaders/X3DProgrammableShaderObject.js +1 -3
  517. package/src/x_ite/Components/Shape/Appearance.js +27 -1
  518. package/src/x_ite/Components/Shape/FillProperties.js +1 -0
  519. package/src/x_ite/Components/Shape/LineProperties.js +15 -9
  520. package/src/x_ite/Components/Shape/Material.js +33 -22
  521. package/src/x_ite/Components/Shape/PhysicalMaterial.js +22 -15
  522. package/src/x_ite/Components/Shape/PointProperties.js +23 -7
  523. package/src/x_ite/Components/Shape/UnlitMaterial.js +3 -2
  524. package/src/x_ite/Components/Shape/X3DOneSidedMaterialNode.js +25 -19
  525. package/src/x_ite/Components/Sound/AudioClip.js +5 -5
  526. package/src/x_ite/Components/Sound/X3DSoundSourceNode.js +26 -34
  527. package/src/x_ite/Components/Text/X3DFontStyleNode.js +1 -1
  528. package/src/x_ite/Components/TextureProjector/TextureProjector.js +4 -12
  529. package/src/x_ite/Components/TextureProjector/TextureProjectorParallel.js +6 -14
  530. package/src/x_ite/Components/TextureProjector/X3DTextureProjectorNode.js +7 -7
  531. package/src/x_ite/Components/Texturing/ImageTexture.js +15 -10
  532. package/src/x_ite/Components/Texturing/MovieTexture.js +51 -11
  533. package/src/x_ite/Components/Texturing3D/ImageTexture3D.js +2 -2
  534. package/src/x_ite/Components/Texturing3D/ImageTextureAtlas.js +230 -0
  535. package/src/x_ite/Components/Time/X3DTimeDependentNode.js +12 -10
  536. package/src/x_ite/Execution/BindableList.js +35 -37
  537. package/src/x_ite/Execution/BindableStack.js +25 -7
  538. package/src/x_ite/Execution/X3DScene.js +2 -2
  539. package/src/x_ite/Execution/X3DWorld.js +1 -1
  540. package/src/x_ite/Fields/SFRotation.js +2 -1
  541. package/src/x_ite/Fields/SFString.js +1 -1
  542. package/src/x_ite/InputOutput/FileLoader.js +105 -236
  543. package/src/x_ite/InputOutput/Generator.js +12 -8
  544. package/src/x_ite/Parser/Expressions.js +85 -0
  545. package/src/x_ite/Parser/GLB2Parser.js +147 -0
  546. package/src/x_ite/Parser/GLTF2Parser.js +2221 -0
  547. package/src/x_ite/Parser/GoldenGate.js +64 -13
  548. package/src/x_ite/Parser/JSONParser.js +7 -36
  549. package/src/x_ite/Parser/OBJParser.js +1076 -0
  550. package/src/x_ite/Parser/STLAParser.js +376 -0
  551. package/src/x_ite/Parser/STLBParser.js +156 -0
  552. package/src/x_ite/Parser/SVGParser.js +2476 -0
  553. package/src/x_ite/Parser/VRMLParser.js +127 -183
  554. package/src/x_ite/Parser/X3DOptimizer.js +191 -0
  555. package/src/x_ite/Parser/X3DParser.js +34 -0
  556. package/src/x_ite/Parser/XMLParser.js +11 -109
  557. package/src/x_ite/Prototype/X3DExternProtoDeclaration.js +2 -2
  558. package/src/x_ite/Prototype/X3DProtoDeclaration.js +3 -3
  559. package/src/x_ite/Rendering/DependentRenderer.js +1 -1
  560. package/src/x_ite/Rendering/MultiSampleFrameBuffer.js +150 -0
  561. package/src/x_ite/Rendering/TextureBuffer.js +3 -5
  562. package/src/x_ite/Rendering/X3DRenderObject.js +2 -7
  563. package/src/x_ite/X3D.js +1 -0
  564. package/src/x_ite/X3DCanvas.js +10 -0
  565. package/src/x_ite.html +39 -17
  566. package/webpack.config.js +1 -0
  567. package/x_ite.min.html +38 -17
  568. package/src/standard/Networking/BinaryTransport.js +0 -116
@@ -0,0 +1,1004 @@
1
+ /*
2
+ SuperGif
3
+
4
+ Example usage:
5
+
6
+ <img src="./example1_preview.gif" rel:animated_src="./example1.gif" width="360" height="360" rel:auto_play="1" />
7
+
8
+ <script type="text/javascript">
9
+ $$('img').each(function (img_tag) {
10
+ if (/.*\.gif/.test(img_tag.src)) {
11
+ var rub = new SuperGif({ gif: img_tag } );
12
+ rub.load();
13
+ }
14
+ });
15
+ </script>
16
+
17
+ Image tag attributes:
18
+
19
+ rel:animated_src - If this url is specified, it's loaded into the player instead of src.
20
+ This allows a preview frame to be shown until animated gif data is streamed into the canvas
21
+
22
+ rel:auto_play - Defaults to 1 if not specified. If set to zero, a call to the play() method is needed
23
+
24
+ Constructor options args
25
+
26
+ gif Required. The DOM element of an img tag.
27
+ loop_mode Optional. Setting this to false will force disable looping of the gif.
28
+ auto_play Optional. Same as the rel:auto_play attribute above, this arg overrides the img tag info.
29
+ max_width Optional. Scale images over max_width down to max_width. Helpful with mobile.
30
+ on_end Optional. Add a callback for when the gif reaches the end of a single loop (one iteration). The first argument passed will be the gif HTMLElement.
31
+ loop_delay Optional. The amount of time to pause (in ms) after each single loop (iteration).
32
+ draw_while_loading Optional. Determines whether the gif will be drawn to the canvas whilst it is loaded.
33
+ show_progress_bar Optional. Only applies when draw_while_loading is set to true.
34
+
35
+ Instance methods
36
+
37
+ // loading
38
+ load( callback ) Loads the gif specified by the src or rel:animated_src sttributie of the img tag into a canvas element and then calls callback if one is passed
39
+ load_url( src, callback ) Loads the gif file specified in the src argument into a canvas element and then calls callback if one is passed
40
+
41
+ // play controls
42
+ play - Start playing the gif
43
+ pause - Stop playing the gif
44
+ move_to(i) - Move to frame i of the gif
45
+ move_relative(i) - Move i frames ahead (or behind if i < 0)
46
+
47
+ // getters
48
+ get_canvas The canvas element that the gif is playing in. Handy for assigning event handlers to.
49
+ get_playing Whether or not the gif is currently playing
50
+ get_loading Whether or not the gif has finished loading/parsing
51
+ get_auto_play Whether or not the gif is set to play automatically
52
+ get_length The number of frames in the gif
53
+ get_current_frame The index of the currently displayed frame of the gif
54
+ get_frames An array containing the data for all parsed frames
55
+ get_duration Returns the duration of the gif in hundredths of a second (standard for GIF spec)
56
+ get_duration_ms Returns the duration of the gif in milliseconds
57
+
58
+ For additional customization (viewport inside iframe) these params may be passed:
59
+ c_w, c_h - width and height of canvas
60
+ vp_t, vp_l, vp_ w, vp_h - top, left, width and height of the viewport
61
+
62
+ A bonus: few articles to understand what is going on
63
+ http://enthusiasms.org/post/16976438906
64
+ http://www.matthewflickinger.com/lab/whatsinagif/bits_and_bytes.asp
65
+ http://humpy77.deviantart.com/journal/Frame-Delay-Times-for-Animated-GIFs-214150546
66
+
67
+ */
68
+ (function (root, factory) {
69
+ if (typeof define === 'function' && define.amd) {
70
+ define([], factory);
71
+ } else if (typeof exports === 'object') {
72
+ module.exports = factory();
73
+ } else {
74
+ root.SuperGif = factory();
75
+ }
76
+ }(this, function () {
77
+ // Generic functions
78
+ var bitsToNum = function (ba) {
79
+ return ba.reduce(function (s, n) {
80
+ return s * 2 + n;
81
+ }, 0);
82
+ };
83
+
84
+ var byteToBitArr = function (bite) {
85
+ var a = [];
86
+ for (var i = 7; i >= 0; i--) {
87
+ a.push( !! (bite & (1 << i)));
88
+ }
89
+ return a;
90
+ };
91
+
92
+ // Stream
93
+ /**
94
+ * @constructor
95
+ */
96
+ // Make compiler happy.
97
+ var Stream = function (data) {
98
+ this.data = data;
99
+ this.len = this.data.length;
100
+ this.pos = 0;
101
+
102
+ this.readByte = function () {
103
+ if (this.pos >= this.data.length) {
104
+ throw new Error('Attempted to read past end of stream.');
105
+ }
106
+ if (data instanceof Uint8Array)
107
+ return data[this.pos++];
108
+ else
109
+ return data.charCodeAt(this.pos++) & 0xFF;
110
+ };
111
+
112
+ this.readBytes = function (n) {
113
+ var bytes = [];
114
+ for (var i = 0; i < n; i++) {
115
+ bytes.push(this.readByte());
116
+ }
117
+ return bytes;
118
+ };
119
+
120
+ this.read = function (n) {
121
+ var s = '';
122
+ for (var i = 0; i < n; i++) {
123
+ s += String.fromCharCode(this.readByte());
124
+ }
125
+ return s;
126
+ };
127
+
128
+ this.readUnsigned = function () { // Little-endian.
129
+ var a = this.readBytes(2);
130
+ return (a[1] << 8) + a[0];
131
+ };
132
+ };
133
+
134
+ var lzwDecode = function (minCodeSize, data) {
135
+ // TODO: Now that the GIF parser is a bit different, maybe this should get an array of bytes instead of a String?
136
+ var pos = 0; // Maybe this streaming thing should be merged with the Stream?
137
+ var readCode = function (size) {
138
+ var code = 0;
139
+ for (var i = 0; i < size; i++) {
140
+ if (data.charCodeAt(pos >> 3) & (1 << (pos & 7))) {
141
+ code |= 1 << i;
142
+ }
143
+ pos++;
144
+ }
145
+ return code;
146
+ };
147
+
148
+ var output = [];
149
+
150
+ var clearCode = 1 << minCodeSize;
151
+ var eoiCode = clearCode + 1;
152
+
153
+ var codeSize = minCodeSize + 1;
154
+
155
+ var dict = [];
156
+
157
+ var clear = function () {
158
+ dict = [];
159
+ codeSize = minCodeSize + 1;
160
+ for (var i = 0; i < clearCode; i++) {
161
+ dict[i] = [i];
162
+ }
163
+ dict[clearCode] = [];
164
+ dict[eoiCode] = null;
165
+
166
+ };
167
+
168
+ var code;
169
+ var last;
170
+
171
+ while (true) {
172
+ last = code;
173
+ code = readCode(codeSize);
174
+
175
+ if (code === clearCode) {
176
+ clear();
177
+ continue;
178
+ }
179
+ if (code === eoiCode) break;
180
+
181
+ if (code < dict.length) {
182
+ if (last !== clearCode) {
183
+ dict.push(dict[last].concat(dict[code][0]));
184
+ }
185
+ }
186
+ else {
187
+ if (code !== dict.length) throw new Error('Invalid LZW code.');
188
+ dict.push(dict[last].concat(dict[last][0]));
189
+ }
190
+ output.push.apply(output, dict[code]);
191
+
192
+ if (dict.length === (1 << codeSize) && codeSize < 12) {
193
+ // If we're at the last code and codeSize is 12, the next code will be a clearCode, and it'll be 12 bits long.
194
+ codeSize++;
195
+ }
196
+ }
197
+
198
+ // I don't know if this is technically an error, but some GIFs do it.
199
+ //if (Math.ceil(pos / 8) !== data.length) throw new Error('Extraneous LZW bytes.');
200
+ return output;
201
+ };
202
+
203
+
204
+ // The actual parsing; returns an object with properties.
205
+ var parseGIF = function (st, handler) {
206
+ handler || (handler = {});
207
+
208
+ // LZW (GIF-specific)
209
+ var parseCT = function (entries) { // Each entry is 3 bytes, for RGB.
210
+ var ct = [];
211
+ for (var i = 0; i < entries; i++) {
212
+ ct.push(st.readBytes(3));
213
+ }
214
+ return ct;
215
+ };
216
+
217
+ var readSubBlocks = function () {
218
+ var size, data;
219
+ data = '';
220
+ do {
221
+ size = st.readByte();
222
+ data += st.read(size);
223
+ } while (size !== 0);
224
+ return data;
225
+ };
226
+
227
+ var parseHeader = function () {
228
+ var hdr = {};
229
+ hdr.sig = st.read(3);
230
+ hdr.ver = st.read(3);
231
+ if (hdr.sig !== 'GIF') throw new Error('Not a GIF file.'); // XXX: This should probably be handled more nicely.
232
+ hdr.width = st.readUnsigned();
233
+ hdr.height = st.readUnsigned();
234
+
235
+ var bits = byteToBitArr(st.readByte());
236
+ hdr.gctFlag = bits.shift();
237
+ hdr.colorRes = bitsToNum(bits.splice(0, 3));
238
+ hdr.sorted = bits.shift();
239
+ hdr.gctSize = bitsToNum(bits.splice(0, 3));
240
+
241
+ hdr.bgColor = st.readByte();
242
+ hdr.pixelAspectRatio = st.readByte(); // if not 0, aspectRatio = (pixelAspectRatio + 15) / 64
243
+ if (hdr.gctFlag) {
244
+ hdr.gct = parseCT(1 << (hdr.gctSize + 1));
245
+ }
246
+ handler.hdr && handler.hdr(hdr);
247
+ };
248
+
249
+ var parseExt = function (block) {
250
+ var parseGCExt = function (block) {
251
+ var blockSize = st.readByte(); // Always 4
252
+ var bits = byteToBitArr(st.readByte());
253
+ block.reserved = bits.splice(0, 3); // Reserved; should be 000.
254
+ block.disposalMethod = bitsToNum(bits.splice(0, 3));
255
+ block.userInput = bits.shift();
256
+ block.transparencyGiven = bits.shift();
257
+
258
+ block.delayTime = st.readUnsigned();
259
+
260
+ block.transparencyIndex = st.readByte();
261
+
262
+ block.terminator = st.readByte();
263
+
264
+ handler.gce && handler.gce(block);
265
+ };
266
+
267
+ var parseComExt = function (block) {
268
+ block.comment = readSubBlocks();
269
+ handler.com && handler.com(block);
270
+ };
271
+
272
+ var parsePTExt = function (block) {
273
+ // No one *ever* uses this. If you use it, deal with parsing it yourself.
274
+ var blockSize = st.readByte(); // Always 12
275
+ block.ptHeader = st.readBytes(12);
276
+ block.ptData = readSubBlocks();
277
+ handler.pte && handler.pte(block);
278
+ };
279
+
280
+ var parseAppExt = function (block) {
281
+ var parseNetscapeExt = function (block) {
282
+ var blockSize = st.readByte(); // Always 3
283
+ block.unknown = st.readByte(); // ??? Always 1? What is this?
284
+ block.iterations = st.readUnsigned();
285
+ block.terminator = st.readByte();
286
+ handler.app && handler.app.NETSCAPE && handler.app.NETSCAPE(block);
287
+ };
288
+
289
+ var parseUnknownAppExt = function (block) {
290
+ block.appData = readSubBlocks();
291
+ // FIXME: This won't work if a handler wants to match on any identifier.
292
+ handler.app && handler.app[block.identifier] && handler.app[block.identifier](block);
293
+ };
294
+
295
+ var blockSize = st.readByte(); // Always 11
296
+ block.identifier = st.read(8);
297
+ block.authCode = st.read(3);
298
+ switch (block.identifier) {
299
+ case 'NETSCAPE':
300
+ parseNetscapeExt(block);
301
+ break;
302
+ default:
303
+ parseUnknownAppExt(block);
304
+ break;
305
+ }
306
+ };
307
+
308
+ var parseUnknownExt = function (block) {
309
+ block.data = readSubBlocks();
310
+ handler.unknown && handler.unknown(block);
311
+ };
312
+
313
+ block.label = st.readByte();
314
+ switch (block.label) {
315
+ case 0xF9:
316
+ block.extType = 'gce';
317
+ parseGCExt(block);
318
+ break;
319
+ case 0xFE:
320
+ block.extType = 'com';
321
+ parseComExt(block);
322
+ break;
323
+ case 0x01:
324
+ block.extType = 'pte';
325
+ parsePTExt(block);
326
+ break;
327
+ case 0xFF:
328
+ block.extType = 'app';
329
+ parseAppExt(block);
330
+ break;
331
+ default:
332
+ block.extType = 'unknown';
333
+ parseUnknownExt(block);
334
+ break;
335
+ }
336
+ };
337
+
338
+ var parseImg = function (img) {
339
+ var deinterlace = function (pixels, width) {
340
+ // Of course this defeats the purpose of interlacing. And it's *probably*
341
+ // the least efficient way it's ever been implemented. But nevertheless...
342
+ var newPixels = new Array(pixels.length);
343
+ var rows = pixels.length / width;
344
+ var cpRow = function (toRow, fromRow) {
345
+ var fromPixels = pixels.slice(fromRow * width, (fromRow + 1) * width);
346
+ newPixels.splice.apply(newPixels, [toRow * width, width].concat(fromPixels));
347
+ };
348
+
349
+ // See appendix E.
350
+ var offsets = [0, 4, 2, 1];
351
+ var steps = [8, 8, 4, 2];
352
+
353
+ var fromRow = 0;
354
+ for (var pass = 0; pass < 4; pass++) {
355
+ for (var toRow = offsets[pass]; toRow < rows; toRow += steps[pass]) {
356
+ cpRow(toRow, fromRow)
357
+ fromRow++;
358
+ }
359
+ }
360
+
361
+ return newPixels;
362
+ };
363
+
364
+ img.leftPos = st.readUnsigned();
365
+ img.topPos = st.readUnsigned();
366
+ img.width = st.readUnsigned();
367
+ img.height = st.readUnsigned();
368
+
369
+ var bits = byteToBitArr(st.readByte());
370
+ img.lctFlag = bits.shift();
371
+ img.interlaced = bits.shift();
372
+ img.sorted = bits.shift();
373
+ img.reserved = bits.splice(0, 2);
374
+ img.lctSize = bitsToNum(bits.splice(0, 3));
375
+
376
+ if (img.lctFlag) {
377
+ img.lct = parseCT(1 << (img.lctSize + 1));
378
+ }
379
+
380
+ img.lzwMinCodeSize = st.readByte();
381
+
382
+ var lzwData = readSubBlocks();
383
+
384
+ img.pixels = lzwDecode(img.lzwMinCodeSize, lzwData);
385
+
386
+ if (img.interlaced) { // Move
387
+ img.pixels = deinterlace(img.pixels, img.width);
388
+ }
389
+
390
+ handler.img && handler.img(img);
391
+ };
392
+
393
+ var parseBlock = function () {
394
+ var block = {};
395
+ block.sentinel = st.readByte();
396
+
397
+ switch (String.fromCharCode(block.sentinel)) { // For ease of matching
398
+ case '!':
399
+ block.type = 'ext';
400
+ parseExt(block);
401
+ break;
402
+ case ',':
403
+ block.type = 'img';
404
+ parseImg(block);
405
+ break;
406
+ case ';':
407
+ block.type = 'eof';
408
+ handler.eof && handler.eof(block);
409
+ break;
410
+ default:
411
+ throw new Error('Unknown block: 0x' + block.sentinel.toString(16)); // TODO: Pad this with a 0.
412
+ }
413
+
414
+ if (block.type !== 'eof') setTimeout(parseBlock, 0);
415
+ };
416
+
417
+ var parse = function () {
418
+ parseHeader();
419
+ setTimeout(parseBlock, 0);
420
+ };
421
+
422
+ parse();
423
+ };
424
+
425
+ var SuperGif = function ( opts ) {
426
+ var options = {
427
+ //viewport position
428
+ vp_l: 0,
429
+ vp_t: 0,
430
+ vp_w: null,
431
+ vp_h: null,
432
+ //canvas sizes
433
+ c_w: null,
434
+ c_h: null
435
+ };
436
+ for (var i in opts ) { options[i] = opts[i] }
437
+ if (options.vp_w && options.vp_h) options.is_vp = true;
438
+
439
+ var stream;
440
+ var hdr;
441
+
442
+ var loadError = null;
443
+ var loading = false;
444
+
445
+ var transparency = null;
446
+ var delay = null;
447
+ var disposalMethod = null;
448
+ var disposalRestoreFromIdx = null;
449
+ var lastDisposalMethod = null;
450
+ var frame = null;
451
+ var lastImg = null;
452
+
453
+ var playing = true;
454
+ var forward = true;
455
+
456
+ var ctx_scaled = false;
457
+
458
+ var frames = [];
459
+ var frameOffsets = []; // elements have .x and .y properties
460
+
461
+ var gif = options.gif;
462
+ if (typeof options.auto_play == 'undefined')
463
+ options.auto_play = (!gif.getAttribute('rel:auto_play') || gif.getAttribute('rel:auto_play') == '1');
464
+
465
+ var onEndListener = (options.hasOwnProperty('on_end') ? options.on_end : null);
466
+ var onErrorListener = (options.hasOwnProperty('on_error') ? options.on_error : null);
467
+ var loopDelay = (options.hasOwnProperty('loop_delay') ? options.loop_delay : 0);
468
+ var overrideLoopMode = (options.hasOwnProperty('loop_mode') ? options.loop_mode : 'auto');
469
+ var drawWhileLoading = (options.hasOwnProperty('draw_while_loading') ? options.draw_while_loading : true);
470
+ var showProgressBar = drawWhileLoading ? (options.hasOwnProperty('show_progress_bar') ? options.show_progress_bar : true) : false;
471
+ var progressBarHeight = (options.hasOwnProperty('progressbar_height') ? options.progressbar_height : 25);
472
+ var progressBarBackgroundColor = (options.hasOwnProperty('progressbar_background_color') ? options.progressbar_background_color : 'rgba(255,255,255,0.4)');
473
+ var progressBarForegroundColor = (options.hasOwnProperty('progressbar_foreground_color') ? options.progressbar_foreground_color : 'rgba(255,0,22,.8)');
474
+
475
+ var clear = function () {
476
+ transparency = null;
477
+ delay = null;
478
+ lastDisposalMethod = disposalMethod;
479
+ disposalMethod = null;
480
+ frame = null;
481
+ };
482
+
483
+ // XXX: There's probably a better way to handle catching exceptions when
484
+ // callbacks are involved.
485
+ var doParse = function () {
486
+ try {
487
+ parseGIF(stream, handler);
488
+ }
489
+ catch (err) {
490
+ doLoadError('parse');
491
+ }
492
+ };
493
+
494
+ var doText = function (text) {
495
+ toolbar.innerHTML = text; // innerText? Escaping? Whatever.
496
+ toolbar.style.visibility = 'visible';
497
+ };
498
+
499
+ var setSizes = function(w, h) {
500
+ canvas.width = w * get_canvas_scale();
501
+ canvas.height = h * get_canvas_scale();
502
+ toolbar.style.minWidth = ( w * get_canvas_scale() ) + 'px';
503
+
504
+ tmpCanvas.width = w;
505
+ tmpCanvas.height = h;
506
+ tmpCanvas.style.width = w + 'px';
507
+ tmpCanvas.style.height = h + 'px';
508
+ tmpCanvas.getContext('2d').setTransform(1, 0, 0, 1, 0, 0);
509
+ };
510
+
511
+ var setFrameOffset = function(frame, offset) {
512
+ if (!frameOffsets[frame]) {
513
+ frameOffsets[frame] = offset;
514
+ return;
515
+ }
516
+ if (typeof offset.x !== 'undefined') {
517
+ frameOffsets[frame].x = offset.x;
518
+ }
519
+ if (typeof offset.y !== 'undefined') {
520
+ frameOffsets[frame].y = offset.y;
521
+ }
522
+ };
523
+
524
+ var doShowProgress = function (pos, length, draw) {
525
+ if (draw && showProgressBar) {
526
+ var height = progressBarHeight;
527
+ var left, mid, top, width;
528
+ if (options.is_vp) {
529
+ if (!ctx_scaled) {
530
+ top = (options.vp_t + options.vp_h - height);
531
+ height = height;
532
+ left = options.vp_l;
533
+ mid = left + (pos / length) * options.vp_w;
534
+ width = canvas.width;
535
+ } else {
536
+ top = (options.vp_t + options.vp_h - height) / get_canvas_scale();
537
+ height = height / get_canvas_scale();
538
+ left = (options.vp_l / get_canvas_scale() );
539
+ mid = left + (pos / length) * (options.vp_w / get_canvas_scale());
540
+ width = canvas.width / get_canvas_scale();
541
+ }
542
+ //some debugging, draw rect around viewport
543
+ if (false) {
544
+ if (!ctx_scaled) {
545
+ var l = options.vp_l, t = options.vp_t;
546
+ var w = options.vp_w, h = options.vp_h;
547
+ } else {
548
+ var l = options.vp_l/get_canvas_scale(), t = options.vp_t/get_canvas_scale();
549
+ var w = options.vp_w/get_canvas_scale(), h = options.vp_h/get_canvas_scale();
550
+ }
551
+ ctx.rect(l,t,w,h);
552
+ ctx.stroke();
553
+ }
554
+ }
555
+ else {
556
+ top = (canvas.height - height) / (ctx_scaled ? get_canvas_scale() : 1);
557
+ mid = ((pos / length) * canvas.width) / (ctx_scaled ? get_canvas_scale() : 1);
558
+ width = canvas.width / (ctx_scaled ? get_canvas_scale() : 1 );
559
+ height /= ctx_scaled ? get_canvas_scale() : 1;
560
+ }
561
+
562
+ ctx.fillStyle = progressBarBackgroundColor;
563
+ ctx.fillRect(mid, top, width - mid, height);
564
+
565
+ ctx.fillStyle = progressBarForegroundColor;
566
+ ctx.fillRect(0, top, mid, height);
567
+ }
568
+ };
569
+
570
+ var doLoadError = function (originOfError) {
571
+ var drawError = function () {
572
+ ctx.fillStyle = 'black';
573
+ ctx.fillRect(0, 0, options.c_w ? options.c_w : hdr.width, options.c_h ? options.c_h : hdr.height);
574
+ ctx.strokeStyle = 'red';
575
+ ctx.lineWidth = 3;
576
+ ctx.moveTo(0, 0);
577
+ ctx.lineTo(options.c_w ? options.c_w : hdr.width, options.c_h ? options.c_h : hdr.height);
578
+ ctx.moveTo(0, options.c_h ? options.c_h : hdr.height);
579
+ ctx.lineTo(options.c_w ? options.c_w : hdr.width, 0);
580
+ ctx.stroke();
581
+ };
582
+
583
+ loadError = originOfError;
584
+ hdr = {
585
+ width: gif.width,
586
+ height: gif.height
587
+ }; // Fake header.
588
+ frames = [];
589
+ drawError();
590
+
591
+ if (originOfError)
592
+ onErrorListener (originOfError);
593
+ };
594
+
595
+ var doHdr = function (_hdr) {
596
+ hdr = _hdr;
597
+ setSizes(hdr.width, hdr.height)
598
+ };
599
+
600
+ var doGCE = function (gce) {
601
+ pushFrame();
602
+ clear();
603
+ transparency = gce.transparencyGiven ? gce.transparencyIndex : null;
604
+ delay = gce.delayTime;
605
+ disposalMethod = gce.disposalMethod;
606
+ // We don't have much to do with the rest of GCE.
607
+ };
608
+
609
+ var pushFrame = function () {
610
+ if (!frame) return;
611
+ frames.push({
612
+ data: frame.getImageData(0, 0, hdr.width, hdr.height),
613
+ delay: delay
614
+ });
615
+ frameOffsets.push({ x: 0, y: 0 });
616
+ };
617
+
618
+ var doImg = function (img) {
619
+ if (!frame) frame = tmpCanvas.getContext('2d');
620
+
621
+ var currIdx = frames.length;
622
+
623
+ //ct = color table, gct = global color table
624
+ var ct = img.lctFlag ? img.lct : hdr.gct; // TODO: What if neither exists?
625
+
626
+ /*
627
+ Disposal method indicates the way in which the graphic is to
628
+ be treated after being displayed.
629
+
630
+ Values : 0 - No disposal specified. The decoder is
631
+ not required to take any action.
632
+ 1 - Do not dispose. The graphic is to be left
633
+ in place.
634
+ 2 - Restore to background color. The area used by the
635
+ graphic must be restored to the background color.
636
+ 3 - Restore to previous. The decoder is required to
637
+ restore the area overwritten by the graphic with
638
+ what was there prior to rendering the graphic.
639
+
640
+ Importantly, "previous" means the frame state
641
+ after the last disposal of method 0, 1, or 2.
642
+ */
643
+ if (currIdx > 0) {
644
+ if (lastDisposalMethod === 3) {
645
+ // Restore to previous
646
+ // If we disposed every frame including first frame up to this point, then we have
647
+ // no composited frame to restore to. In this case, restore to background instead.
648
+ if (disposalRestoreFromIdx !== null) {
649
+ frame.putImageData(frames[disposalRestoreFromIdx].data, 0, 0);
650
+ } else {
651
+ frame.clearRect(lastImg.leftPos, lastImg.topPos, lastImg.width, lastImg.height);
652
+ }
653
+ } else {
654
+ disposalRestoreFromIdx = currIdx - 1;
655
+ }
656
+
657
+ if (lastDisposalMethod === 2) {
658
+ // Restore to background color
659
+ // Browser implementations historically restore to transparent; we do the same.
660
+ // http://www.wizards-toolkit.org/discourse-server/viewtopic.php?f=1&t=21172#p86079
661
+ frame.clearRect(lastImg.leftPos, lastImg.topPos, lastImg.width, lastImg.height);
662
+ }
663
+ }
664
+ // else, Undefined/Do not dispose.
665
+ // frame contains final pixel data from the last frame; do nothing
666
+
667
+ //Get existing pixels for img region after applying disposal method
668
+ var imgData = frame.getImageData(img.leftPos, img.topPos, img.width, img.height);
669
+
670
+ //apply color table colors
671
+ img.pixels.forEach(function (pixel, i) {
672
+ // imgData.data === [R,G,B,A,R,G,B,A,...]
673
+ if (pixel !== transparency) {
674
+ imgData.data[i * 4 + 0] = ct[pixel][0];
675
+ imgData.data[i * 4 + 1] = ct[pixel][1];
676
+ imgData.data[i * 4 + 2] = ct[pixel][2];
677
+ imgData.data[i * 4 + 3] = 255; // Opaque.
678
+ }
679
+ });
680
+
681
+ frame.putImageData(imgData, img.leftPos, img.topPos);
682
+
683
+ if (!ctx_scaled) {
684
+ ctx.scale(get_canvas_scale(),get_canvas_scale());
685
+ ctx_scaled = true;
686
+ }
687
+
688
+ // We could use the on-page canvas directly, except that we draw a progress
689
+ // bar for each image chunk (not just the final image).
690
+ if (drawWhileLoading) {
691
+ ctx.drawImage(tmpCanvas, 0, 0);
692
+ drawWhileLoading = options.auto_play;
693
+ }
694
+
695
+ lastImg = img;
696
+ };
697
+
698
+ var player = (function () {
699
+ var i = -1;
700
+ var iterationCount = 0;
701
+
702
+ var showingInfo = false;
703
+ var pinned = false;
704
+
705
+ /**
706
+ * Gets the index of the frame "up next".
707
+ * @returns {number}
708
+ */
709
+ var getNextFrameNo = function () {
710
+ var delta = (forward ? 1 : -1);
711
+ return (i + delta + frames.length) % frames.length;
712
+ };
713
+
714
+ var stepFrame = function (amount) { // XXX: Name is confusing.
715
+ i = i + amount;
716
+
717
+ putFrame();
718
+ };
719
+
720
+ var step = (function () {
721
+ var stepping = false;
722
+
723
+ var completeLoop = function () {
724
+ if (onEndListener !== null)
725
+ onEndListener(gif);
726
+ iterationCount++;
727
+
728
+ if (overrideLoopMode !== false || iterationCount < 0) {
729
+ doStep();
730
+ } else {
731
+ stepping = false;
732
+ playing = false;
733
+ }
734
+ };
735
+
736
+ var doStep = function () {
737
+ stepping = playing;
738
+ if (!stepping) return;
739
+
740
+ stepFrame(1);
741
+ var delay = frames[i].delay * 10;
742
+ if (!delay) delay = 100; // FIXME: Should this even default at all? What should it be?
743
+
744
+ var nextFrameNo = getNextFrameNo();
745
+ if (nextFrameNo === 0) {
746
+ delay += loopDelay;
747
+ setTimeout(completeLoop, delay);
748
+ } else {
749
+ setTimeout(doStep, delay);
750
+ }
751
+ };
752
+
753
+ return function () {
754
+ if (!stepping) setTimeout(doStep, 0);
755
+ };
756
+ }());
757
+
758
+ var putFrame = function () {
759
+ var offset;
760
+ i = parseInt(i, 10);
761
+
762
+ if (i > frames.length - 1){
763
+ i = 0;
764
+ }
765
+
766
+ if (i < 0){
767
+ i = 0;
768
+ }
769
+
770
+ offset = frameOffsets[i];
771
+
772
+ tmpCanvas.getContext("2d").putImageData(frames[i].data, offset.x, offset.y);
773
+ ctx.globalCompositeOperation = "copy";
774
+ ctx.drawImage(tmpCanvas, 0, 0);
775
+ };
776
+
777
+ var play = function () {
778
+ playing = true;
779
+ step();
780
+ };
781
+
782
+ var pause = function () {
783
+ playing = false;
784
+ };
785
+
786
+
787
+ return {
788
+ init: function () {
789
+ if (loadError) return;
790
+
791
+ if ( ! (options.c_w && options.c_h) ) {
792
+ ctx.scale(get_canvas_scale(),get_canvas_scale());
793
+ }
794
+
795
+ if (options.auto_play) {
796
+ step();
797
+ }
798
+ else {
799
+ i = 0;
800
+ putFrame();
801
+ }
802
+ },
803
+ step: step,
804
+ play: play,
805
+ pause: pause,
806
+ playing: playing,
807
+ move_relative: stepFrame,
808
+ current_frame: function() { return i; },
809
+ length: function() { return frames.length },
810
+ move_to: function ( frame_idx ) {
811
+ i = frame_idx;
812
+ putFrame();
813
+ }
814
+ }
815
+ }());
816
+
817
+ var doDecodeProgress = function (draw) {
818
+ doShowProgress(stream.pos, stream.data.length, draw);
819
+ };
820
+
821
+ var doNothing = function () {};
822
+ /**
823
+ * @param{boolean=} draw Whether to draw progress bar or not; this is not idempotent because of translucency.
824
+ * Note that this means that the text will be unsynchronized with the progress bar on non-frames;
825
+ * but those are typically so small (GCE etc.) that it doesn't really matter. TODO: Do this properly.
826
+ */
827
+ var withProgress = function (fn, draw) {
828
+ return function (block) {
829
+ fn(block);
830
+ doDecodeProgress(draw);
831
+ };
832
+ };
833
+
834
+
835
+ var handler = {
836
+ hdr: withProgress(doHdr),
837
+ gce: withProgress(doGCE),
838
+ com: withProgress(doNothing),
839
+ // I guess that's all for now.
840
+ app: {
841
+ // TODO: Is there much point in actually supporting iterations?
842
+ NETSCAPE: withProgress(doNothing)
843
+ },
844
+ img: withProgress(doImg, true),
845
+ eof: function (block) {
846
+ //toolbar.style.display = '';
847
+ pushFrame();
848
+ doDecodeProgress(false);
849
+ if ( ! (options.c_w && options.c_h) ) {
850
+ canvas.width = hdr.width * get_canvas_scale();
851
+ canvas.height = hdr.height * get_canvas_scale();
852
+ }
853
+ player.init();
854
+ loading = false;
855
+ if (load_callback) {
856
+ load_callback(gif);
857
+ }
858
+
859
+ }
860
+ };
861
+
862
+ var init = function () {
863
+ var parent = gif.parentNode;
864
+
865
+ var div = document.createElement('div');
866
+ canvas = document.createElement('canvas');
867
+ ctx = canvas.getContext('2d');
868
+ toolbar = document.createElement('div');
869
+
870
+ tmpCanvas = document.createElement('canvas');
871
+
872
+ div.width = canvas.width = gif.width;
873
+ div.height = canvas.height = gif.height;
874
+ toolbar.style.minWidth = gif.width + 'px';
875
+
876
+ div.className = 'jsgif';
877
+ toolbar.className = 'jsgif_toolbar';
878
+ div.appendChild(canvas);
879
+ div.appendChild(toolbar);
880
+
881
+ parent.insertBefore(div, gif);
882
+ parent.removeChild(gif);
883
+
884
+ if (options.c_w && options.c_h) setSizes(options.c_w, options.c_h);
885
+ initialized=true;
886
+ };
887
+
888
+ var get_canvas_scale = function() {
889
+ var scale;
890
+ if (options.max_width && hdr && hdr.width > options.max_width) {
891
+ scale = options.max_width / hdr.width;
892
+ }
893
+ else {
894
+ scale = 1;
895
+ }
896
+ return scale;
897
+ }
898
+
899
+ var canvas, ctx, toolbar, tmpCanvas;
900
+ var initialized = false;
901
+ var load_callback = false;
902
+
903
+ var load_setup = function(callback) {
904
+ if (loading) return false;
905
+ if (callback) load_callback = callback;
906
+ else load_callback = false;
907
+
908
+ loading = true;
909
+ frames = [];
910
+ clear();
911
+ disposalRestoreFromIdx = null;
912
+ lastDisposalMethod = null;
913
+ frame = null;
914
+ lastImg = null;
915
+
916
+ return true;
917
+ }
918
+
919
+ var calculateDuration = function() {
920
+ return frames.reduce(function(duration, frame) {
921
+ return duration + frame.delay;
922
+ }, 0);
923
+ }
924
+
925
+ return {
926
+ // play controls
927
+ play: player.play,
928
+ pause: player.pause,
929
+ move_relative: player.move_relative,
930
+ move_to: player.move_to,
931
+
932
+ // getters for instance vars
933
+ get_playing : function() { return playing },
934
+ get_canvas : function() { return canvas },
935
+ get_canvas_scale : function() { return get_canvas_scale() },
936
+ get_loading : function() { return loading },
937
+ get_auto_play : function() { return options.auto_play },
938
+ get_length : function() { return player.length() },
939
+ get_frames : function() { return frames },
940
+ get_duration : function() { return calculateDuration() },
941
+ get_duration_ms : function() { return calculateDuration() * 10 },
942
+ get_current_frame: function() { return player.current_frame() },
943
+ load_url: function(src,callback){
944
+ if (!load_setup(callback)) return;
945
+
946
+ var h = new XMLHttpRequest();
947
+ // new browsers (XMLHttpRequest2-compliant)
948
+ h.open('GET', src, true);
949
+
950
+ if ('overrideMimeType' in h) {
951
+ h.overrideMimeType('text/plain; charset=x-user-defined');
952
+ }
953
+
954
+ // old browsers (XMLHttpRequest-compliant)
955
+ else if ('responseType' in h) {
956
+ h.responseType = 'arraybuffer';
957
+ }
958
+
959
+ // IE9 (Microsoft.XMLHTTP-compliant)
960
+ else {
961
+ h.setRequestHeader('Accept-Charset', 'x-user-defined');
962
+ }
963
+
964
+ h.onloadstart = function() {
965
+ // Wait until connection is opened to replace the gif element with a canvas to avoid a blank img
966
+ if (!initialized) init();
967
+ };
968
+ h.onload = function(e) {
969
+ if (this.status != 200) {
970
+ doLoadError('xhr - response');
971
+ }
972
+ // emulating response field for IE9
973
+ if (!('response' in this)) {
974
+ this.response = new VBArray(this.responseText).toArray().map(String.fromCharCode).join('');
975
+ }
976
+ var data = this.response;
977
+ if (data.toString().indexOf("ArrayBuffer") > 0) {
978
+ data = new Uint8Array(data);
979
+ }
980
+
981
+ stream = new Stream(data);
982
+ setTimeout(doParse, 0);
983
+ };
984
+ h.onprogress = function (e) {
985
+ if (e.lengthComputable) doShowProgress(e.loaded, e.total, true);
986
+ };
987
+ h.onerror = function() { doLoadError('xhr'); };
988
+ h.send();
989
+ },
990
+ load: function (callback) {
991
+ this.load_url(gif.getAttribute('rel:animated_src') || gif.src,callback);
992
+ },
993
+ load_raw: function(arr, callback) {
994
+ if (!load_setup(callback)) return;
995
+ if (!initialized) init();
996
+ stream = new Stream(arr);
997
+ setTimeout(doParse, 0);
998
+ },
999
+ set_frame_offset: setFrameOffset
1000
+ };
1001
+ };
1002
+
1003
+ return SuperGif;
1004
+ }));