@lumen5/lottie-web 5.14.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (300) hide show
  1. package/.babelrc.json +3 -0
  2. package/.eslintrc.json +46 -0
  3. package/.gitattributes +1 -0
  4. package/.github/FUNDING.yml +1 -0
  5. package/.github/ISSUE_TEMPLATE.md +22 -0
  6. package/.github/workflows/publish.yml +26 -0
  7. package/.github/workflows/testAnimations.yml +29 -0
  8. package/.github/workflows/updateScreenshots.yml +34 -0
  9. package/CHANGELOG.md +601 -0
  10. package/History.md +1230 -0
  11. package/LICENSE.md +21 -0
  12. package/README.md +351 -0
  13. package/bower.json +31 -0
  14. package/build/old_parser/bodymovin_parser.jsx +3023 -0
  15. package/build/old_parser/helperProject.aep +0 -0
  16. package/build/player/cjs/lottie.min.js +18229 -0
  17. package/build/player/cjs/lottie_canvas.min.js +16465 -0
  18. package/build/player/cjs/lottie_html.min.js +16312 -0
  19. package/build/player/cjs/lottie_light.min.js +11584 -0
  20. package/build/player/cjs/lottie_light_canvas.min.js +13518 -0
  21. package/build/player/cjs/lottie_light_html.min.js +12843 -0
  22. package/build/player/cjs/lottie_svg.min.js +15053 -0
  23. package/build/player/esm/lottie.min.js +18225 -0
  24. package/build/player/esm/lottie_canvas.min.js +16461 -0
  25. package/build/player/esm/lottie_html.min.js +16308 -0
  26. package/build/player/esm/lottie_light.min.js +11580 -0
  27. package/build/player/esm/lottie_light_canvas.min.js +13514 -0
  28. package/build/player/esm/lottie_light_html.min.js +12839 -0
  29. package/build/player/esm/lottie_svg.min.js +15049 -0
  30. package/build/player/lottie.d.ts +5 -0
  31. package/build/player/lottie.js +17151 -0
  32. package/build/player/lottie.min.js +1 -0
  33. package/build/player/lottie_canvas.js +15506 -0
  34. package/build/player/lottie_canvas.min.js +1 -0
  35. package/build/player/lottie_canvas_worker.js +18196 -0
  36. package/build/player/lottie_canvas_worker.min.js +15 -0
  37. package/build/player/lottie_html.d.ts +5 -0
  38. package/build/player/lottie_html.js +15354 -0
  39. package/build/player/lottie_html.min.js +1 -0
  40. package/build/player/lottie_light.d.ts +5 -0
  41. package/build/player/lottie_light.js +10854 -0
  42. package/build/player/lottie_light.min.js +1 -0
  43. package/build/player/lottie_light_canvas.d.ts +5 -0
  44. package/build/player/lottie_light_canvas.js +12666 -0
  45. package/build/player/lottie_light_canvas.min.js +1 -0
  46. package/build/player/lottie_light_html.d.ts +5 -0
  47. package/build/player/lottie_light_html.js +12029 -0
  48. package/build/player/lottie_light_html.min.js +1 -0
  49. package/build/player/lottie_svg.d.ts +5 -0
  50. package/build/player/lottie_svg.js +14179 -0
  51. package/build/player/lottie_svg.min.js +1 -0
  52. package/build/player/lottie_worker.js +18196 -0
  53. package/build/player/lottie_worker.min.js +15 -0
  54. package/docs/json/animation.json +101 -0
  55. package/docs/json/effects/angle.json +40 -0
  56. package/docs/json/effects/checkBox.json +40 -0
  57. package/docs/json/effects/color.json +40 -0
  58. package/docs/json/effects/customValue.json +4 -0
  59. package/docs/json/effects/dropDown.json +40 -0
  60. package/docs/json/effects/fill.json +55 -0
  61. package/docs/json/effects/group.json +41 -0
  62. package/docs/json/effects/index.json +51 -0
  63. package/docs/json/effects/layer.json +33 -0
  64. package/docs/json/effects/noValue.json +1 -0
  65. package/docs/json/effects/point.json +43 -0
  66. package/docs/json/effects/proLevels.json +130 -0
  67. package/docs/json/effects/slider.json +40 -0
  68. package/docs/json/effects/stroke.json +64 -0
  69. package/docs/json/effects/tint.json +43 -0
  70. package/docs/json/effects/tritone.json +46 -0
  71. package/docs/json/helpers/blendMode.json +71 -0
  72. package/docs/json/helpers/boolean.json +14 -0
  73. package/docs/json/helpers/composite.json +15 -0
  74. package/docs/json/helpers/lineCap.json +19 -0
  75. package/docs/json/helpers/lineJoin.json +19 -0
  76. package/docs/json/helpers/mask.json +80 -0
  77. package/docs/json/helpers/textBased.json +23 -0
  78. package/docs/json/helpers/textGrouping.json +23 -0
  79. package/docs/json/helpers/textShape.json +31 -0
  80. package/docs/json/helpers/transform.json +146 -0
  81. package/docs/json/layers/image.json +113 -0
  82. package/docs/json/layers/null.json +87 -0
  83. package/docs/json/layers/preComp.json +118 -0
  84. package/docs/json/layers/shape.json +157 -0
  85. package/docs/json/layers/solid.json +120 -0
  86. package/docs/json/layers/text.json +523 -0
  87. package/docs/json/properties/doubleKeyframe.json +50 -0
  88. package/docs/json/properties/multiDimensional.json +21 -0
  89. package/docs/json/properties/multiDimensionalKeyframed.json +35 -0
  90. package/docs/json/properties/offsetKeyframe.json +53 -0
  91. package/docs/json/properties/shape.json +27 -0
  92. package/docs/json/properties/shapeKeyframed.json +35 -0
  93. package/docs/json/properties/shapeProp.json +50 -0
  94. package/docs/json/properties/shapePropKeyframe.json +54 -0
  95. package/docs/json/properties/value.json +21 -0
  96. package/docs/json/properties/valueKeyframe.json +33 -0
  97. package/docs/json/properties/valueKeyframed.json +25 -0
  98. package/docs/json/shapes/ellipse.json +54 -0
  99. package/docs/json/shapes/fill.json +48 -0
  100. package/docs/json/shapes/gFill.json +107 -0
  101. package/docs/json/shapes/gStroke.json +137 -0
  102. package/docs/json/shapes/group.json +89 -0
  103. package/docs/json/shapes/merge.json +27 -0
  104. package/docs/json/shapes/rect.json +66 -0
  105. package/docs/json/shapes/repeater.json +63 -0
  106. package/docs/json/shapes/round.json +35 -0
  107. package/docs/json/shapes/shape.json +40 -0
  108. package/docs/json/shapes/star.json +133 -0
  109. package/docs/json/shapes/stroke.json +78 -0
  110. package/docs/json/shapes/transform.json +102 -0
  111. package/docs/json/shapes/trim.json +61 -0
  112. package/docs/json/sources/chars.json +61 -0
  113. package/docs/json/sources/image.json +31 -0
  114. package/docs/json/sources/precomp.json +39 -0
  115. package/index.d.ts +197 -0
  116. package/package.json +54 -0
  117. package/player/index.html +115 -0
  118. package/player/js/3rd_party/BezierEaser.js +158 -0
  119. package/player/js/3rd_party/howler.js +5 -0
  120. package/player/js/3rd_party/seedrandom.js +237 -0
  121. package/player/js/3rd_party/transformation-matrix.js +449 -0
  122. package/player/js/EffectsManager.js +83 -0
  123. package/player/js/animation/AnimationItem.js +809 -0
  124. package/player/js/animation/AnimationItemWorkerOverride.js +157 -0
  125. package/player/js/animation/AnimationManager.js +248 -0
  126. package/player/js/animation/AnimationManagerWorkerOverride.js +201 -0
  127. package/player/js/effects/EffectsManagerPlaceholder.js +5 -0
  128. package/player/js/effects/SliderEffect.js +37 -0
  129. package/player/js/effects/TransformEffect.js +44 -0
  130. package/player/js/elements/AudioElement.js +102 -0
  131. package/player/js/elements/BaseElement.js +78 -0
  132. package/player/js/elements/BaseTextElement.js +4 -0
  133. package/player/js/elements/CompElement.js +107 -0
  134. package/player/js/elements/FootageElement.js +47 -0
  135. package/player/js/elements/ImageElement.js +42 -0
  136. package/player/js/elements/NullElement.js +39 -0
  137. package/player/js/elements/ShapeElement.js +76 -0
  138. package/player/js/elements/SolidElement.js +23 -0
  139. package/player/js/elements/TextElement.js +94 -0
  140. package/player/js/elements/canvasElements/CVBaseElement.js +167 -0
  141. package/player/js/elements/canvasElements/CVCompBaseElement.js +11 -0
  142. package/player/js/elements/canvasElements/CVCompElement.js +57 -0
  143. package/player/js/elements/canvasElements/CVContextData.js +239 -0
  144. package/player/js/elements/canvasElements/CVEffects.js +57 -0
  145. package/player/js/elements/canvasElements/CVImageElement.js +58 -0
  146. package/player/js/elements/canvasElements/CVMaskElement.js +72 -0
  147. package/player/js/elements/canvasElements/CVShapeElement.js +521 -0
  148. package/player/js/elements/canvasElements/CVSolidElement.js +30 -0
  149. package/player/js/elements/canvasElements/CVTextElement.js +244 -0
  150. package/player/js/elements/canvasElements/effects/CVGaussianBlurEffect.js +29 -0
  151. package/player/js/elements/canvasElements/effects/CVTransformEffect.js +9 -0
  152. package/player/js/elements/helpers/FrameElement.js +54 -0
  153. package/player/js/elements/helpers/HierarchyElement.js +52 -0
  154. package/player/js/elements/helpers/RenderableDOMElement.js +72 -0
  155. package/player/js/elements/helpers/RenderableElement.js +87 -0
  156. package/player/js/elements/helpers/TransformElement.js +140 -0
  157. package/player/js/elements/helpers/shapes/CVShapeData.js +33 -0
  158. package/player/js/elements/helpers/shapes/ProcessedElement.js +6 -0
  159. package/player/js/elements/helpers/shapes/SVGElementsRenderer.js +239 -0
  160. package/player/js/elements/helpers/shapes/SVGFillStyleData.js +18 -0
  161. package/player/js/elements/helpers/shapes/SVGGradientFillStyleData.js +100 -0
  162. package/player/js/elements/helpers/shapes/SVGGradientStrokeStyleData.js +20 -0
  163. package/player/js/elements/helpers/shapes/SVGNoStyleData.js +15 -0
  164. package/player/js/elements/helpers/shapes/SVGShapeData.js +28 -0
  165. package/player/js/elements/helpers/shapes/SVGStrokeStyleData.js +21 -0
  166. package/player/js/elements/helpers/shapes/SVGStyleData.js +19 -0
  167. package/player/js/elements/helpers/shapes/SVGTransformData.js +11 -0
  168. package/player/js/elements/helpers/shapes/ShapeElement.js +5 -0
  169. package/player/js/elements/helpers/shapes/ShapeGroupData.js +9 -0
  170. package/player/js/elements/helpers/shapes/ShapeTransformManager.js +61 -0
  171. package/player/js/elements/htmlElements/HBaseElement.js +88 -0
  172. package/player/js/elements/htmlElements/HCameraElement.js +170 -0
  173. package/player/js/elements/htmlElements/HCompElement.js +61 -0
  174. package/player/js/elements/htmlElements/HEffects.js +3 -0
  175. package/player/js/elements/htmlElements/HImageElement.js +42 -0
  176. package/player/js/elements/htmlElements/HShapeElement.js +261 -0
  177. package/player/js/elements/htmlElements/HSolidElement.js +36 -0
  178. package/player/js/elements/htmlElements/HTextElement.js +290 -0
  179. package/player/js/elements/svgElements/SVGBaseElement.js +181 -0
  180. package/player/js/elements/svgElements/SVGCompElement.js +28 -0
  181. package/player/js/elements/svgElements/SVGEffects.js +70 -0
  182. package/player/js/elements/svgElements/SVGEffectsPlaceholder.js +3 -0
  183. package/player/js/elements/svgElements/SVGShapeElement.js +366 -0
  184. package/player/js/elements/svgElements/SVGTextElement.js +322 -0
  185. package/player/js/elements/svgElements/effects/SVGComposableEffect.js +22 -0
  186. package/player/js/elements/svgElements/effects/SVGDropShadowEffect.js +83 -0
  187. package/player/js/elements/svgElements/effects/SVGFillFilter.js +22 -0
  188. package/player/js/elements/svgElements/effects/SVGGaussianBlurEffect.js +44 -0
  189. package/player/js/elements/svgElements/effects/SVGMatte3Effect.js +101 -0
  190. package/player/js/elements/svgElements/effects/SVGProLevelsFilter.js +108 -0
  191. package/player/js/elements/svgElements/effects/SVGStrokeEffect.js +119 -0
  192. package/player/js/elements/svgElements/effects/SVGTintEffect.js +47 -0
  193. package/player/js/elements/svgElements/effects/SVGTransformEffect.js +10 -0
  194. package/player/js/elements/svgElements/effects/SVGTritoneFilter.js +43 -0
  195. package/player/js/main.js +21 -0
  196. package/player/js/mask.js +239 -0
  197. package/player/js/module.js +153 -0
  198. package/player/js/modules/canvas.js +22 -0
  199. package/player/js/modules/canvas_light.js +25 -0
  200. package/player/js/modules/full.js +70 -0
  201. package/player/js/modules/full_worker.js +0 -0
  202. package/player/js/modules/html.js +37 -0
  203. package/player/js/modules/html_light.js +25 -0
  204. package/player/js/modules/main.js +162 -0
  205. package/player/js/modules/svg.js +37 -0
  206. package/player/js/modules/svg_light.js +25 -0
  207. package/player/js/renderers/BaseRenderer.js +187 -0
  208. package/player/js/renderers/CanvasRenderer.js +67 -0
  209. package/player/js/renderers/CanvasRendererBase.js +318 -0
  210. package/player/js/renderers/CanvasRendererWorkerOverride.js +54 -0
  211. package/player/js/renderers/HybridRenderer.js +47 -0
  212. package/player/js/renderers/HybridRendererBase.js +344 -0
  213. package/player/js/renderers/SVGRenderer.js +82 -0
  214. package/player/js/renderers/SVGRendererBase.js +255 -0
  215. package/player/js/renderers/renderersManager.js +29 -0
  216. package/player/js/utils/BaseEvent.js +42 -0
  217. package/player/js/utils/DataManager.js +676 -0
  218. package/player/js/utils/DataManagerWorkerOverrides.js +13 -0
  219. package/player/js/utils/FontManager.js +443 -0
  220. package/player/js/utils/FontManagerWorkerOverride.js +16 -0
  221. package/player/js/utils/PolynomialBezier.js +253 -0
  222. package/player/js/utils/PropertyFactory.js +489 -0
  223. package/player/js/utils/SlotManager.js +17 -0
  224. package/player/js/utils/TransformProperty.js +251 -0
  225. package/player/js/utils/animationFramePolyFill.js +25 -0
  226. package/player/js/utils/asset_loader.js +53 -0
  227. package/player/js/utils/asset_loader_worker_override.js +3 -0
  228. package/player/js/utils/audio/AudioController.js +85 -0
  229. package/player/js/utils/audio/AudioElement.js +6 -0
  230. package/player/js/utils/bez.js +251 -0
  231. package/player/js/utils/common.js +280 -0
  232. package/player/js/utils/expressions/CompInterface.js +28 -0
  233. package/player/js/utils/expressions/EffectInterface.js +111 -0
  234. package/player/js/utils/expressions/ExpressionManager.js +752 -0
  235. package/player/js/utils/expressions/ExpressionPropertyDecorator.js +463 -0
  236. package/player/js/utils/expressions/ExpressionTextPropertyDecorator.js +40 -0
  237. package/player/js/utils/expressions/ExpressionValue.js +61 -0
  238. package/player/js/utils/expressions/ExpressionValueFactory.js +102 -0
  239. package/player/js/utils/expressions/Expressions.js +48 -0
  240. package/player/js/utils/expressions/FootageInterface.js +60 -0
  241. package/player/js/utils/expressions/InterfacesProvider.js +21 -0
  242. package/player/js/utils/expressions/LayerInterface.js +179 -0
  243. package/player/js/utils/expressions/MaskInterface.js +50 -0
  244. package/player/js/utils/expressions/ProjectInterface.js +31 -0
  245. package/player/js/utils/expressions/PropertyGroupFactory.js +13 -0
  246. package/player/js/utils/expressions/PropertyInterface.js +19 -0
  247. package/player/js/utils/expressions/ShapeInterface.js +543 -0
  248. package/player/js/utils/expressions/TextInterface.js +35 -0
  249. package/player/js/utils/expressions/TextSelectorPropertyDecorator.js +44 -0
  250. package/player/js/utils/expressions/TransformInterface.js +126 -0
  251. package/player/js/utils/expressions/expressionHelpers.js +86 -0
  252. package/player/js/utils/expressions/shapes/ShapePathInterface.js +47 -0
  253. package/player/js/utils/featureSupport.js +16 -0
  254. package/player/js/utils/filters.js +32 -0
  255. package/player/js/utils/functionExtensions.js +27 -0
  256. package/player/js/utils/getFontProperties.js +42 -0
  257. package/player/js/utils/helpers/arrays.js +43 -0
  258. package/player/js/utils/helpers/assetManager.js +96 -0
  259. package/player/js/utils/helpers/blendModes.js +26 -0
  260. package/player/js/utils/helpers/bufferManager.js +61 -0
  261. package/player/js/utils/helpers/dynamicProperties.js +29 -0
  262. package/player/js/utils/helpers/effectTypes.js +3 -0
  263. package/player/js/utils/helpers/html_elements.js +6 -0
  264. package/player/js/utils/helpers/propTypes.js +3 -0
  265. package/player/js/utils/helpers/shapeEnums.js +16 -0
  266. package/player/js/utils/helpers/svg_elements.js +8 -0
  267. package/player/js/utils/imagePreloader.js +213 -0
  268. package/player/js/utils/imagePreloaderWorkerOverride.js +3 -0
  269. package/player/js/utils/markers/markerParser.js +47 -0
  270. package/player/js/utils/pooling/bezier_length_pool.js +20 -0
  271. package/player/js/utils/pooling/point_pool.js +13 -0
  272. package/player/js/utils/pooling/pool_factory.js +44 -0
  273. package/player/js/utils/pooling/pooling.js +15 -0
  274. package/player/js/utils/pooling/segments_length_pool.js +24 -0
  275. package/player/js/utils/pooling/shapeCollection_pool.js +48 -0
  276. package/player/js/utils/pooling/shape_pool.js +44 -0
  277. package/player/js/utils/shapes/DashProperty.js +63 -0
  278. package/player/js/utils/shapes/GradientProperty.js +93 -0
  279. package/player/js/utils/shapes/MouseModifier.js +222 -0
  280. package/player/js/utils/shapes/OffsetPathModifier.js +306 -0
  281. package/player/js/utils/shapes/PuckerAndBloatModifier.js +80 -0
  282. package/player/js/utils/shapes/RepeaterModifier.js +232 -0
  283. package/player/js/utils/shapes/RoundCornersModifier.js +122 -0
  284. package/player/js/utils/shapes/ShapeCollection.js +29 -0
  285. package/player/js/utils/shapes/ShapeModifiers.js +71 -0
  286. package/player/js/utils/shapes/ShapePath.js +100 -0
  287. package/player/js/utils/shapes/ShapeProperty.js +546 -0
  288. package/player/js/utils/shapes/TrimModifier.js +359 -0
  289. package/player/js/utils/shapes/ZigZagModifier.js +174 -0
  290. package/player/js/utils/shapes/shapePathBuilder.js +20 -0
  291. package/player/js/utils/text/LetterProps.js +60 -0
  292. package/player/js/utils/text/TextAnimatorDataProperty.js +34 -0
  293. package/player/js/utils/text/TextAnimatorProperty.js +610 -0
  294. package/player/js/utils/text/TextProperty.js +461 -0
  295. package/player/js/utils/text/TextSelectorProperty.js +179 -0
  296. package/player/js/worker_wrapper.js +1029 -0
  297. package/rollup.config.js +215 -0
  298. package/tasks/build.js +773 -0
  299. package/tasks/build_worker.js +164 -0
  300. package/tasks/watch.js +34 -0
