@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,22 @@
1
+ import createNS from '../../../utils/helpers/svg_elements';
2
+
3
+ function SVGComposableEffect() {
4
+
5
+ }
6
+ SVGComposableEffect.prototype = {
7
+ createMergeNode: (resultId, ins) => {
8
+ var feMerge = createNS('feMerge');
9
+ feMerge.setAttribute('result', resultId);
10
+ var feMergeNode;
11
+ var i;
12
+ for (i = 0; i < ins.length; i += 1) {
13
+ feMergeNode = createNS('feMergeNode');
14
+ feMergeNode.setAttribute('in', ins[i]);
15
+ feMerge.appendChild(feMergeNode);
16
+ feMerge.appendChild(feMergeNode);
17
+ }
18
+ return feMerge;
19
+ },
20
+ };
21
+
22
+ export default SVGComposableEffect;
@@ -0,0 +1,83 @@
1
+ import {
2
+ degToRads,
3
+ rgbToHex,
4
+ } from '../../../utils/common';
5
+ import createNS from '../../../utils/helpers/svg_elements';
6
+ import SVGComposableEffect from './SVGComposableEffect';
7
+ import {
8
+ extendPrototype,
9
+ } from '../../../utils/functionExtensions';
10
+
11
+ function SVGDropShadowEffect(filter, filterManager, elem, id, source) {
12
+ var globalFilterSize = filterManager.container.globalData.renderConfig.filterSize;
13
+ var filterSize = filterManager.data.fs || globalFilterSize;
14
+ filter.setAttribute('x', filterSize.x || globalFilterSize.x);
15
+ filter.setAttribute('y', filterSize.y || globalFilterSize.y);
16
+ filter.setAttribute('width', filterSize.width || globalFilterSize.width);
17
+ filter.setAttribute('height', filterSize.height || globalFilterSize.height);
18
+ this.filterManager = filterManager;
19
+
20
+ var feGaussianBlur = createNS('feGaussianBlur');
21
+ feGaussianBlur.setAttribute('in', 'SourceAlpha');
22
+ feGaussianBlur.setAttribute('result', id + '_drop_shadow_1');
23
+ feGaussianBlur.setAttribute('stdDeviation', '0');
24
+ this.feGaussianBlur = feGaussianBlur;
25
+ filter.appendChild(feGaussianBlur);
26
+
27
+ var feOffset = createNS('feOffset');
28
+ feOffset.setAttribute('dx', '25');
29
+ feOffset.setAttribute('dy', '0');
30
+ feOffset.setAttribute('in', id + '_drop_shadow_1');
31
+ feOffset.setAttribute('result', id + '_drop_shadow_2');
32
+ this.feOffset = feOffset;
33
+ filter.appendChild(feOffset);
34
+ var feFlood = createNS('feFlood');
35
+ feFlood.setAttribute('flood-color', '#00ff00');
36
+ feFlood.setAttribute('flood-opacity', '1');
37
+ feFlood.setAttribute('result', id + '_drop_shadow_3');
38
+ this.feFlood = feFlood;
39
+ filter.appendChild(feFlood);
40
+
41
+ var feComposite = createNS('feComposite');
42
+ feComposite.setAttribute('in', id + '_drop_shadow_3');
43
+ feComposite.setAttribute('in2', id + '_drop_shadow_2');
44
+ feComposite.setAttribute('operator', 'in');
45
+ feComposite.setAttribute('result', id + '_drop_shadow_4');
46
+ filter.appendChild(feComposite);
47
+
48
+ var feMerge = this.createMergeNode(
49
+ id,
50
+ [
51
+ id + '_drop_shadow_4',
52
+ source,
53
+ ]
54
+ );
55
+ filter.appendChild(feMerge);
56
+ //
57
+ }
58
+ extendPrototype([SVGComposableEffect], SVGDropShadowEffect);
59
+
60
+ SVGDropShadowEffect.prototype.renderFrame = function (forceRender) {
61
+ if (forceRender || this.filterManager._mdf) {
62
+ if (forceRender || this.filterManager.effectElements[4].p._mdf) {
63
+ this.feGaussianBlur.setAttribute('stdDeviation', this.filterManager.effectElements[4].p.v / 4);
64
+ }
65
+ if (forceRender || this.filterManager.effectElements[0].p._mdf) {
66
+ var col = this.filterManager.effectElements[0].p.v;
67
+ this.feFlood.setAttribute('flood-color', rgbToHex(Math.round(col[0] * 255), Math.round(col[1] * 255), Math.round(col[2] * 255)));
68
+ }
69
+ if (forceRender || this.filterManager.effectElements[1].p._mdf) {
70
+ this.feFlood.setAttribute('flood-opacity', this.filterManager.effectElements[1].p.v / 255);
71
+ }
72
+ if (forceRender || this.filterManager.effectElements[2].p._mdf || this.filterManager.effectElements[3].p._mdf) {
73
+ var distance = this.filterManager.effectElements[3].p.v;
74
+ var angle = (this.filterManager.effectElements[2].p.v - 90) * degToRads;
75
+ var x = distance * Math.cos(angle);
76
+ var y = distance * Math.sin(angle);
77
+ this.feOffset.setAttribute('dx', x);
78
+ this.feOffset.setAttribute('dy', y);
79
+ }
80
+ }
81
+ };
82
+
83
+ export default SVGDropShadowEffect;
@@ -0,0 +1,22 @@
1
+ import createNS from '../../../utils/helpers/svg_elements';
2
+
3
+ function SVGFillFilter(filter, filterManager, elem, id) {
4
+ this.filterManager = filterManager;
5
+ var feColorMatrix = createNS('feColorMatrix');
6
+ feColorMatrix.setAttribute('type', 'matrix');
7
+ feColorMatrix.setAttribute('color-interpolation-filters', 'sRGB');
8
+ feColorMatrix.setAttribute('values', '1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 1 0');
9
+ feColorMatrix.setAttribute('result', id);
10
+ filter.appendChild(feColorMatrix);
11
+ this.matrixFilter = feColorMatrix;
12
+ }
13
+
14
+ SVGFillFilter.prototype.renderFrame = function (forceRender) {
15
+ if (forceRender || this.filterManager._mdf) {
16
+ var color = this.filterManager.effectElements[2].p.v;
17
+ var opacity = this.filterManager.effectElements[6].p.v;
18
+ this.matrixFilter.setAttribute('values', '0 0 0 0 ' + color[0] + ' 0 0 0 0 ' + color[1] + ' 0 0 0 0 ' + color[2] + ' 0 0 0 ' + opacity + ' 0');
19
+ }
20
+ };
21
+
22
+ export default SVGFillFilter;
@@ -0,0 +1,44 @@
1
+ import createNS from '../../../utils/helpers/svg_elements';
2
+
3
+ function SVGGaussianBlurEffect(filter, filterManager, elem, id) {
4
+ // Outset the filter region by 100% on all sides to accommodate blur expansion.
5
+ filter.setAttribute('x', '-100%');
6
+ filter.setAttribute('y', '-100%');
7
+ filter.setAttribute('width', '300%');
8
+ filter.setAttribute('height', '300%');
9
+
10
+ this.filterManager = filterManager;
11
+ var feGaussianBlur = createNS('feGaussianBlur');
12
+ feGaussianBlur.setAttribute('result', id);
13
+ filter.appendChild(feGaussianBlur);
14
+ this.feGaussianBlur = feGaussianBlur;
15
+ }
16
+
17
+ SVGGaussianBlurEffect.prototype.renderFrame = function (forceRender) {
18
+ if (forceRender || this.filterManager._mdf) {
19
+ // Empirical value, matching AE's blur appearance.
20
+ var kBlurrinessToSigma = 0.3;
21
+ var sigma = this.filterManager.effectElements[0].p.v * kBlurrinessToSigma;
22
+
23
+ // Dimensions mapping:
24
+ //
25
+ // 1 -> horizontal & vertical
26
+ // 2 -> horizontal only
27
+ // 3 -> vertical only
28
+ //
29
+ var dimensions = this.filterManager.effectElements[1].p.v;
30
+ var sigmaX = (dimensions == 3) ? 0 : sigma; // eslint-disable-line eqeqeq
31
+ var sigmaY = (dimensions == 2) ? 0 : sigma; // eslint-disable-line eqeqeq
32
+
33
+ this.feGaussianBlur.setAttribute('stdDeviation', sigmaX + ' ' + sigmaY);
34
+
35
+ // Repeat edges mapping:
36
+ //
37
+ // 0 -> off -> duplicate
38
+ // 1 -> on -> wrap
39
+ var edgeMode = (this.filterManager.effectElements[2].p.v == 1) ? 'wrap' : 'duplicate'; // eslint-disable-line eqeqeq
40
+ this.feGaussianBlur.setAttribute('edgeMode', edgeMode);
41
+ }
42
+ };
43
+
44
+ export default SVGGaussianBlurEffect;
@@ -0,0 +1,101 @@
1
+ import {
2
+ createElementID,
3
+ } from '../../../utils/common';
4
+ import createNS from '../../../utils/helpers/svg_elements';
5
+
6
+ var _svgMatteSymbols = [];
7
+
8
+ function SVGMatte3Effect(filterElem, filterManager, elem) {
9
+ this.initialized = false;
10
+ this.filterManager = filterManager;
11
+ this.filterElem = filterElem;
12
+ this.elem = elem;
13
+ elem.matteElement = createNS('g');
14
+ elem.matteElement.appendChild(elem.layerElement);
15
+ elem.matteElement.appendChild(elem.transformedElement);
16
+ elem.baseElement = elem.matteElement;
17
+ }
18
+
19
+ SVGMatte3Effect.prototype.findSymbol = function (mask) {
20
+ var i = 0;
21
+ var len = _svgMatteSymbols.length;
22
+ while (i < len) {
23
+ if (_svgMatteSymbols[i] === mask) {
24
+ return _svgMatteSymbols[i];
25
+ }
26
+ i += 1;
27
+ }
28
+ return null;
29
+ };
30
+
31
+ SVGMatte3Effect.prototype.replaceInParent = function (mask, symbolId) {
32
+ var parentNode = mask.layerElement.parentNode;
33
+ if (!parentNode) {
34
+ return;
35
+ }
36
+ var children = parentNode.children;
37
+ var i = 0;
38
+ var len = children.length;
39
+ while (i < len) {
40
+ if (children[i] === mask.layerElement) {
41
+ break;
42
+ }
43
+ i += 1;
44
+ }
45
+ var nextChild;
46
+ if (i <= len - 2) {
47
+ nextChild = children[i + 1];
48
+ }
49
+ var useElem = createNS('use');
50
+ useElem.setAttribute('href', '#' + symbolId);
51
+ if (nextChild) {
52
+ parentNode.insertBefore(useElem, nextChild);
53
+ } else {
54
+ parentNode.appendChild(useElem);
55
+ }
56
+ };
57
+
58
+ SVGMatte3Effect.prototype.setElementAsMask = function (elem, mask) {
59
+ if (!this.findSymbol(mask)) {
60
+ var symbolId = createElementID();
61
+ var masker = createNS('mask');
62
+ masker.setAttribute('id', mask.layerId);
63
+ masker.setAttribute('mask-type', 'alpha');
64
+ _svgMatteSymbols.push(mask);
65
+ var defs = elem.globalData.defs;
66
+ defs.appendChild(masker);
67
+ var symbol = createNS('symbol');
68
+ symbol.setAttribute('id', symbolId);
69
+ this.replaceInParent(mask, symbolId);
70
+ symbol.appendChild(mask.layerElement);
71
+ defs.appendChild(symbol);
72
+ var useElem = createNS('use');
73
+ useElem.setAttribute('href', '#' + symbolId);
74
+ masker.appendChild(useElem);
75
+ mask.data.hd = false;
76
+ mask.show();
77
+ }
78
+ elem.setMatte(mask.layerId);
79
+ };
80
+
81
+ SVGMatte3Effect.prototype.initialize = function () {
82
+ var ind = this.filterManager.effectElements[0].p.v;
83
+ var elements = this.elem.comp.elements;
84
+ var i = 0;
85
+ var len = elements.length;
86
+ while (i < len) {
87
+ if (elements[i] && elements[i].data.ind === ind) {
88
+ this.setElementAsMask(this.elem, elements[i]);
89
+ }
90
+ i += 1;
91
+ }
92
+ this.initialized = true;
93
+ };
94
+
95
+ SVGMatte3Effect.prototype.renderFrame = function () {
96
+ if (!this.initialized) {
97
+ this.initialize();
98
+ }
99
+ };
100
+
101
+ export default SVGMatte3Effect;
@@ -0,0 +1,108 @@
1
+ import createNS from '../../../utils/helpers/svg_elements';
2
+
3
+ function SVGProLevelsFilter(filter, filterManager, elem, id) {
4
+ this.filterManager = filterManager;
5
+ var effectElements = this.filterManager.effectElements;
6
+ var feComponentTransfer = createNS('feComponentTransfer');
7
+
8
+ // Red
9
+ if (effectElements[10].p.k || effectElements[10].p.v !== 0 || effectElements[11].p.k || effectElements[11].p.v !== 1 || effectElements[12].p.k || effectElements[12].p.v !== 1 || effectElements[13].p.k || effectElements[13].p.v !== 0 || effectElements[14].p.k || effectElements[14].p.v !== 1) {
10
+ this.feFuncR = this.createFeFunc('feFuncR', feComponentTransfer);
11
+ }
12
+ // Green
13
+ if (effectElements[17].p.k || effectElements[17].p.v !== 0 || effectElements[18].p.k || effectElements[18].p.v !== 1 || effectElements[19].p.k || effectElements[19].p.v !== 1 || effectElements[20].p.k || effectElements[20].p.v !== 0 || effectElements[21].p.k || effectElements[21].p.v !== 1) {
14
+ this.feFuncG = this.createFeFunc('feFuncG', feComponentTransfer);
15
+ }
16
+ // Blue
17
+ if (effectElements[24].p.k || effectElements[24].p.v !== 0 || effectElements[25].p.k || effectElements[25].p.v !== 1 || effectElements[26].p.k || effectElements[26].p.v !== 1 || effectElements[27].p.k || effectElements[27].p.v !== 0 || effectElements[28].p.k || effectElements[28].p.v !== 1) {
18
+ this.feFuncB = this.createFeFunc('feFuncB', feComponentTransfer);
19
+ }
20
+ // Alpha
21
+ if (effectElements[31].p.k || effectElements[31].p.v !== 0 || effectElements[32].p.k || effectElements[32].p.v !== 1 || effectElements[33].p.k || effectElements[33].p.v !== 1 || effectElements[34].p.k || effectElements[34].p.v !== 0 || effectElements[35].p.k || effectElements[35].p.v !== 1) {
22
+ this.feFuncA = this.createFeFunc('feFuncA', feComponentTransfer);
23
+ }
24
+ // RGB
25
+ if (this.feFuncR || this.feFuncG || this.feFuncB || this.feFuncA) {
26
+ feComponentTransfer.setAttribute('color-interpolation-filters', 'sRGB');
27
+ filter.appendChild(feComponentTransfer);
28
+ }
29
+
30
+ if (effectElements[3].p.k || effectElements[3].p.v !== 0 || effectElements[4].p.k || effectElements[4].p.v !== 1 || effectElements[5].p.k || effectElements[5].p.v !== 1 || effectElements[6].p.k || effectElements[6].p.v !== 0 || effectElements[7].p.k || effectElements[7].p.v !== 1) {
31
+ feComponentTransfer = createNS('feComponentTransfer');
32
+ feComponentTransfer.setAttribute('color-interpolation-filters', 'sRGB');
33
+ feComponentTransfer.setAttribute('result', id);
34
+ filter.appendChild(feComponentTransfer);
35
+ this.feFuncRComposed = this.createFeFunc('feFuncR', feComponentTransfer);
36
+ this.feFuncGComposed = this.createFeFunc('feFuncG', feComponentTransfer);
37
+ this.feFuncBComposed = this.createFeFunc('feFuncB', feComponentTransfer);
38
+ }
39
+ }
40
+
41
+ SVGProLevelsFilter.prototype.createFeFunc = function (type, feComponentTransfer) {
42
+ var feFunc = createNS(type);
43
+ feFunc.setAttribute('type', 'table');
44
+ feComponentTransfer.appendChild(feFunc);
45
+ return feFunc;
46
+ };
47
+
48
+ SVGProLevelsFilter.prototype.getTableValue = function (inputBlack, inputWhite, gamma, outputBlack, outputWhite) {
49
+ var cnt = 0;
50
+ var segments = 256;
51
+ var perc;
52
+ var min = Math.min(inputBlack, inputWhite);
53
+ var max = Math.max(inputBlack, inputWhite);
54
+ var table = Array.call(null, { length: segments });
55
+ var colorValue;
56
+ var pos = 0;
57
+ var outputDelta = outputWhite - outputBlack;
58
+ var inputDelta = inputWhite - inputBlack;
59
+ while (cnt <= 256) {
60
+ perc = cnt / 256;
61
+ if (perc <= min) {
62
+ colorValue = inputDelta < 0 ? outputWhite : outputBlack;
63
+ } else if (perc >= max) {
64
+ colorValue = inputDelta < 0 ? outputBlack : outputWhite;
65
+ } else {
66
+ colorValue = (outputBlack + outputDelta * Math.pow((perc - inputBlack) / inputDelta, 1 / gamma));
67
+ }
68
+ table[pos] = colorValue;
69
+ pos += 1;
70
+ cnt += 256 / (segments - 1);
71
+ }
72
+ return table.join(' ');
73
+ };
74
+
75
+ SVGProLevelsFilter.prototype.renderFrame = function (forceRender) {
76
+ if (forceRender || this.filterManager._mdf) {
77
+ var val;
78
+ var effectElements = this.filterManager.effectElements;
79
+ if (this.feFuncRComposed && (forceRender || effectElements[3].p._mdf || effectElements[4].p._mdf || effectElements[5].p._mdf || effectElements[6].p._mdf || effectElements[7].p._mdf)) {
80
+ val = this.getTableValue(effectElements[3].p.v, effectElements[4].p.v, effectElements[5].p.v, effectElements[6].p.v, effectElements[7].p.v);
81
+ this.feFuncRComposed.setAttribute('tableValues', val);
82
+ this.feFuncGComposed.setAttribute('tableValues', val);
83
+ this.feFuncBComposed.setAttribute('tableValues', val);
84
+ }
85
+
86
+ if (this.feFuncR && (forceRender || effectElements[10].p._mdf || effectElements[11].p._mdf || effectElements[12].p._mdf || effectElements[13].p._mdf || effectElements[14].p._mdf)) {
87
+ val = this.getTableValue(effectElements[10].p.v, effectElements[11].p.v, effectElements[12].p.v, effectElements[13].p.v, effectElements[14].p.v);
88
+ this.feFuncR.setAttribute('tableValues', val);
89
+ }
90
+
91
+ if (this.feFuncG && (forceRender || effectElements[17].p._mdf || effectElements[18].p._mdf || effectElements[19].p._mdf || effectElements[20].p._mdf || effectElements[21].p._mdf)) {
92
+ val = this.getTableValue(effectElements[17].p.v, effectElements[18].p.v, effectElements[19].p.v, effectElements[20].p.v, effectElements[21].p.v);
93
+ this.feFuncG.setAttribute('tableValues', val);
94
+ }
95
+
96
+ if (this.feFuncB && (forceRender || effectElements[24].p._mdf || effectElements[25].p._mdf || effectElements[26].p._mdf || effectElements[27].p._mdf || effectElements[28].p._mdf)) {
97
+ val = this.getTableValue(effectElements[24].p.v, effectElements[25].p.v, effectElements[26].p.v, effectElements[27].p.v, effectElements[28].p.v);
98
+ this.feFuncB.setAttribute('tableValues', val);
99
+ }
100
+
101
+ if (this.feFuncA && (forceRender || effectElements[31].p._mdf || effectElements[32].p._mdf || effectElements[33].p._mdf || effectElements[34].p._mdf || effectElements[35].p._mdf)) {
102
+ val = this.getTableValue(effectElements[31].p.v, effectElements[32].p.v, effectElements[33].p.v, effectElements[34].p.v, effectElements[35].p.v);
103
+ this.feFuncA.setAttribute('tableValues', val);
104
+ }
105
+ }
106
+ };
107
+
108
+ export default SVGProLevelsFilter;
@@ -0,0 +1,119 @@
1
+ import { getLocationHref } from '../../../main';
2
+ import {
3
+ createElementID,
4
+ bmFloor,
5
+ } from '../../../utils/common';
6
+ import createNS from '../../../utils/helpers/svg_elements';
7
+
8
+ function SVGStrokeEffect(fil, filterManager, elem) {
9
+ this.initialized = false;
10
+ this.filterManager = filterManager;
11
+ this.elem = elem;
12
+ this.paths = [];
13
+ }
14
+
15
+ SVGStrokeEffect.prototype.initialize = function () {
16
+ var elemChildren = this.elem.layerElement.children || this.elem.layerElement.childNodes;
17
+ var path;
18
+ var groupPath;
19
+ var i;
20
+ var len;
21
+ if (this.filterManager.effectElements[1].p.v === 1) {
22
+ len = this.elem.maskManager.masksProperties.length;
23
+ i = 0;
24
+ } else {
25
+ i = this.filterManager.effectElements[0].p.v - 1;
26
+ len = i + 1;
27
+ }
28
+ groupPath = createNS('g');
29
+ groupPath.setAttribute('fill', 'none');
30
+ groupPath.setAttribute('stroke-linecap', 'round');
31
+ groupPath.setAttribute('stroke-dashoffset', 1);
32
+ for (i; i < len; i += 1) {
33
+ path = createNS('path');
34
+ groupPath.appendChild(path);
35
+ this.paths.push({ p: path, m: i });
36
+ }
37
+ if (this.filterManager.effectElements[10].p.v === 3) {
38
+ var mask = createNS('mask');
39
+ var id = createElementID();
40
+ mask.setAttribute('id', id);
41
+ mask.setAttribute('mask-type', 'alpha');
42
+ mask.appendChild(groupPath);
43
+ this.elem.globalData.defs.appendChild(mask);
44
+ var g = createNS('g');
45
+ g.setAttribute('mask', 'url(' + getLocationHref() + '#' + id + ')');
46
+ while (elemChildren[0]) {
47
+ g.appendChild(elemChildren[0]);
48
+ }
49
+ this.elem.layerElement.appendChild(g);
50
+ this.masker = mask;
51
+ groupPath.setAttribute('stroke', '#fff');
52
+ } else if (this.filterManager.effectElements[10].p.v === 1 || this.filterManager.effectElements[10].p.v === 2) {
53
+ if (this.filterManager.effectElements[10].p.v === 2) {
54
+ elemChildren = this.elem.layerElement.children || this.elem.layerElement.childNodes;
55
+ while (elemChildren.length) {
56
+ this.elem.layerElement.removeChild(elemChildren[0]);
57
+ }
58
+ }
59
+ this.elem.layerElement.appendChild(groupPath);
60
+ this.elem.layerElement.removeAttribute('mask');
61
+ groupPath.setAttribute('stroke', '#fff');
62
+ }
63
+ this.initialized = true;
64
+ this.pathMasker = groupPath;
65
+ };
66
+
67
+ SVGStrokeEffect.prototype.renderFrame = function (forceRender) {
68
+ if (!this.initialized) {
69
+ this.initialize();
70
+ }
71
+ var i;
72
+ var len = this.paths.length;
73
+ var mask;
74
+ var path;
75
+ for (i = 0; i < len; i += 1) {
76
+ if (this.paths[i].m !== -1) {
77
+ mask = this.elem.maskManager.viewData[this.paths[i].m];
78
+ path = this.paths[i].p;
79
+ if (forceRender || this.filterManager._mdf || mask.prop._mdf) {
80
+ path.setAttribute('d', mask.lastPath);
81
+ }
82
+ if (forceRender || this.filterManager.effectElements[9].p._mdf || this.filterManager.effectElements[4].p._mdf || this.filterManager.effectElements[7].p._mdf || this.filterManager.effectElements[8].p._mdf || mask.prop._mdf) {
83
+ var dasharrayValue;
84
+ if (this.filterManager.effectElements[7].p.v !== 0 || this.filterManager.effectElements[8].p.v !== 100) {
85
+ var s = Math.min(this.filterManager.effectElements[7].p.v, this.filterManager.effectElements[8].p.v) * 0.01;
86
+ var e = Math.max(this.filterManager.effectElements[7].p.v, this.filterManager.effectElements[8].p.v) * 0.01;
87
+ var l = path.getTotalLength();
88
+ dasharrayValue = '0 0 0 ' + l * s + ' ';
89
+ var lineLength = l * (e - s);
90
+ var segment = 1 + this.filterManager.effectElements[4].p.v * 2 * this.filterManager.effectElements[9].p.v * 0.01;
91
+ var units = Math.floor(lineLength / segment);
92
+ var j;
93
+ for (j = 0; j < units; j += 1) {
94
+ dasharrayValue += '1 ' + this.filterManager.effectElements[4].p.v * 2 * this.filterManager.effectElements[9].p.v * 0.01 + ' ';
95
+ }
96
+ dasharrayValue += '0 ' + l * 10 + ' 0 0';
97
+ } else {
98
+ dasharrayValue = '1 ' + this.filterManager.effectElements[4].p.v * 2 * this.filterManager.effectElements[9].p.v * 0.01;
99
+ }
100
+ path.setAttribute('stroke-dasharray', dasharrayValue);
101
+ }
102
+ }
103
+ }
104
+ if (forceRender || this.filterManager.effectElements[4].p._mdf) {
105
+ this.pathMasker.setAttribute('stroke-width', this.filterManager.effectElements[4].p.v * 2);
106
+ }
107
+
108
+ if (forceRender || this.filterManager.effectElements[6].p._mdf) {
109
+ this.pathMasker.setAttribute('opacity', this.filterManager.effectElements[6].p.v);
110
+ }
111
+ if (this.filterManager.effectElements[10].p.v === 1 || this.filterManager.effectElements[10].p.v === 2) {
112
+ if (forceRender || this.filterManager.effectElements[3].p._mdf) {
113
+ var color = this.filterManager.effectElements[3].p.v;
114
+ this.pathMasker.setAttribute('stroke', 'rgb(' + bmFloor(color[0] * 255) + ',' + bmFloor(color[1] * 255) + ',' + bmFloor(color[2] * 255) + ')');
115
+ }
116
+ }
117
+ };
118
+
119
+ export default SVGStrokeEffect;
@@ -0,0 +1,47 @@
1
+ import createNS from '../../../utils/helpers/svg_elements';
2
+ import SVGComposableEffect from './SVGComposableEffect';
3
+ import {
4
+ extendPrototype,
5
+ } from '../../../utils/functionExtensions';
6
+
7
+ var linearFilterValue = '0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0';
8
+
9
+ function SVGTintFilter(filter, filterManager, elem, id, source) {
10
+ this.filterManager = filterManager;
11
+ var feColorMatrix = createNS('feColorMatrix');
12
+ feColorMatrix.setAttribute('type', 'matrix');
13
+ feColorMatrix.setAttribute('color-interpolation-filters', 'linearRGB');
14
+ feColorMatrix.setAttribute('values', linearFilterValue + ' 1 0');
15
+ this.linearFilter = feColorMatrix;
16
+ feColorMatrix.setAttribute('result', id + '_tint_1');
17
+ filter.appendChild(feColorMatrix);
18
+ feColorMatrix = createNS('feColorMatrix');
19
+ feColorMatrix.setAttribute('type', 'matrix');
20
+ feColorMatrix.setAttribute('color-interpolation-filters', 'sRGB');
21
+ feColorMatrix.setAttribute('values', '1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 1 0');
22
+ feColorMatrix.setAttribute('result', id + '_tint_2');
23
+ filter.appendChild(feColorMatrix);
24
+ this.matrixFilter = feColorMatrix;
25
+ var feMerge = this.createMergeNode(
26
+ id,
27
+ [
28
+ source,
29
+ id + '_tint_1',
30
+ id + '_tint_2',
31
+ ]
32
+ );
33
+ filter.appendChild(feMerge);
34
+ }
35
+ extendPrototype([SVGComposableEffect], SVGTintFilter);
36
+
37
+ SVGTintFilter.prototype.renderFrame = function (forceRender) {
38
+ if (forceRender || this.filterManager._mdf) {
39
+ var colorBlack = this.filterManager.effectElements[0].p.v;
40
+ var colorWhite = this.filterManager.effectElements[1].p.v;
41
+ var opacity = this.filterManager.effectElements[2].p.v / 100;
42
+ this.linearFilter.setAttribute('values', linearFilterValue + ' ' + opacity + ' 0');
43
+ this.matrixFilter.setAttribute('values', (colorWhite[0] - colorBlack[0]) + ' 0 0 0 ' + colorBlack[0] + ' ' + (colorWhite[1] - colorBlack[1]) + ' 0 0 0 ' + colorBlack[1] + ' ' + (colorWhite[2] - colorBlack[2]) + ' 0 0 0 ' + colorBlack[2] + ' 0 0 0 1 0');
44
+ }
45
+ };
46
+
47
+ export default SVGTintFilter;
@@ -0,0 +1,10 @@
1
+ import TransformEffect from '../../../effects/TransformEffect';
2
+ import { extendPrototype } from '../../../utils/functionExtensions';
3
+
4
+ function SVGTransformEffect(_, filterManager) {
5
+ this.init(filterManager);
6
+ }
7
+
8
+ extendPrototype([TransformEffect], SVGTransformEffect);
9
+
10
+ export default SVGTransformEffect;
@@ -0,0 +1,43 @@
1
+ import createNS from '../../../utils/helpers/svg_elements';
2
+
3
+ function SVGTritoneFilter(filter, filterManager, elem, id) {
4
+ this.filterManager = filterManager;
5
+ var feColorMatrix = createNS('feColorMatrix');
6
+ feColorMatrix.setAttribute('type', 'matrix');
7
+ feColorMatrix.setAttribute('color-interpolation-filters', 'linearRGB');
8
+ feColorMatrix.setAttribute('values', '0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0');
9
+ filter.appendChild(feColorMatrix);
10
+ var feComponentTransfer = createNS('feComponentTransfer');
11
+ feComponentTransfer.setAttribute('color-interpolation-filters', 'sRGB');
12
+ feComponentTransfer.setAttribute('result', id);
13
+ this.matrixFilter = feComponentTransfer;
14
+ var feFuncR = createNS('feFuncR');
15
+ feFuncR.setAttribute('type', 'table');
16
+ feComponentTransfer.appendChild(feFuncR);
17
+ this.feFuncR = feFuncR;
18
+ var feFuncG = createNS('feFuncG');
19
+ feFuncG.setAttribute('type', 'table');
20
+ feComponentTransfer.appendChild(feFuncG);
21
+ this.feFuncG = feFuncG;
22
+ var feFuncB = createNS('feFuncB');
23
+ feFuncB.setAttribute('type', 'table');
24
+ feComponentTransfer.appendChild(feFuncB);
25
+ this.feFuncB = feFuncB;
26
+ filter.appendChild(feComponentTransfer);
27
+ }
28
+
29
+ SVGTritoneFilter.prototype.renderFrame = function (forceRender) {
30
+ if (forceRender || this.filterManager._mdf) {
31
+ var color1 = this.filterManager.effectElements[0].p.v;
32
+ var color2 = this.filterManager.effectElements[1].p.v;
33
+ var color3 = this.filterManager.effectElements[2].p.v;
34
+ var tableR = color3[0] + ' ' + color2[0] + ' ' + color1[0];
35
+ var tableG = color3[1] + ' ' + color2[1] + ' ' + color1[1];
36
+ var tableB = color3[2] + ' ' + color2[2] + ' ' + color1[2];
37
+ this.feFuncR.setAttribute('tableValues', tableR);
38
+ this.feFuncG.setAttribute('tableValues', tableG);
39
+ this.feFuncB.setAttribute('tableValues', tableB);
40
+ }
41
+ };
42
+
43
+ export default SVGTritoneFilter;
@@ -0,0 +1,21 @@
1
+ const svgNS = 'http://www.w3.org/2000/svg';
2
+
3
+ let locationHref = '';
4
+ let _useWebWorker = false;
5
+
6
+ const initialDefaultFrame = -999999;
7
+
8
+ const setWebWorker = (flag) => { _useWebWorker = !!flag; };
9
+ const getWebWorker = () => _useWebWorker;
10
+
11
+ const setLocationHref = (value) => { locationHref = value; };
12
+ const getLocationHref = () => locationHref;
13
+
14
+ export {
15
+ svgNS,
16
+ initialDefaultFrame,
17
+ setWebWorker,
18
+ getWebWorker,
19
+ setLocationHref,
20
+ getLocationHref,
21
+ };