@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.
- package/.babelrc.json +3 -0
- package/.eslintrc.json +46 -0
- package/.gitattributes +1 -0
- package/.github/FUNDING.yml +1 -0
- package/.github/ISSUE_TEMPLATE.md +22 -0
- package/.github/workflows/publish.yml +26 -0
- package/.github/workflows/testAnimations.yml +29 -0
- package/.github/workflows/updateScreenshots.yml +34 -0
- package/CHANGELOG.md +601 -0
- package/History.md +1230 -0
- package/LICENSE.md +21 -0
- package/README.md +351 -0
- package/bower.json +31 -0
- package/build/old_parser/bodymovin_parser.jsx +3023 -0
- package/build/old_parser/helperProject.aep +0 -0
- package/build/player/cjs/lottie.min.js +18229 -0
- package/build/player/cjs/lottie_canvas.min.js +16465 -0
- package/build/player/cjs/lottie_html.min.js +16312 -0
- package/build/player/cjs/lottie_light.min.js +11584 -0
- package/build/player/cjs/lottie_light_canvas.min.js +13518 -0
- package/build/player/cjs/lottie_light_html.min.js +12843 -0
- package/build/player/cjs/lottie_svg.min.js +15053 -0
- package/build/player/esm/lottie.min.js +18225 -0
- package/build/player/esm/lottie_canvas.min.js +16461 -0
- package/build/player/esm/lottie_html.min.js +16308 -0
- package/build/player/esm/lottie_light.min.js +11580 -0
- package/build/player/esm/lottie_light_canvas.min.js +13514 -0
- package/build/player/esm/lottie_light_html.min.js +12839 -0
- package/build/player/esm/lottie_svg.min.js +15049 -0
- package/build/player/lottie.d.ts +5 -0
- package/build/player/lottie.js +17151 -0
- package/build/player/lottie.min.js +1 -0
- package/build/player/lottie_canvas.js +15506 -0
- package/build/player/lottie_canvas.min.js +1 -0
- package/build/player/lottie_canvas_worker.js +18196 -0
- package/build/player/lottie_canvas_worker.min.js +15 -0
- package/build/player/lottie_html.d.ts +5 -0
- package/build/player/lottie_html.js +15354 -0
- package/build/player/lottie_html.min.js +1 -0
- package/build/player/lottie_light.d.ts +5 -0
- package/build/player/lottie_light.js +10854 -0
- package/build/player/lottie_light.min.js +1 -0
- package/build/player/lottie_light_canvas.d.ts +5 -0
- package/build/player/lottie_light_canvas.js +12666 -0
- package/build/player/lottie_light_canvas.min.js +1 -0
- package/build/player/lottie_light_html.d.ts +5 -0
- package/build/player/lottie_light_html.js +12029 -0
- package/build/player/lottie_light_html.min.js +1 -0
- package/build/player/lottie_svg.d.ts +5 -0
- package/build/player/lottie_svg.js +14179 -0
- package/build/player/lottie_svg.min.js +1 -0
- package/build/player/lottie_worker.js +18196 -0
- package/build/player/lottie_worker.min.js +15 -0
- package/docs/json/animation.json +101 -0
- package/docs/json/effects/angle.json +40 -0
- package/docs/json/effects/checkBox.json +40 -0
- package/docs/json/effects/color.json +40 -0
- package/docs/json/effects/customValue.json +4 -0
- package/docs/json/effects/dropDown.json +40 -0
- package/docs/json/effects/fill.json +55 -0
- package/docs/json/effects/group.json +41 -0
- package/docs/json/effects/index.json +51 -0
- package/docs/json/effects/layer.json +33 -0
- package/docs/json/effects/noValue.json +1 -0
- package/docs/json/effects/point.json +43 -0
- package/docs/json/effects/proLevels.json +130 -0
- package/docs/json/effects/slider.json +40 -0
- package/docs/json/effects/stroke.json +64 -0
- package/docs/json/effects/tint.json +43 -0
- package/docs/json/effects/tritone.json +46 -0
- package/docs/json/helpers/blendMode.json +71 -0
- package/docs/json/helpers/boolean.json +14 -0
- package/docs/json/helpers/composite.json +15 -0
- package/docs/json/helpers/lineCap.json +19 -0
- package/docs/json/helpers/lineJoin.json +19 -0
- package/docs/json/helpers/mask.json +80 -0
- package/docs/json/helpers/textBased.json +23 -0
- package/docs/json/helpers/textGrouping.json +23 -0
- package/docs/json/helpers/textShape.json +31 -0
- package/docs/json/helpers/transform.json +146 -0
- package/docs/json/layers/image.json +113 -0
- package/docs/json/layers/null.json +87 -0
- package/docs/json/layers/preComp.json +118 -0
- package/docs/json/layers/shape.json +157 -0
- package/docs/json/layers/solid.json +120 -0
- package/docs/json/layers/text.json +523 -0
- package/docs/json/properties/doubleKeyframe.json +50 -0
- package/docs/json/properties/multiDimensional.json +21 -0
- package/docs/json/properties/multiDimensionalKeyframed.json +35 -0
- package/docs/json/properties/offsetKeyframe.json +53 -0
- package/docs/json/properties/shape.json +27 -0
- package/docs/json/properties/shapeKeyframed.json +35 -0
- package/docs/json/properties/shapeProp.json +50 -0
- package/docs/json/properties/shapePropKeyframe.json +54 -0
- package/docs/json/properties/value.json +21 -0
- package/docs/json/properties/valueKeyframe.json +33 -0
- package/docs/json/properties/valueKeyframed.json +25 -0
- package/docs/json/shapes/ellipse.json +54 -0
- package/docs/json/shapes/fill.json +48 -0
- package/docs/json/shapes/gFill.json +107 -0
- package/docs/json/shapes/gStroke.json +137 -0
- package/docs/json/shapes/group.json +89 -0
- package/docs/json/shapes/merge.json +27 -0
- package/docs/json/shapes/rect.json +66 -0
- package/docs/json/shapes/repeater.json +63 -0
- package/docs/json/shapes/round.json +35 -0
- package/docs/json/shapes/shape.json +40 -0
- package/docs/json/shapes/star.json +133 -0
- package/docs/json/shapes/stroke.json +78 -0
- package/docs/json/shapes/transform.json +102 -0
- package/docs/json/shapes/trim.json +61 -0
- package/docs/json/sources/chars.json +61 -0
- package/docs/json/sources/image.json +31 -0
- package/docs/json/sources/precomp.json +39 -0
- package/index.d.ts +197 -0
- package/package.json +54 -0
- package/player/index.html +115 -0
- package/player/js/3rd_party/BezierEaser.js +158 -0
- package/player/js/3rd_party/howler.js +5 -0
- package/player/js/3rd_party/seedrandom.js +237 -0
- package/player/js/3rd_party/transformation-matrix.js +449 -0
- package/player/js/EffectsManager.js +83 -0
- package/player/js/animation/AnimationItem.js +809 -0
- package/player/js/animation/AnimationItemWorkerOverride.js +157 -0
- package/player/js/animation/AnimationManager.js +248 -0
- package/player/js/animation/AnimationManagerWorkerOverride.js +201 -0
- package/player/js/effects/EffectsManagerPlaceholder.js +5 -0
- package/player/js/effects/SliderEffect.js +37 -0
- package/player/js/effects/TransformEffect.js +44 -0
- package/player/js/elements/AudioElement.js +102 -0
- package/player/js/elements/BaseElement.js +78 -0
- package/player/js/elements/BaseTextElement.js +4 -0
- package/player/js/elements/CompElement.js +107 -0
- package/player/js/elements/FootageElement.js +47 -0
- package/player/js/elements/ImageElement.js +42 -0
- package/player/js/elements/NullElement.js +39 -0
- package/player/js/elements/ShapeElement.js +76 -0
- package/player/js/elements/SolidElement.js +23 -0
- package/player/js/elements/TextElement.js +94 -0
- package/player/js/elements/canvasElements/CVBaseElement.js +167 -0
- package/player/js/elements/canvasElements/CVCompBaseElement.js +11 -0
- package/player/js/elements/canvasElements/CVCompElement.js +57 -0
- package/player/js/elements/canvasElements/CVContextData.js +239 -0
- package/player/js/elements/canvasElements/CVEffects.js +57 -0
- package/player/js/elements/canvasElements/CVImageElement.js +58 -0
- package/player/js/elements/canvasElements/CVMaskElement.js +72 -0
- package/player/js/elements/canvasElements/CVShapeElement.js +521 -0
- package/player/js/elements/canvasElements/CVSolidElement.js +30 -0
- package/player/js/elements/canvasElements/CVTextElement.js +244 -0
- package/player/js/elements/canvasElements/effects/CVGaussianBlurEffect.js +29 -0
- package/player/js/elements/canvasElements/effects/CVTransformEffect.js +9 -0
- package/player/js/elements/helpers/FrameElement.js +54 -0
- package/player/js/elements/helpers/HierarchyElement.js +52 -0
- package/player/js/elements/helpers/RenderableDOMElement.js +72 -0
- package/player/js/elements/helpers/RenderableElement.js +87 -0
- package/player/js/elements/helpers/TransformElement.js +140 -0
- package/player/js/elements/helpers/shapes/CVShapeData.js +33 -0
- package/player/js/elements/helpers/shapes/ProcessedElement.js +6 -0
- package/player/js/elements/helpers/shapes/SVGElementsRenderer.js +239 -0
- package/player/js/elements/helpers/shapes/SVGFillStyleData.js +18 -0
- package/player/js/elements/helpers/shapes/SVGGradientFillStyleData.js +100 -0
- package/player/js/elements/helpers/shapes/SVGGradientStrokeStyleData.js +20 -0
- package/player/js/elements/helpers/shapes/SVGNoStyleData.js +15 -0
- package/player/js/elements/helpers/shapes/SVGShapeData.js +28 -0
- package/player/js/elements/helpers/shapes/SVGStrokeStyleData.js +21 -0
- package/player/js/elements/helpers/shapes/SVGStyleData.js +19 -0
- package/player/js/elements/helpers/shapes/SVGTransformData.js +11 -0
- package/player/js/elements/helpers/shapes/ShapeElement.js +5 -0
- package/player/js/elements/helpers/shapes/ShapeGroupData.js +9 -0
- package/player/js/elements/helpers/shapes/ShapeTransformManager.js +61 -0
- package/player/js/elements/htmlElements/HBaseElement.js +88 -0
- package/player/js/elements/htmlElements/HCameraElement.js +170 -0
- package/player/js/elements/htmlElements/HCompElement.js +61 -0
- package/player/js/elements/htmlElements/HEffects.js +3 -0
- package/player/js/elements/htmlElements/HImageElement.js +42 -0
- package/player/js/elements/htmlElements/HShapeElement.js +261 -0
- package/player/js/elements/htmlElements/HSolidElement.js +36 -0
- package/player/js/elements/htmlElements/HTextElement.js +290 -0
- package/player/js/elements/svgElements/SVGBaseElement.js +181 -0
- package/player/js/elements/svgElements/SVGCompElement.js +28 -0
- package/player/js/elements/svgElements/SVGEffects.js +70 -0
- package/player/js/elements/svgElements/SVGEffectsPlaceholder.js +3 -0
- package/player/js/elements/svgElements/SVGShapeElement.js +366 -0
- package/player/js/elements/svgElements/SVGTextElement.js +322 -0
- package/player/js/elements/svgElements/effects/SVGComposableEffect.js +22 -0
- package/player/js/elements/svgElements/effects/SVGDropShadowEffect.js +83 -0
- package/player/js/elements/svgElements/effects/SVGFillFilter.js +22 -0
- package/player/js/elements/svgElements/effects/SVGGaussianBlurEffect.js +44 -0
- package/player/js/elements/svgElements/effects/SVGMatte3Effect.js +101 -0
- package/player/js/elements/svgElements/effects/SVGProLevelsFilter.js +108 -0
- package/player/js/elements/svgElements/effects/SVGStrokeEffect.js +119 -0
- package/player/js/elements/svgElements/effects/SVGTintEffect.js +47 -0
- package/player/js/elements/svgElements/effects/SVGTransformEffect.js +10 -0
- package/player/js/elements/svgElements/effects/SVGTritoneFilter.js +43 -0
- package/player/js/main.js +21 -0
- package/player/js/mask.js +239 -0
- package/player/js/module.js +153 -0
- package/player/js/modules/canvas.js +22 -0
- package/player/js/modules/canvas_light.js +25 -0
- package/player/js/modules/full.js +70 -0
- package/player/js/modules/full_worker.js +0 -0
- package/player/js/modules/html.js +37 -0
- package/player/js/modules/html_light.js +25 -0
- package/player/js/modules/main.js +162 -0
- package/player/js/modules/svg.js +37 -0
- package/player/js/modules/svg_light.js +25 -0
- package/player/js/renderers/BaseRenderer.js +187 -0
- package/player/js/renderers/CanvasRenderer.js +67 -0
- package/player/js/renderers/CanvasRendererBase.js +318 -0
- package/player/js/renderers/CanvasRendererWorkerOverride.js +54 -0
- package/player/js/renderers/HybridRenderer.js +47 -0
- package/player/js/renderers/HybridRendererBase.js +344 -0
- package/player/js/renderers/SVGRenderer.js +82 -0
- package/player/js/renderers/SVGRendererBase.js +255 -0
- package/player/js/renderers/renderersManager.js +29 -0
- package/player/js/utils/BaseEvent.js +42 -0
- package/player/js/utils/DataManager.js +676 -0
- package/player/js/utils/DataManagerWorkerOverrides.js +13 -0
- package/player/js/utils/FontManager.js +443 -0
- package/player/js/utils/FontManagerWorkerOverride.js +16 -0
- package/player/js/utils/PolynomialBezier.js +253 -0
- package/player/js/utils/PropertyFactory.js +489 -0
- package/player/js/utils/SlotManager.js +17 -0
- package/player/js/utils/TransformProperty.js +251 -0
- package/player/js/utils/animationFramePolyFill.js +25 -0
- package/player/js/utils/asset_loader.js +53 -0
- package/player/js/utils/asset_loader_worker_override.js +3 -0
- package/player/js/utils/audio/AudioController.js +85 -0
- package/player/js/utils/audio/AudioElement.js +6 -0
- package/player/js/utils/bez.js +251 -0
- package/player/js/utils/common.js +280 -0
- package/player/js/utils/expressions/CompInterface.js +28 -0
- package/player/js/utils/expressions/EffectInterface.js +111 -0
- package/player/js/utils/expressions/ExpressionManager.js +752 -0
- package/player/js/utils/expressions/ExpressionPropertyDecorator.js +463 -0
- package/player/js/utils/expressions/ExpressionTextPropertyDecorator.js +40 -0
- package/player/js/utils/expressions/ExpressionValue.js +61 -0
- package/player/js/utils/expressions/ExpressionValueFactory.js +102 -0
- package/player/js/utils/expressions/Expressions.js +48 -0
- package/player/js/utils/expressions/FootageInterface.js +60 -0
- package/player/js/utils/expressions/InterfacesProvider.js +21 -0
- package/player/js/utils/expressions/LayerInterface.js +179 -0
- package/player/js/utils/expressions/MaskInterface.js +50 -0
- package/player/js/utils/expressions/ProjectInterface.js +31 -0
- package/player/js/utils/expressions/PropertyGroupFactory.js +13 -0
- package/player/js/utils/expressions/PropertyInterface.js +19 -0
- package/player/js/utils/expressions/ShapeInterface.js +543 -0
- package/player/js/utils/expressions/TextInterface.js +35 -0
- package/player/js/utils/expressions/TextSelectorPropertyDecorator.js +44 -0
- package/player/js/utils/expressions/TransformInterface.js +126 -0
- package/player/js/utils/expressions/expressionHelpers.js +86 -0
- package/player/js/utils/expressions/shapes/ShapePathInterface.js +47 -0
- package/player/js/utils/featureSupport.js +16 -0
- package/player/js/utils/filters.js +32 -0
- package/player/js/utils/functionExtensions.js +27 -0
- package/player/js/utils/getFontProperties.js +42 -0
- package/player/js/utils/helpers/arrays.js +43 -0
- package/player/js/utils/helpers/assetManager.js +96 -0
- package/player/js/utils/helpers/blendModes.js +26 -0
- package/player/js/utils/helpers/bufferManager.js +61 -0
- package/player/js/utils/helpers/dynamicProperties.js +29 -0
- package/player/js/utils/helpers/effectTypes.js +3 -0
- package/player/js/utils/helpers/html_elements.js +6 -0
- package/player/js/utils/helpers/propTypes.js +3 -0
- package/player/js/utils/helpers/shapeEnums.js +16 -0
- package/player/js/utils/helpers/svg_elements.js +8 -0
- package/player/js/utils/imagePreloader.js +213 -0
- package/player/js/utils/imagePreloaderWorkerOverride.js +3 -0
- package/player/js/utils/markers/markerParser.js +47 -0
- package/player/js/utils/pooling/bezier_length_pool.js +20 -0
- package/player/js/utils/pooling/point_pool.js +13 -0
- package/player/js/utils/pooling/pool_factory.js +44 -0
- package/player/js/utils/pooling/pooling.js +15 -0
- package/player/js/utils/pooling/segments_length_pool.js +24 -0
- package/player/js/utils/pooling/shapeCollection_pool.js +48 -0
- package/player/js/utils/pooling/shape_pool.js +44 -0
- package/player/js/utils/shapes/DashProperty.js +63 -0
- package/player/js/utils/shapes/GradientProperty.js +93 -0
- package/player/js/utils/shapes/MouseModifier.js +222 -0
- package/player/js/utils/shapes/OffsetPathModifier.js +306 -0
- package/player/js/utils/shapes/PuckerAndBloatModifier.js +80 -0
- package/player/js/utils/shapes/RepeaterModifier.js +232 -0
- package/player/js/utils/shapes/RoundCornersModifier.js +122 -0
- package/player/js/utils/shapes/ShapeCollection.js +29 -0
- package/player/js/utils/shapes/ShapeModifiers.js +71 -0
- package/player/js/utils/shapes/ShapePath.js +100 -0
- package/player/js/utils/shapes/ShapeProperty.js +546 -0
- package/player/js/utils/shapes/TrimModifier.js +359 -0
- package/player/js/utils/shapes/ZigZagModifier.js +174 -0
- package/player/js/utils/shapes/shapePathBuilder.js +20 -0
- package/player/js/utils/text/LetterProps.js +60 -0
- package/player/js/utils/text/TextAnimatorDataProperty.js +34 -0
- package/player/js/utils/text/TextAnimatorProperty.js +610 -0
- package/player/js/utils/text/TextProperty.js +461 -0
- package/player/js/utils/text/TextSelectorProperty.js +179 -0
- package/player/js/worker_wrapper.js +1029 -0
- package/rollup.config.js +215 -0
- package/tasks/build.js +773 -0
- package/tasks/build_worker.js +164 -0
- 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
|
+
};
|