@@ -0,0 +1,318 @@
1
+ import {
2
+ extendPrototype,
3
+ } from '../utils/functionExtensions';
4
+ import {
5
+ createSizedArray,
6
+ } from '../utils/helpers/arrays';
7
+ import createTag from '../utils/helpers/html_elements';
8
+ import SVGRenderer from './SVGRenderer';
9
+ import BaseRenderer from './BaseRenderer';
10
+ import CVShapeElement from '../elements/canvasElements/CVShapeElement';
11
+ import CVTextElement from '../elements/canvasElements/CVTextElement';
12
+ import CVImageElement from '../elements/canvasElements/CVImageElement';
13
+ import CVSolidElement from '../elements/canvasElements/CVSolidElement';
14
+
15
+ function CanvasRendererBase() {
16
+ }
17
+ extendPrototype([BaseRenderer], CanvasRendererBase);
18
+
19
+ CanvasRendererBase.prototype.createShape = function (data) {
20
+ return new CVShapeElement(data, this.globalData, this);
21
+ };
22
+
23
+ CanvasRendererBase.prototype.createText = function (data) {
24
+ return new CVTextElement(data, this.globalData, this);
25
+ };
26
+
27
+ CanvasRendererBase.prototype.createImage = function (data) {
28
+ return new CVImageElement(data, this.globalData, this);
29
+ };
30
+
31
+ CanvasRendererBase.prototype.createSolid = function (data) {
32
+ return new CVSolidElement(data, this.globalData, this);
33
+ };
34
+
35
+ CanvasRendererBase.prototype.createNull = SVGRenderer.prototype.createNull;
36
+
37
+ CanvasRendererBase.prototype.ctxTransform = function (props) {
38
+ if (props[0] === 1 && props[1] === 0 && props[4] === 0 && props[5] === 1 && props[12] === 0 && props[13] === 0) {
39
+ return;
40
+ }
41
+ this.canvasContext.transform(props[0], props[1], props[4], props[5], props[12], props[13]);
42
+ };
43
+
44
+ CanvasRendererBase.prototype.ctxOpacity = function (op) {
45
+ this.canvasContext.globalAlpha *= op < 0 ? 0 : op;
46
+ };
47
+
48
+ CanvasRendererBase.prototype.ctxFillStyle = function (value) {
49
+ this.canvasContext.fillStyle = value;
50
+ };
51
+
52
+ CanvasRendererBase.prototype.ctxStrokeStyle = function (value) {
53
+ this.canvasContext.strokeStyle = value;
54
+ };
55
+
56
+ CanvasRendererBase.prototype.ctxLineWidth = function (value) {
57
+ this.canvasContext.lineWidth = value;
58
+ };
59
+
60
+ CanvasRendererBase.prototype.ctxLineCap = function (value) {
61
+ this.canvasContext.lineCap = value;
62
+ };
63
+
64
+ CanvasRendererBase.prototype.ctxLineJoin = function (value) {
65
+ this.canvasContext.lineJoin = value;
66
+ };
67
+
68
+ CanvasRendererBase.prototype.ctxMiterLimit = function (value) {
69
+ this.canvasContext.miterLimit = value;
70
+ };
71
+
72
+ CanvasRendererBase.prototype.ctxFill = function (rule) {
73
+ this.canvasContext.fill(rule);
74
+ };
75
+
76
+ CanvasRendererBase.prototype.ctxFillRect = function (x, y, w, h) {
77
+ this.canvasContext.fillRect(x, y, w, h);
78
+ };
79
+
80
+ CanvasRendererBase.prototype.ctxStroke = function () {
81
+ this.canvasContext.stroke();
82
+ };
83
+
84
+ CanvasRendererBase.prototype.reset = function () {
85
+ if (!this.renderConfig.clearCanvas) {
86
+ this.canvasContext.restore();
87
+ return;
88
+ }
89
+ this.contextData.reset();
90
+ };
91
+
92
+ CanvasRendererBase.prototype.save = function () {
93
+ this.canvasContext.save();
94
+ };
95
+
96
+ CanvasRendererBase.prototype.restore = function (actionFlag) {
97
+ if (!this.renderConfig.clearCanvas) {
98
+ this.canvasContext.restore();
99
+ return;
100
+ }
101
+ if (actionFlag) {
102
+ this.globalData.blendMode = 'source-over';
103
+ }
104
+ this.contextData.restore(actionFlag);
105
+ };
106
+
107
+ CanvasRendererBase.prototype.configAnimation = function (animData) {
108
+ if (this.animationItem.wrapper) {
109
+ this.animationItem.container = createTag('canvas');
110
+ var containerStyle = this.animationItem.container.style;
111
+ containerStyle.width = '100%';
112
+ containerStyle.height = '100%';
113
+ var origin = '0px 0px 0px';
114
+ containerStyle.transformOrigin = origin;
115
+ containerStyle.mozTransformOrigin = origin;
116
+ containerStyle.webkitTransformOrigin = origin;
117
+ containerStyle['-webkit-transform'] = origin;
118
+ containerStyle.contentVisibility = this.renderConfig.contentVisibility;
119
+ this.animationItem.wrapper.appendChild(this.animationItem.container);
120
+ this.canvasContext = this.animationItem.container.getContext('2d');
121
+ if (this.renderConfig.className) {
122
+ this.animationItem.container.setAttribute('class', this.renderConfig.className);
123
+ }
124
+ if (this.renderConfig.id) {
125
+ this.animationItem.container.setAttribute('id', this.renderConfig.id);
126
+ }
127
+ } else {
128
+ this.canvasContext = this.renderConfig.context;
129
+ }
130
+ this.contextData.setContext(this.canvasContext);
131
+ this.data = animData;
132
+ this.layers = animData.layers;
133
+ this.transformCanvas = {
134
+ w: animData.w,
135
+ h: animData.h,
136
+ sx: 0,
137
+ sy: 0,
138
+ tx: 0,
139
+ ty: 0,
140
+ };
141
+ this.setupGlobalData(animData, document.body);
142
+ this.globalData.canvasContext = this.canvasContext;
143
+ this.globalData.renderer = this;
144
+ this.globalData.isDashed = false;
145
+ this.globalData.progressiveLoad = this.renderConfig.progressiveLoad;
146
+ this.globalData.transformCanvas = this.transformCanvas;
147
+ this.elements = createSizedArray(animData.layers.length);
148
+
149
+ this.updateContainerSize();
150
+ };
151
+
152
+ CanvasRendererBase.prototype.updateContainerSize = function (width, height) {
153
+ this.reset();
154
+ var elementWidth;
155
+ var elementHeight;
156
+ if (width) {
157
+ elementWidth = width;
158
+ elementHeight = height;
159
+ this.canvasContext.canvas.width = elementWidth;
160
+ this.canvasContext.canvas.height = elementHeight;
161
+ } else {
162
+ if (this.animationItem.wrapper && this.animationItem.container) {
163
+ elementWidth = this.animationItem.wrapper.offsetWidth;
164
+ elementHeight = this.animationItem.wrapper.offsetHeight;
165
+ } else {
166
+ elementWidth = this.canvasContext.canvas.width;
167
+ elementHeight = this.canvasContext.canvas.height;
168
+ }
169
+ this.canvasContext.canvas.width = elementWidth * this.renderConfig.dpr;
170
+ this.canvasContext.canvas.height = elementHeight * this.renderConfig.dpr;
171
+ }
172
+
173
+ var elementRel;
174
+ var animationRel;
175
+ if (this.renderConfig.preserveAspectRatio.indexOf('meet') !== -1 || this.renderConfig.preserveAspectRatio.indexOf('slice') !== -1) {
176
+ var par = this.renderConfig.preserveAspectRatio.split(' ');
177
+ var fillType = par[1] || 'meet';
178
+ var pos = par[0] || 'xMidYMid';
179
+ var xPos = pos.substr(0, 4);
180
+ var yPos = pos.substr(4);
181
+ elementRel = elementWidth / elementHeight;
182
+ animationRel = this.transformCanvas.w / this.transformCanvas.h;
183
+ if ((animationRel > elementRel && fillType === 'meet') || (animationRel < elementRel && fillType === 'slice')) {
184
+ this.transformCanvas.sx = elementWidth / (this.transformCanvas.w / this.renderConfig.dpr);
185
+ this.transformCanvas.sy = elementWidth / (this.transformCanvas.w / this.renderConfig.dpr);
186
+ } else {
187
+ this.transformCanvas.sx = elementHeight / (this.transformCanvas.h / this.renderConfig.dpr);
188
+ this.transformCanvas.sy = elementHeight / (this.transformCanvas.h / this.renderConfig.dpr);
189
+ }
190
+
191
+ if (xPos === 'xMid' && ((animationRel < elementRel && fillType === 'meet') || (animationRel > elementRel && fillType === 'slice'))) {
192
+ this.transformCanvas.tx = ((elementWidth - this.transformCanvas.w * (elementHeight / this.transformCanvas.h)) / 2) * this.renderConfig.dpr;
193
+ } else if (xPos === 'xMax' && ((animationRel < elementRel && fillType === 'meet') || (animationRel > elementRel && fillType === 'slice'))) {
194
+ this.transformCanvas.tx = (elementWidth - this.transformCanvas.w * (elementHeight / this.transformCanvas.h)) * this.renderConfig.dpr;
195
+ } else {
196
+ this.transformCanvas.tx = 0;
197
+ }
198
+ if (yPos === 'YMid' && ((animationRel > elementRel && fillType === 'meet') || (animationRel < elementRel && fillType === 'slice'))) {
199
+ this.transformCanvas.ty = ((elementHeight - this.transformCanvas.h * (elementWidth / this.transformCanvas.w)) / 2) * this.renderConfig.dpr;
200
+ } else if (yPos === 'YMax' && ((animationRel > elementRel && fillType === 'meet') || (animationRel < elementRel && fillType === 'slice'))) {
201
+ this.transformCanvas.ty = ((elementHeight - this.transformCanvas.h * (elementWidth / this.transformCanvas.w))) * this.renderConfig.dpr;
202
+ } else {
203
+ this.transformCanvas.ty = 0;
204
+ }
205
+ } else if (this.renderConfig.preserveAspectRatio === 'none') {
206
+ this.transformCanvas.sx = elementWidth / (this.transformCanvas.w / this.renderConfig.dpr);
207
+ this.transformCanvas.sy = elementHeight / (this.transformCanvas.h / this.renderConfig.dpr);
208
+ this.transformCanvas.tx = 0;
209
+ this.transformCanvas.ty = 0;
210
+ } else {
211
+ this.transformCanvas.sx = this.renderConfig.dpr;
212
+ this.transformCanvas.sy = this.renderConfig.dpr;
213
+ this.transformCanvas.tx = 0;
214
+ this.transformCanvas.ty = 0;
215
+ }
216
+ this.transformCanvas.props = [this.transformCanvas.sx, 0, 0, 0, 0, this.transformCanvas.sy, 0, 0, 0, 0, 1, 0, this.transformCanvas.tx, this.transformCanvas.ty, 0, 1];
217
+ /* var i, len = this.elements.length;
218
+ for(i=0;i<len;i+=1){
219
+ if(this.elements[i] && this.elements[i].data.ty === 0){
220
+ this.elements[i].resize(this.globalData.transformCanvas);
221
+ }
222
+ } */
223
+ this.ctxTransform(this.transformCanvas.props);
224
+ this.canvasContext.beginPath();
225
+ this.canvasContext.rect(0, 0, this.transformCanvas.w, this.transformCanvas.h);
226
+ this.canvasContext.closePath();
227
+ this.canvasContext.clip();
228
+
229
+ this.renderFrame(this.renderedFrame, true);
230
+ };
231
+
232
+ CanvasRendererBase.prototype.destroy = function () {
233
+ if (this.renderConfig.clearCanvas && this.animationItem.wrapper) {
234
+ this.animationItem.wrapper.innerText = '';
235
+ }
236
+ var i;
237
+ var len = this.layers ? this.layers.length : 0;
238
+ for (i = len - 1; i >= 0; i -= 1) {
239
+ if (this.elements[i] && this.elements[i].destroy) {
240
+ this.elements[i].destroy();
241
+ }
242
+ }
243
+ this.elements.length = 0;
244
+ this.globalData.canvasContext = null;
245
+ this.animationItem.container = null;
246
+ this.destroyed = true;
247
+ };
248
+
249
+ CanvasRendererBase.prototype.renderFrame = function (num, forceRender) {
250
+ if ((this.renderedFrame === num && this.renderConfig.clearCanvas === true && !forceRender) || this.destroyed || num === -1) {
251
+ return;
252
+ }
253
+ this.renderedFrame = num;
254
+ this.globalData.frameNum = num - this.animationItem._isFirstFrame;
255
+ this.globalData.frameId += 1;
256
+ this.globalData._mdf = !this.renderConfig.clearCanvas || forceRender;
257
+ this.globalData.projectInterface.currentFrame = num;
258
+
259
+ // console.log('--------');
260
+ // console.log('NEW: ',num);
261
+ var i;
262
+ var len = this.layers.length;
263
+ if (!this.completeLayers) {
264
+ this.checkLayers(num);
265
+ }
266
+
267
+ for (i = len - 1; i >= 0; i -= 1) {
268
+ if (this.completeLayers || this.elements[i]) {
269
+ this.elements[i].prepareFrame(num - this.layers[i].st);
270
+ }
271
+ }
272
+ if (this.globalData._mdf) {
273
+ if (this.renderConfig.clearCanvas === true) {
274
+ this.canvasContext.clearRect(0, 0, this.transformCanvas.w, this.transformCanvas.h);
275
+ } else {
276
+ this.save();
277
+ }
278
+ for (i = len - 1; i >= 0; i -= 1) {
279
+ if (this.completeLayers || this.elements[i]) {
280
+ this.elements[i].renderFrame();
281
+ }
282
+ }
283
+ if (this.renderConfig.clearCanvas !== true) {
284
+ this.restore();
285
+ }
286
+ }
287
+ this.renderConfig.bufferManager.releaseAll();
288
+ };
289
+
290
+ CanvasRendererBase.prototype.buildItem = function (pos) {
291
+ var elements = this.elements;
292
+ if (elements[pos] || this.layers[pos].ty === 99) {
293
+ return;
294
+ }
295
+ var element = this.createItem(this.layers[pos], this, this.globalData);
296
+ elements[pos] = element;
297
+ element.initExpressions();
298
+ /* if(this.layers[pos].ty === 0){
299
+ element.resize(this.globalData.transformCanvas);
300
+ } */
301
+ };
302
+
303
+ CanvasRendererBase.prototype.checkPendingElements = function () {
304
+ while (this.pendingElements.length) {
305
+ var element = this.pendingElements.pop();
306
+ element.checkParenting();
307
+ }
308
+ };
309
+
310
+ CanvasRendererBase.prototype.hide = function () {
311
+ this.animationItem.container.style.display = 'none';
312
+ };
313
+
314
+ CanvasRendererBase.prototype.show = function () {
315
+ this.animationItem.container.style.display = 'block';
316
+ };
317
+
318
+ export default CanvasRendererBase;
@@ -0,0 +1,54 @@
1
+ import {
2
+ createSizedArray,
3
+ } from '../utils/helpers/arrays';
4
+ import CanvasRenderer from './CanvasRenderer';
5
+ import createTag from '../utils/helpers/html_elements';
6
+
7
+ CanvasRenderer.prototype.configAnimation = function (animData) {
8
+ if (this.animationItem.wrapper) {
9
+ this.animationItem.container = createTag('canvas');
10
+ var containerStyle = this.animationItem.container.style;
11
+ containerStyle.width = '100%';
12
+ containerStyle.height = '100%';
13
+ var origin = '0px 0px 0px';
14
+ containerStyle.transformOrigin = origin;
15
+ containerStyle.mozTransformOrigin = origin;
16
+ containerStyle.webkitTransformOrigin = origin;
17
+ containerStyle['-webkit-transform'] = origin;
18
+ this.animationItem.wrapper.appendChild(this.animationItem.container);
19
+ this.canvasContext = this.animationItem.container.getContext('2d');
20
+ if (this.renderConfig.className) {
21
+ this.animationItem.container.setAttribute('class', this.renderConfig.className);
22
+ }
23
+ } else {
24
+ this.canvasContext = this.renderConfig.context;
25
+ }
26
+ this.data = animData;
27
+ this.layers = animData.layers;
28
+ this.transformCanvas = {
29
+ w: animData.w,
30
+ h: animData.h,
31
+ sx: 0,
32
+ sy: 0,
33
+ tx: 0,
34
+ ty: 0,
35
+ };
36
+ this.globalData.frameId = 0;
37
+ this.globalData.frameRate = animData.fr;
38
+ this.globalData.nm = animData.nm;
39
+ this.globalData.compSize = {
40
+ w: animData.w,
41
+ h: animData.h,
42
+ };
43
+ this.globalData.canvasContext = this.canvasContext;
44
+ this.globalData.renderer = this;
45
+ this.globalData.isDashed = false;
46
+ this.globalData.progressiveLoad = this.renderConfig.progressiveLoad;
47
+ this.globalData.transformCanvas = this.transformCanvas;
48
+ this.elements = createSizedArray(animData.layers.length);
49
+
50
+ this.updateContainerSize();
51
+ };
52
+
53
+ // TODO: review export
54
+ export default CanvasRenderer;
@@ -0,0 +1,47 @@
1
+ import {
2
+ extendPrototype,
3
+ } from '../utils/functionExtensions';
4
+ import HybridRendererBase from './HybridRendererBase';
5
+ import HCompElement from '../elements/htmlElements/HCompElement';
6
+ import SVGCompElement from '../elements/svgElements/SVGCompElement';
7
+
8
+ function HybridRenderer(animationItem, config) {
9
+ this.animationItem = animationItem;
10
+ this.layers = null;
11
+ this.renderedFrame = -1;
12
+ this.renderConfig = {
13
+ className: (config && config.className) || '',
14
+ imagePreserveAspectRatio: (config && config.imagePreserveAspectRatio) || 'xMidYMid slice',
15
+ hideOnTransparent: !(config && config.hideOnTransparent === false),
16
+ filterSize: {
17
+ width: (config && config.filterSize && config.filterSize.width) || '400%',
18
+ height: (config && config.filterSize && config.filterSize.height) || '400%',
19
+ x: (config && config.filterSize && config.filterSize.x) || '-100%',
20
+ y: (config && config.filterSize && config.filterSize.y) || '-100%',
21
+ },
22
+ runExpressions: !config || config.runExpressions === undefined || config.runExpressions,
23
+ };
24
+ this.globalData = {
25
+ _mdf: false,
26
+ frameNum: -1,
27
+ renderConfig: this.renderConfig,
28
+ };
29
+ this.pendingElements = [];
30
+ this.elements = [];
31
+ this.threeDElements = [];
32
+ this.destroyed = false;
33
+ this.camera = null;
34
+ this.supports3d = true;
35
+ this.rendererType = 'html';
36
+ }
37
+
38
+ extendPrototype([HybridRendererBase], HybridRenderer);
39
+
40
+ HybridRenderer.prototype.createComp = function (data) {
41
+ if (!this.supports3d) {
42
+ return new SVGCompElement(data, this.globalData, this);
43
+ }
44
+ return new HCompElement(data, this.globalData, this);
45
+ };
46
+
47
+ export default HybridRenderer;