@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,167 @@
1
+ import assetManager from '../../utils/helpers/assetManager';
2
+ import getBlendMode from '../../utils/helpers/blendModes';
3
+ import Matrix from '../../3rd_party/transformation-matrix';
4
+ import CVEffects from './CVEffects';
5
+ import CVMaskElement from './CVMaskElement';
6
+ import effectTypes from '../../utils/helpers/effectTypes';
7
+
8
+ function CVBaseElement() {
9
+ }
10
+
11
+ var operationsMap = {
12
+ 1: 'source-in',
13
+ 2: 'source-out',
14
+ 3: 'source-in',
15
+ 4: 'source-out',
16
+ };
17
+
18
+ CVBaseElement.prototype = {
19
+ createElements: function () {},
20
+ initRendererElement: function () {},
21
+ createContainerElements: function () {
22
+ // If the layer is masked we will use two buffers to store each different states of the drawing
23
+ // This solution is not ideal for several reason. But unfortunately, because of the recursive
24
+ // nature of the render tree, it's the only simple way to make sure one inner mask doesn't override an outer mask.
25
+ // TODO: try to reduce the size of these buffers to the size of the composition contaning the layer
26
+ // It might be challenging because the layer most likely is transformed in some way
27
+ if (this.data.tt >= 1) {
28
+ if (this.data.tt >= 3 && !document._isProxy) {
29
+ assetManager.loadLumaCanvas();
30
+ }
31
+ }
32
+ this.canvasContext = this.globalData.canvasContext;
33
+ this.transformCanvas = this.globalData.transformCanvas;
34
+ this.renderableEffectsManager = new CVEffects(this);
35
+ this.searchEffectTransforms();
36
+ },
37
+ createContent: function () {},
38
+ setBlendMode: function () {
39
+ var globalData = this.globalData;
40
+ if (globalData.blendMode !== this.data.bm) {
41
+ globalData.blendMode = this.data.bm;
42
+ var blendModeValue = getBlendMode(this.data.bm);
43
+ globalData.canvasContext.globalCompositeOperation = blendModeValue;
44
+ }
45
+ },
46
+ createRenderableComponents: function () {
47
+ this.maskManager = new CVMaskElement(this.data, this);
48
+ this.transformEffects = this.renderableEffectsManager.getEffects(effectTypes.TRANSFORM_EFFECT);
49
+ },
50
+ hideElement: function () {
51
+ if (!this.hidden && (!this.isInRange || this.isTransparent)) {
52
+ this.hidden = true;
53
+ }
54
+ },
55
+ showElement: function () {
56
+ if (this.isInRange && !this.isTransparent) {
57
+ this.hidden = false;
58
+ this._isFirstFrame = true;
59
+ this.maskManager._isFirstFrame = true;
60
+ }
61
+ },
62
+ clearCanvas: function (canvasContext) {
63
+ canvasContext.clearRect(
64
+ this.transformCanvas.tx,
65
+ this.transformCanvas.ty,
66
+ this.transformCanvas.w * this.transformCanvas.sx,
67
+ this.transformCanvas.h * this.transformCanvas.sy
68
+ );
69
+ },
70
+ prepareLayer: function () {
71
+ if (this.data.tt >= 1) {
72
+ this.globalDrawingBufferCanvas = this.globalData.renderConfig.bufferManager.allocate(this.canvasContext.canvas.width, this.canvasContext.canvas.height);
73
+ var globalDrawingBufferCanvasCtx = this.globalDrawingBufferCanvas.getContext('2d');
74
+ this.clearCanvas(globalDrawingBufferCanvasCtx);
75
+ // on the first buffer we store the current state of the global drawing
76
+ globalDrawingBufferCanvasCtx.drawImage(this.canvasContext.canvas, 0, 0);
77
+ // The next four lines are to clear the canvas
78
+ // TODO: Check if there is a way to clear the canvas without resetting the transform
79
+ this.currentTransform = this.canvasContext.getTransform();
80
+ this.canvasContext.setTransform(1, 0, 0, 1, 0, 0);
81
+ this.clearCanvas(this.canvasContext);
82
+ this.canvasContext.setTransform(this.currentTransform);
83
+ }
84
+ },
85
+ exitLayer: function () {
86
+ if (this.data.tt >= 1) {
87
+ var contentOfCurrentLayerCanvas = this.globalData.renderConfig.bufferManager.allocate(this.canvasContext.canvas.width, this.canvasContext.canvas.height);
88
+ // On the second buffer we store the current state of the global drawing
89
+ // that only contains the content of this layer
90
+ // (if it is a composition, it also includes the nested layers)
91
+ var contentOfCurrentLayerCanvasCtx = contentOfCurrentLayerCanvas.getContext('2d');
92
+ this.clearCanvas(contentOfCurrentLayerCanvasCtx);
93
+ contentOfCurrentLayerCanvasCtx.drawImage(this.canvasContext.canvas, 0, 0);
94
+ // We clear the canvas again
95
+ this.canvasContext.setTransform(1, 0, 0, 1, 0, 0);
96
+ this.clearCanvas(this.canvasContext);
97
+ this.canvasContext.setTransform(this.currentTransform);
98
+ // We draw the mask
99
+ const mask = this.comp.getElementById('tp' in this.data ? this.data.tp : this.data.ind - 1);
100
+ mask.renderFrame(true);
101
+ // We draw the second buffer (that contains the content of this layer)
102
+ this.canvasContext.setTransform(1, 0, 0, 1, 0, 0);
103
+
104
+ // If the mask is a Luma matte, we need to do two extra painting operations
105
+ // the _isProxy check is to avoid drawing a fake canvas in workers that will throw an error
106
+ if (this.data.tt >= 3 && !document._isProxy) {
107
+ // We copy the painted mask to a buffer that has a color matrix filter applied to it
108
+ // that applies the rgb values to the alpha channel
109
+ var lumaBuffer = assetManager.getLumaCanvas(this.canvasContext.canvas);
110
+ var lumaBufferCtx = lumaBuffer.getContext('2d');
111
+ lumaBufferCtx.drawImage(this.canvasContext.canvas, 0, 0);
112
+ this.clearCanvas(this.canvasContext);
113
+ // we repaint the context with the mask applied to it
114
+ this.canvasContext.drawImage(lumaBuffer, 0, 0);
115
+ }
116
+ this.canvasContext.globalCompositeOperation = operationsMap[this.data.tt];
117
+ this.canvasContext.drawImage(contentOfCurrentLayerCanvas, 0, 0);
118
+ // We finally draw the first buffer (that contains the content of the global drawing)
119
+ // We use destination-over to draw the global drawing below the current layer
120
+ this.canvasContext.globalCompositeOperation = 'destination-over';
121
+ this.canvasContext.drawImage(this.globalDrawingBufferCanvas, 0, 0);
122
+ this.canvasContext.setTransform(this.currentTransform);
123
+ // We reset the globalCompositeOperation to source-over, the standard type of operation
124
+ this.canvasContext.globalCompositeOperation = 'source-over';
125
+
126
+ this.globalData.renderConfig.bufferManager.release(this.globalDrawingBufferCanvas);
127
+ this.globalData.renderConfig.bufferManager.release(contentOfCurrentLayerCanvas);
128
+ }
129
+ },
130
+ renderFrame: function (forceRender) {
131
+ if (this.hidden || this.data.hd) {
132
+ return;
133
+ }
134
+ if (this.data.td === 1 && !forceRender) {
135
+ return;
136
+ }
137
+ this.renderTransform();
138
+ this.renderRenderable();
139
+ this.renderLocalTransform();
140
+ this.setBlendMode();
141
+ var forceRealStack = this.data.ty === 0;
142
+ this.prepareLayer();
143
+ this.globalData.renderer.save(forceRealStack);
144
+ this.globalData.renderer.ctxTransform(this.finalTransform.localMat.props);
145
+ this.globalData.renderer.ctxOpacity(this.finalTransform.localOpacity);
146
+ this.renderInnerContent();
147
+ this.globalData.renderer.restore(forceRealStack);
148
+ this.exitLayer();
149
+ if (this.maskManager.hasMasks) {
150
+ this.globalData.renderer.restore(true);
151
+ }
152
+ if (this._isFirstFrame) {
153
+ this._isFirstFrame = false;
154
+ }
155
+ },
156
+ destroy: function () {
157
+ this.canvasContext = null;
158
+ this.data = null;
159
+ this.globalData = null;
160
+ this.maskManager.destroy();
161
+ },
162
+ mHelper: new Matrix(),
163
+ };
164
+ CVBaseElement.prototype.hide = CVBaseElement.prototype.hideElement;
165
+ CVBaseElement.prototype.show = CVBaseElement.prototype.showElement;
166
+
167
+ export default CVBaseElement;
@@ -0,0 +1,11 @@
1
+ import BaseRenderer from '../../renderers/BaseRenderer';
2
+ import {
3
+ extendPrototype,
4
+ } from '../../utils/functionExtensions';
5
+
6
+ function CVCompBaseElement() {
7
+
8
+ }
9
+ extendPrototype([BaseRenderer], CVCompBaseElement);
10
+
11
+ export default CVCompBaseElement;
@@ -0,0 +1,57 @@
1
+ import {
2
+ extendPrototype,
3
+ } from '../../utils/functionExtensions';
4
+ import {
5
+ createSizedArray,
6
+ } from '../../utils/helpers/arrays';
7
+ import PropertyFactory from '../../utils/PropertyFactory';
8
+ import CanvasRendererBase from '../../renderers/CanvasRendererBase';
9
+ import CVBaseElement from './CVBaseElement';
10
+ import ICompElement from '../CompElement';
11
+
12
+ function CVCompElement(data, globalData, comp) {
13
+ this.completeLayers = false;
14
+ this.layers = data.layers;
15
+ this.pendingElements = [];
16
+ this.elements = createSizedArray(this.layers.length);
17
+ this.initElement(data, globalData, comp);
18
+ this.tm = data.tm ? PropertyFactory.getProp(this, data.tm, 0, globalData.frameRate, this) : { _placeholder: true };
19
+ }
20
+
21
+ extendPrototype([CanvasRendererBase, ICompElement, CVBaseElement], CVCompElement);
22
+
23
+ CVCompElement.prototype.renderInnerContent = function () {
24
+ var ctx = this.canvasContext;
25
+ ctx.beginPath();
26
+ ctx.moveTo(0, 0);
27
+ ctx.lineTo(this.data.w, 0);
28
+ ctx.lineTo(this.data.w, this.data.h);
29
+ ctx.lineTo(0, this.data.h);
30
+ ctx.lineTo(0, 0);
31
+ ctx.clip();
32
+ var i;
33
+ var len = this.layers.length;
34
+ for (i = len - 1; i >= 0; i -= 1) {
35
+ if (this.completeLayers || this.elements[i]) {
36
+ this.elements[i].renderFrame();
37
+ }
38
+ }
39
+ };
40
+
41
+ CVCompElement.prototype.destroy = function () {
42
+ var i;
43
+ var len = this.layers.length;
44
+ for (i = len - 1; i >= 0; i -= 1) {
45
+ if (this.elements[i]) {
46
+ this.elements[i].destroy();
47
+ }
48
+ }
49
+ this.layers = null;
50
+ this.elements = null;
51
+ };
52
+
53
+ CVCompElement.prototype.createComp = function (data) {
54
+ return new CVCompElement(data, this.globalData, this);
55
+ };
56
+
57
+ export default CVCompElement;
@@ -0,0 +1,239 @@
1
+ import {
2
+ createTypedArray,
3
+ } from '../../utils/helpers/arrays';
4
+ import Matrix from '../../3rd_party/transformation-matrix';
5
+
6
+ function CanvasContext() {
7
+ this.opacity = -1;
8
+ this.transform = createTypedArray('float32', 16);
9
+ this.fillStyle = '';
10
+ this.strokeStyle = '';
11
+ this.lineWidth = '';
12
+ this.lineCap = '';
13
+ this.lineJoin = '';
14
+ this.miterLimit = '';
15
+ this.id = Math.random();
16
+ }
17
+
18
+ function CVContextData() {
19
+ this.stack = [];
20
+ this.cArrPos = 0;
21
+ this.cTr = new Matrix();
22
+ var i;
23
+ var len = 15;
24
+ for (i = 0; i < len; i += 1) {
25
+ var canvasContext = new CanvasContext();
26
+ this.stack[i] = canvasContext;
27
+ }
28
+ this._length = len;
29
+ this.nativeContext = null;
30
+ this.transformMat = new Matrix();
31
+ this.currentOpacity = 1;
32
+ //
33
+ this.currentFillStyle = '';
34
+ this.appliedFillStyle = '';
35
+ //
36
+ this.currentStrokeStyle = '';
37
+ this.appliedStrokeStyle = '';
38
+ //
39
+ this.currentLineWidth = '';
40
+ this.appliedLineWidth = '';
41
+ //
42
+ this.currentLineCap = '';
43
+ this.appliedLineCap = '';
44
+ //
45
+ this.currentLineJoin = '';
46
+ this.appliedLineJoin = '';
47
+ //
48
+ this.appliedMiterLimit = '';
49
+ this.currentMiterLimit = '';
50
+ }
51
+
52
+ CVContextData.prototype.duplicate = function () {
53
+ var newLength = this._length * 2;
54
+ var i = 0;
55
+ for (i = this._length; i < newLength; i += 1) {
56
+ this.stack[i] = new CanvasContext();
57
+ }
58
+ this._length = newLength;
59
+ };
60
+
61
+ CVContextData.prototype.reset = function () {
62
+ this.cArrPos = 0;
63
+ this.cTr.reset();
64
+ this.stack[this.cArrPos].opacity = 1;
65
+ };
66
+
67
+ CVContextData.prototype.restore = function (forceRestore) {
68
+ this.cArrPos -= 1;
69
+ var currentContext = this.stack[this.cArrPos];
70
+ var transform = currentContext.transform;
71
+ var i;
72
+ var arr = this.cTr.props;
73
+ for (i = 0; i < 16; i += 1) {
74
+ arr[i] = transform[i];
75
+ }
76
+ if (forceRestore) {
77
+ this.nativeContext.restore();
78
+ var prevStack = this.stack[this.cArrPos + 1];
79
+ this.appliedFillStyle = prevStack.fillStyle;
80
+ this.appliedStrokeStyle = prevStack.strokeStyle;
81
+ this.appliedLineWidth = prevStack.lineWidth;
82
+ this.appliedLineCap = prevStack.lineCap;
83
+ this.appliedLineJoin = prevStack.lineJoin;
84
+ this.appliedMiterLimit = prevStack.miterLimit;
85
+ }
86
+ this.nativeContext.setTransform(transform[0], transform[1], transform[4], transform[5], transform[12], transform[13]);
87
+ if (forceRestore || (currentContext.opacity !== -1 && this.currentOpacity !== currentContext.opacity)) {
88
+ this.nativeContext.globalAlpha = currentContext.opacity;
89
+ this.currentOpacity = currentContext.opacity;
90
+ }
91
+ this.currentFillStyle = currentContext.fillStyle;
92
+ this.currentStrokeStyle = currentContext.strokeStyle;
93
+ this.currentLineWidth = currentContext.lineWidth;
94
+ this.currentLineCap = currentContext.lineCap;
95
+ this.currentLineJoin = currentContext.lineJoin;
96
+ this.currentMiterLimit = currentContext.miterLimit;
97
+ };
98
+
99
+ CVContextData.prototype.save = function (saveOnNativeFlag) {
100
+ if (saveOnNativeFlag) {
101
+ this.nativeContext.save();
102
+ }
103
+ var props = this.cTr.props;
104
+ if (this._length <= this.cArrPos) {
105
+ this.duplicate();
106
+ }
107
+
108
+ var currentStack = this.stack[this.cArrPos];
109
+ var i;
110
+ for (i = 0; i < 16; i += 1) {
111
+ currentStack.transform[i] = props[i];
112
+ }
113
+ this.cArrPos += 1;
114
+ var newStack = this.stack[this.cArrPos];
115
+ newStack.opacity = currentStack.opacity;
116
+ newStack.fillStyle = currentStack.fillStyle;
117
+ newStack.strokeStyle = currentStack.strokeStyle;
118
+ newStack.lineWidth = currentStack.lineWidth;
119
+ newStack.lineCap = currentStack.lineCap;
120
+ newStack.lineJoin = currentStack.lineJoin;
121
+ newStack.miterLimit = currentStack.miterLimit;
122
+ };
123
+
124
+ CVContextData.prototype.setOpacity = function (value) {
125
+ this.stack[this.cArrPos].opacity = value;
126
+ };
127
+
128
+ CVContextData.prototype.setContext = function (value) {
129
+ this.nativeContext = value;
130
+ };
131
+
132
+ CVContextData.prototype.fillStyle = function (value) {
133
+ if (this.stack[this.cArrPos].fillStyle !== value) {
134
+ this.currentFillStyle = value;
135
+ this.stack[this.cArrPos].fillStyle = value;
136
+ }
137
+ };
138
+
139
+ CVContextData.prototype.strokeStyle = function (value) {
140
+ if (this.stack[this.cArrPos].strokeStyle !== value) {
141
+ this.currentStrokeStyle = value;
142
+ this.stack[this.cArrPos].strokeStyle = value;
143
+ }
144
+ };
145
+
146
+ CVContextData.prototype.lineWidth = function (value) {
147
+ if (this.stack[this.cArrPos].lineWidth !== value) {
148
+ this.currentLineWidth = value;
149
+ this.stack[this.cArrPos].lineWidth = value;
150
+ }
151
+ };
152
+
153
+ CVContextData.prototype.lineCap = function (value) {
154
+ if (this.stack[this.cArrPos].lineCap !== value) {
155
+ this.currentLineCap = value;
156
+ this.stack[this.cArrPos].lineCap = value;
157
+ }
158
+ };
159
+
160
+ CVContextData.prototype.lineJoin = function (value) {
161
+ if (this.stack[this.cArrPos].lineJoin !== value) {
162
+ this.currentLineJoin = value;
163
+ this.stack[this.cArrPos].lineJoin = value;
164
+ }
165
+ };
166
+
167
+ CVContextData.prototype.miterLimit = function (value) {
168
+ if (this.stack[this.cArrPos].miterLimit !== value) {
169
+ this.currentMiterLimit = value;
170
+ this.stack[this.cArrPos].miterLimit = value;
171
+ }
172
+ };
173
+
174
+ CVContextData.prototype.transform = function (props) {
175
+ this.transformMat.cloneFromProps(props);
176
+ // Taking the last transform value from the stored stack of transforms
177
+ var currentTransform = this.cTr;
178
+ // Applying the last transform value after the new transform to respect the order of transformations
179
+ this.transformMat.multiply(currentTransform);
180
+ // Storing the new transformed value in the stored transform
181
+ currentTransform.cloneFromProps(this.transformMat.props);
182
+ var trProps = currentTransform.props;
183
+ // Applying the new transform to the canvas
184
+ this.nativeContext.setTransform(trProps[0], trProps[1], trProps[4], trProps[5], trProps[12], trProps[13]);
185
+ };
186
+
187
+ CVContextData.prototype.opacity = function (op) {
188
+ var currentOpacity = this.stack[this.cArrPos].opacity;
189
+ currentOpacity *= op < 0 ? 0 : op;
190
+ if (this.stack[this.cArrPos].opacity !== currentOpacity) {
191
+ if (this.currentOpacity !== op) {
192
+ this.nativeContext.globalAlpha = op;
193
+ this.currentOpacity = op;
194
+ }
195
+ this.stack[this.cArrPos].opacity = currentOpacity;
196
+ }
197
+ };
198
+
199
+ CVContextData.prototype.fill = function (rule) {
200
+ if (this.appliedFillStyle !== this.currentFillStyle) {
201
+ this.appliedFillStyle = this.currentFillStyle;
202
+ this.nativeContext.fillStyle = this.appliedFillStyle;
203
+ }
204
+ this.nativeContext.fill(rule);
205
+ };
206
+
207
+ CVContextData.prototype.fillRect = function (x, y, w, h) {
208
+ if (this.appliedFillStyle !== this.currentFillStyle) {
209
+ this.appliedFillStyle = this.currentFillStyle;
210
+ this.nativeContext.fillStyle = this.appliedFillStyle;
211
+ }
212
+ this.nativeContext.fillRect(x, y, w, h);
213
+ };
214
+
215
+ CVContextData.prototype.stroke = function () {
216
+ if (this.appliedStrokeStyle !== this.currentStrokeStyle) {
217
+ this.appliedStrokeStyle = this.currentStrokeStyle;
218
+ this.nativeContext.strokeStyle = this.appliedStrokeStyle;
219
+ }
220
+ if (this.appliedLineWidth !== this.currentLineWidth) {
221
+ this.appliedLineWidth = this.currentLineWidth;
222
+ this.nativeContext.lineWidth = this.appliedLineWidth;
223
+ }
224
+ if (this.appliedLineCap !== this.currentLineCap) {
225
+ this.appliedLineCap = this.currentLineCap;
226
+ this.nativeContext.lineCap = this.appliedLineCap;
227
+ }
228
+ if (this.appliedLineJoin !== this.currentLineJoin) {
229
+ this.appliedLineJoin = this.currentLineJoin;
230
+ this.nativeContext.lineJoin = this.appliedLineJoin;
231
+ }
232
+ if (this.appliedMiterLimit !== this.currentMiterLimit) {
233
+ this.appliedMiterLimit = this.currentMiterLimit;
234
+ this.nativeContext.miterLimit = this.appliedMiterLimit;
235
+ }
236
+ this.nativeContext.stroke();
237
+ };
238
+
239
+ export default CVContextData;
@@ -0,0 +1,57 @@
1
+ var registeredEffects = {};
2
+
3
+ function CVEffects(elem) {
4
+ var i;
5
+ var len = elem.data.ef ? elem.data.ef.length : 0;
6
+ this.filters = [];
7
+ this.globalData = elem.globalData;
8
+ var filterManager;
9
+ for (i = 0; i < len; i += 1) {
10
+ filterManager = null;
11
+ var type = elem.data.ef[i].ty;
12
+ if (registeredEffects[type]) {
13
+ var Effect = registeredEffects[type].effect;
14
+ filterManager = new Effect(elem.effectsManager.effectElements[i], elem);
15
+ }
16
+ if (filterManager) {
17
+ this.filters.push(filterManager);
18
+ }
19
+ }
20
+ if (this.filters.length) {
21
+ elem.addRenderableComponent(this);
22
+ }
23
+ }
24
+
25
+ CVEffects.prototype.renderFrame = function (_isFirstFrame) {
26
+ var i;
27
+ var len = this.filters.length;
28
+ var canvasContext = this.globalData.canvasContext;
29
+ var filterStrings = [];
30
+ for (i = 0; i < len; i += 1) {
31
+ this.filters[i].renderFrame(_isFirstFrame);
32
+ if (this.filters[i].filterString) {
33
+ filterStrings.push(this.filters[i].filterString);
34
+ }
35
+ }
36
+ canvasContext.filter = filterStrings.length ? filterStrings.join(' ') : 'none';
37
+ };
38
+
39
+ CVEffects.prototype.getEffects = function (type) {
40
+ var i;
41
+ var len = this.filters.length;
42
+ var effects = [];
43
+ for (i = 0; i < len; i += 1) {
44
+ if (this.filters[i].type === type) {
45
+ effects.push(this.filters[i]);
46
+ }
47
+ }
48
+ return effects;
49
+ };
50
+
51
+ export function registerEffect(id, effect) {
52
+ registeredEffects[id] = {
53
+ effect,
54
+ };
55
+ }
56
+
57
+ export default CVEffects;
@@ -0,0 +1,58 @@
1
+ import {
2
+ extendPrototype,
3
+ } from '../../utils/functionExtensions';
4
+ import createTag from '../../utils/helpers/html_elements';
5
+ import RenderableElement from '../helpers/RenderableElement';
6
+ import BaseElement from '../BaseElement';
7
+ import TransformElement from '../helpers/TransformElement';
8
+ import HierarchyElement from '../helpers/HierarchyElement';
9
+ import FrameElement from '../helpers/FrameElement';
10
+ import CVBaseElement from './CVBaseElement';
11
+ import IImageElement from '../ImageElement';
12
+ import SVGShapeElement from '../svgElements/SVGShapeElement';
13
+
14
+ function CVImageElement(data, globalData, comp) {
15
+ this.assetData = globalData.getAssetData(data.refId);
16
+ this.img = globalData.imageLoader.getAsset(this.assetData);
17
+ this.initElement(data, globalData, comp);
18
+ }
19
+ extendPrototype([BaseElement, TransformElement, CVBaseElement, HierarchyElement, FrameElement, RenderableElement], CVImageElement);
20
+
21
+ CVImageElement.prototype.initElement = SVGShapeElement.prototype.initElement;
22
+ CVImageElement.prototype.prepareFrame = IImageElement.prototype.prepareFrame;
23
+
24
+ CVImageElement.prototype.createContent = function () {
25
+ if (this.img.width && (this.assetData.w !== this.img.width || this.assetData.h !== this.img.height)) {
26
+ var canvas = createTag('canvas');
27
+ canvas.width = this.assetData.w;
28
+ canvas.height = this.assetData.h;
29
+ var ctx = canvas.getContext('2d');
30
+
31
+ var imgW = this.img.width;
32
+ var imgH = this.img.height;
33
+ var imgRel = imgW / imgH;
34
+ var canvasRel = this.assetData.w / this.assetData.h;
35
+ var widthCrop;
36
+ var heightCrop;
37
+ var par = this.assetData.pr || this.globalData.renderConfig.imagePreserveAspectRatio;
38
+ if ((imgRel > canvasRel && par === 'xMidYMid slice') || (imgRel < canvasRel && par !== 'xMidYMid slice')) {
39
+ heightCrop = imgH;
40
+ widthCrop = heightCrop * canvasRel;
41
+ } else {
42
+ widthCrop = imgW;
43
+ heightCrop = widthCrop / canvasRel;
44
+ }
45
+ ctx.drawImage(this.img, (imgW - widthCrop) / 2, (imgH - heightCrop) / 2, widthCrop, heightCrop, 0, 0, this.assetData.w, this.assetData.h);
46
+ this.img = canvas;
47
+ }
48
+ };
49
+
50
+ CVImageElement.prototype.renderInnerContent = function () {
51
+ this.canvasContext.drawImage(this.img, 0, 0);
52
+ };
53
+
54
+ CVImageElement.prototype.destroy = function () {
55
+ this.img = null;
56
+ };
57
+
58
+ export default CVImageElement;
@@ -0,0 +1,72 @@
1
+ import {
2
+ createSizedArray,
3
+ } from '../../utils/helpers/arrays';
4
+
5
+ import ShapePropertyFactory from '../../utils/shapes/ShapeProperty';
6
+ import MaskElement from '../../mask';
7
+
8
+ function CVMaskElement(data, element) {
9
+ this.data = data;
10
+ this.element = element;
11
+ this.masksProperties = this.data.masksProperties || [];
12
+ this.viewData = createSizedArray(this.masksProperties.length);
13
+ var i;
14
+ var len = this.masksProperties.length;
15
+ var hasMasks = false;
16
+ for (i = 0; i < len; i += 1) {
17
+ if (this.masksProperties[i].mode !== 'n') {
18
+ hasMasks = true;
19
+ }
20
+ this.viewData[i] = ShapePropertyFactory.getShapeProp(this.element, this.masksProperties[i], 3);
21
+ }
22
+ this.hasMasks = hasMasks;
23
+ if (hasMasks) {
24
+ this.element.addRenderableComponent(this);
25
+ }
26
+ }
27
+
28
+ CVMaskElement.prototype.renderFrame = function () {
29
+ if (!this.hasMasks) {
30
+ return;
31
+ }
32
+ var transform = this.element.finalTransform.mat;
33
+ var ctx = this.element.canvasContext;
34
+ var i;
35
+ var len = this.masksProperties.length;
36
+ var pt;
37
+ var pts;
38
+ var data;
39
+ ctx.beginPath();
40
+ for (i = 0; i < len; i += 1) {
41
+ if (this.masksProperties[i].mode !== 'n') {
42
+ if (this.masksProperties[i].inv) {
43
+ ctx.moveTo(0, 0);
44
+ ctx.lineTo(this.element.globalData.compSize.w, 0);
45
+ ctx.lineTo(this.element.globalData.compSize.w, this.element.globalData.compSize.h);
46
+ ctx.lineTo(0, this.element.globalData.compSize.h);
47
+ ctx.lineTo(0, 0);
48
+ }
49
+ data = this.viewData[i].v;
50
+ pt = transform.applyToPointArray(data.v[0][0], data.v[0][1], 0);
51
+ ctx.moveTo(pt[0], pt[1]);
52
+ var j;
53
+ var jLen = data._length;
54
+ for (j = 1; j < jLen; j += 1) {
55
+ pts = transform.applyToTriplePoints(data.o[j - 1], data.i[j], data.v[j]);
56
+ ctx.bezierCurveTo(pts[0], pts[1], pts[2], pts[3], pts[4], pts[5]);
57
+ }
58
+ pts = transform.applyToTriplePoints(data.o[j - 1], data.i[0], data.v[0]);
59
+ ctx.bezierCurveTo(pts[0], pts[1], pts[2], pts[3], pts[4], pts[5]);
60
+ }
61
+ }
62
+ this.element.globalData.renderer.save(true);
63
+ ctx.clip();
64
+ };
65
+
66
+ CVMaskElement.prototype.getMaskProperty = MaskElement.prototype.getMaskProperty;
67
+
68
+ CVMaskElement.prototype.destroy = function () {
69
+ this.element = null;
70
+ };
71
+
72
+ export default CVMaskElement;