fabric 5.3.0 → 6.0.0-beta3
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 +11 -0
- package/.babelrcAlt +19 -0
- package/.browserslistrc +5 -0
- package/.eslintignore +3 -0
- package/.eslintrc.js +43 -0
- package/.eslintrc.json +38 -46
- package/.eslintrc_tests +12 -0
- package/.gitattributes +2 -0
- package/.gitpod.yml +17 -1
- package/.prettierignore +19 -0
- package/.prettierrc +4 -0
- package/CHANGELOG.md +532 -189
- package/CONTRIBUTING.md +224 -59
- package/README.md +200 -235
- package/bower.json +1 -3
- package/dist/fabric.d.ts +42 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +27582 -0
- package/dist/index.js.map +1 -0
- package/dist/index.min.js +1 -0
- package/dist/index.mjs +27519 -0
- package/dist/index.mjs.map +1 -0
- package/dist/index.node.cjs +27663 -0
- package/dist/index.node.cjs.map +1 -0
- package/dist/index.node.d.ts +14 -0
- package/dist/index.node.mjs +27606 -0
- package/dist/index.node.mjs.map +1 -0
- package/dist/src/ClassRegistry.d.ts +13 -0
- package/dist/src/Collection.d.ts +136 -0
- package/dist/src/CommonMethods.d.ts +32 -0
- package/dist/src/EventTypeDefs.d.ts +227 -0
- package/dist/src/Intersection.d.ts +112 -0
- package/dist/src/Observable.d.ts +60 -0
- package/dist/src/Pattern.d.ts +113 -0
- package/dist/src/Point.d.ts +232 -0
- package/dist/src/Shadow.d.ts +97 -0
- package/dist/src/brushes/BaseBrush.d.ts +105 -0
- package/dist/src/brushes/CircleBrush.d.ts +49 -0
- package/dist/src/brushes/PatternBrush.d.ts +23 -0
- package/dist/src/brushes/PencilBrush.d.ts +92 -0
- package/dist/src/brushes/SprayBrush.d.ts +79 -0
- package/dist/src/cache.d.ts +47 -0
- package/dist/src/canvas/Canvas.d.ts +548 -0
- package/dist/src/canvas/SelectableCanvas.d.ts +754 -0
- package/dist/src/canvas/StaticCanvas.d.ts +778 -0
- package/dist/src/canvas/TextEditingManager.d.ts +17 -0
- package/dist/src/canvas/canvas_gestures.mixin.d.ts +2 -0
- package/dist/src/color/Color.d.ts +174 -0
- package/dist/src/color/color_map.d.ts +155 -0
- package/dist/src/color/constants.d.ts +22 -0
- package/dist/src/color/util.d.ts +12 -0
- package/dist/src/config.d.ts +115 -0
- package/dist/src/constants.d.ts +14 -0
- package/dist/src/controls/Control.d.ts +228 -0
- package/dist/src/controls/changeWidth.d.ts +13 -0
- package/dist/src/controls/commonControls.d.ts +28 -0
- package/dist/src/controls/controlRendering.d.ts +29 -0
- package/dist/src/controls/drag.d.ts +12 -0
- package/dist/src/controls/index.d.ts +13 -0
- package/dist/src/controls/polyControl.d.ts +5 -0
- package/dist/src/controls/rotate.d.ts +12 -0
- package/dist/src/controls/scale.d.ts +47 -0
- package/dist/src/controls/scaleSkew.d.ts +39 -0
- package/dist/src/controls/skew.d.ts +33 -0
- package/dist/src/controls/util.d.ts +41 -0
- package/dist/src/controls/wrapWithFireEvent.d.ts +8 -0
- package/dist/src/controls/wrapWithFixedAnchor.d.ts +9 -0
- package/dist/src/env/browser.d.ts +3 -0
- package/dist/src/env/index.d.ts +15 -0
- package/dist/src/env/node.d.ts +5 -0
- package/dist/src/env/types.d.ts +15 -0
- package/dist/src/filters/BaseFilter.d.ts +153 -0
- package/dist/src/filters/BlendColor.d.ts +80 -0
- package/dist/src/filters/BlendImage.d.ts +92 -0
- package/dist/src/filters/Blur.d.ts +51 -0
- package/dist/src/filters/Boilerplate.d.ts +48 -0
- package/dist/src/filters/Brightness.d.ts +47 -0
- package/dist/src/filters/Canvas2dFilterBackend.d.ts +27 -0
- package/dist/src/filters/ColorMatrix.d.ts +63 -0
- package/dist/src/filters/ColorMatrixFilters.d.ts +545 -0
- package/dist/src/filters/Composed.d.ts +45 -0
- package/dist/src/filters/Contrast.d.ts +45 -0
- package/dist/src/filters/Convolute.d.ts +82 -0
- package/dist/src/filters/FilterBackend.d.ts +14 -0
- package/dist/src/filters/GLProbes/GLProbe.d.ts +11 -0
- package/dist/src/filters/GLProbes/NodeGLProbe.d.ts +11 -0
- package/dist/src/filters/GLProbes/WebGLProbe.d.ts +20 -0
- package/dist/src/filters/Gamma.d.ts +54 -0
- package/dist/src/filters/Grayscale.d.ts +46 -0
- package/dist/src/filters/HueRotation.d.ts +24 -0
- package/dist/src/filters/Invert.d.ts +55 -0
- package/dist/src/filters/Noise.d.ts +54 -0
- package/dist/src/filters/Pixelate.d.ts +44 -0
- package/dist/src/filters/RemoveColor.d.ts +63 -0
- package/dist/src/filters/Resize.d.ts +136 -0
- package/dist/src/filters/Saturation.d.ts +48 -0
- package/dist/src/filters/Vibrance.d.ts +48 -0
- package/dist/src/filters/WebGLFilterBackend.d.ts +126 -0
- package/dist/src/filters/filters.d.ts +21 -0
- package/dist/src/filters/index.d.ts +5 -0
- package/dist/src/filters/shaders/baseFilter.d.ts +4 -0
- package/dist/src/filters/shaders/blendColor.d.ts +13 -0
- package/dist/src/filters/shaders/blendImage.d.ts +3 -0
- package/dist/src/filters/shaders/blur.d.ts +2 -0
- package/dist/src/filters/shaders/brightness.d.ts +2 -0
- package/dist/src/filters/shaders/colorMatrix.d.ts +2 -0
- package/dist/src/filters/shaders/constrast.d.ts +2 -0
- package/dist/src/filters/shaders/convolute.d.ts +11 -0
- package/dist/src/filters/shaders/gamma.d.ts +2 -0
- package/dist/src/filters/shaders/grayscale.d.ts +3 -0
- package/dist/src/filters/shaders/invert.d.ts +2 -0
- package/dist/src/filters/shaders/noise.d.ts +2 -0
- package/dist/src/filters/shaders/pixelate.d.ts +2 -0
- package/dist/src/filters/shaders/removeColor.d.ts +2 -0
- package/dist/src/filters/shaders/saturation.d.ts +2 -0
- package/dist/src/filters/shaders/vibrance.d.ts +2 -0
- package/dist/src/filters/typedefs.d.ts +49 -0
- package/dist/src/gradient/Gradient.d.ts +149 -0
- package/dist/src/gradient/constants.d.ts +15 -0
- package/dist/src/gradient/parser/index.d.ts +4 -0
- package/dist/src/gradient/parser/misc.d.ts +4 -0
- package/dist/src/gradient/parser/parseColorStops.d.ts +3 -0
- package/dist/src/gradient/parser/parseCoords.d.ts +17 -0
- package/dist/src/gradient/typedefs.d.ts +93 -0
- package/dist/src/mixins/eraser_brush.mixin.d.ts +2 -0
- package/dist/src/parkinglot/canvas_animation.mixin.d.ts +2 -0
- package/dist/src/parkinglot/straighten.d.ts +2 -0
- package/dist/src/parser/applyViewboxTransform.d.ts +5 -0
- package/dist/src/parser/attributes.d.ts +6 -0
- package/dist/src/parser/constants.d.ts +53 -0
- package/dist/src/parser/doesSomeParentMatch.d.ts +2 -0
- package/dist/src/parser/elementById.d.ts +6 -0
- package/dist/src/parser/elementMatchesRule.d.ts +5 -0
- package/dist/src/parser/elements_parser.d.ts +3 -0
- package/dist/src/parser/getCSSRules.d.ts +7 -0
- package/dist/src/parser/getGlobalStylesForElement.d.ts +5 -0
- package/dist/src/parser/getGradientDefs.d.ts +7 -0
- package/dist/src/parser/getMultipleNodes.d.ts +2 -0
- package/dist/src/parser/getSvgRegex.d.ts +2 -0
- package/dist/src/parser/hasAncestorWithNodeName.d.ts +2 -0
- package/dist/src/parser/index.d.ts +10 -0
- package/dist/src/parser/loadSVGFromString.d.ts +12 -0
- package/dist/src/parser/loadSVGFromURL.d.ts +13 -0
- package/dist/src/parser/normalizeAttr.d.ts +2 -0
- package/dist/src/parser/normalizeValue.d.ts +2 -0
- package/dist/src/parser/parseAttributes.d.ts +9 -0
- package/dist/src/parser/parseElements.d.ts +11 -0
- package/dist/src/parser/parseFontDeclaration.d.ts +10 -0
- package/dist/src/parser/parsePointsAttribute.d.ts +12 -0
- package/dist/src/parser/parseSVGDocument.d.ts +15 -0
- package/dist/src/parser/parseStyleAttribute.d.ts +9 -0
- package/dist/src/parser/parseStyleObject.d.ts +2 -0
- package/dist/src/parser/parseStyleString.d.ts +2 -0
- package/dist/src/parser/parseTransformAttribute.d.ts +10 -0
- package/dist/src/parser/parseUseDirectives.d.ts +2 -0
- package/dist/src/parser/percent.d.ts +9 -0
- package/dist/src/parser/recursivelyParseGradientsXlink.d.ts +2 -0
- package/dist/src/parser/rotateMatrix.d.ts +2 -0
- package/dist/src/parser/scaleMatrix.d.ts +2 -0
- package/dist/src/parser/selectorMatches.d.ts +2 -0
- package/dist/src/parser/setStrokeFillOpacity.d.ts +6 -0
- package/dist/src/parser/skewMatrix.d.ts +2 -0
- package/dist/src/parser/translateMatrix.d.ts +2 -0
- package/dist/src/shapes/ActiveSelection.d.ts +82 -0
- package/dist/src/shapes/Circle.d.ts +99 -0
- package/dist/src/shapes/Ellipse.d.ts +84 -0
- package/dist/src/shapes/Group.d.ts +408 -0
- package/dist/src/shapes/IText/DraggableTextDelegate.d.ts +78 -0
- package/dist/src/shapes/IText/IText.d.ts +335 -0
- package/dist/src/shapes/IText/ITextBehavior.d.ts +287 -0
- package/dist/src/shapes/IText/ITextClickBehavior.d.ts +83 -0
- package/dist/src/shapes/IText/ITextKeyBehavior.d.ts +195 -0
- package/dist/src/shapes/IText/constants.d.ts +13 -0
- package/dist/src/shapes/Image.d.ts +311 -0
- package/dist/src/shapes/Line.d.ts +126 -0
- package/dist/src/shapes/Object/AnimatableObject.d.ts +33 -0
- package/dist/src/shapes/Object/FabricObject.d.ts +11 -0
- package/dist/src/shapes/Object/FabricObjectSVGExportMixin.d.ts +74 -0
- package/dist/src/shapes/Object/InteractiveObject.d.ts +296 -0
- package/dist/src/shapes/Object/Object.d.ts +594 -0
- package/dist/src/shapes/Object/ObjectGeometry.d.ts +327 -0
- package/dist/src/shapes/Object/ObjectOrigin.d.ts +109 -0
- package/dist/src/shapes/Object/StackedObject.d.ts +72 -0
- package/dist/src/shapes/Object/defaultValues.d.ts +76 -0
- package/dist/src/shapes/Object/types/BaseProps.d.ts +84 -0
- package/dist/src/shapes/Object/types/BorderProps.d.ts +37 -0
- package/dist/src/shapes/Object/types/ControlProps.d.ts +62 -0
- package/dist/src/shapes/Object/types/FabricObjectProps.d.ts +96 -0
- package/dist/src/shapes/Object/types/FillStrokeProps.d.ts +80 -0
- package/dist/src/shapes/Object/types/LockInteractionProps.d.ts +51 -0
- package/dist/src/shapes/Object/types/ObjectProps.d.ts +42 -0
- package/dist/src/shapes/Object/types/SerializedObjectProps.d.ts +66 -0
- package/dist/src/shapes/Object/types/index.d.ts +6 -0
- package/dist/src/shapes/Path.d.ts +130 -0
- package/dist/src/shapes/Polygon.d.ts +9 -0
- package/dist/src/shapes/Polyline.d.ts +140 -0
- package/dist/src/shapes/Rect.d.ts +76 -0
- package/dist/src/shapes/Text/StyledText.d.ts +119 -0
- package/dist/src/shapes/Text/Text.d.ts +673 -0
- package/dist/src/shapes/Text/TextSVGExportMixin.d.ts +32 -0
- package/dist/src/shapes/Text/constants.d.ts +7 -0
- package/dist/src/shapes/Textbox.d.ts +185 -0
- package/dist/src/shapes/Triangle.d.ts +25 -0
- package/dist/src/typedefs.d.ts +90 -0
- package/dist/src/util/animation/AnimationBase.d.ts +54 -0
- package/dist/src/util/animation/AnimationFrameProvider.d.ts +3 -0
- package/dist/src/util/animation/AnimationRegistry.d.ts +29 -0
- package/dist/src/util/animation/ArrayAnimation.d.ts +10 -0
- package/dist/src/util/animation/ColorAnimation.d.ts +11 -0
- package/dist/src/util/animation/ValueAnimation.d.ts +10 -0
- package/dist/src/util/animation/animate.d.ts +37 -0
- package/dist/src/util/animation/easing.d.ts +130 -0
- package/dist/src/util/animation/types.d.ts +87 -0
- package/dist/src/util/applyMixins.d.ts +8 -0
- package/dist/src/util/dom_event.d.ts +5 -0
- package/dist/src/util/dom_misc.d.ts +39 -0
- package/dist/src/util/dom_request.d.ts +14 -0
- package/dist/src/util/dom_style.d.ts +7 -0
- package/dist/src/util/fireEvent.d.ts +3 -0
- package/dist/src/util/index.d.ts +35 -0
- package/dist/src/util/internals/cloneDeep.d.ts +2 -0
- package/dist/src/util/internals/getRandomInt.d.ts +8 -0
- package/dist/src/util/internals/ifNaN.d.ts +8 -0
- package/dist/src/util/internals/index.d.ts +4 -0
- package/dist/src/util/internals/removeFromArray.d.ts +9 -0
- package/dist/src/util/internals/uid.d.ts +2 -0
- package/dist/src/util/lang_string.d.ts +22 -0
- package/dist/src/util/misc/boundingBoxFromPoints.d.ts +9 -0
- package/dist/src/util/misc/capValue.d.ts +2 -0
- package/dist/src/util/misc/cos.d.ts +10 -0
- package/dist/src/util/misc/dom.d.ts +28 -0
- package/dist/src/util/misc/findScaleTo.d.ts +29 -0
- package/dist/src/util/misc/groupSVGElements.d.ts +9 -0
- package/dist/src/util/misc/isTransparent.d.ts +11 -0
- package/dist/src/util/misc/matrix.d.ts +92 -0
- package/dist/src/util/misc/mergeClipPaths.d.ts +23 -0
- package/dist/src/util/misc/objectEnlive.d.ts +56 -0
- package/dist/src/util/misc/objectTransforms.d.ts +68 -0
- package/dist/src/util/misc/pick.d.ts +9 -0
- package/dist/src/util/misc/planeChange.d.ts +84 -0
- package/dist/src/util/misc/projectStroke/StrokeLineCapProjections.d.ts +51 -0
- package/dist/src/util/misc/projectStroke/StrokeLineJoinProjections.d.ts +81 -0
- package/dist/src/util/misc/projectStroke/StrokeProjectionsBase.d.ts +25 -0
- package/dist/src/util/misc/projectStroke/index.d.ts +11 -0
- package/dist/src/util/misc/projectStroke/types.d.ts +23 -0
- package/dist/src/util/misc/radiansDegreesConversion.d.ts +14 -0
- package/dist/src/util/misc/resolveOrigin.d.ts +9 -0
- package/dist/src/util/misc/rotatePoint.d.ts +12 -0
- package/dist/src/util/misc/sin.d.ts +10 -0
- package/dist/src/util/misc/svgParsing.d.ts +53 -0
- package/dist/src/util/misc/textStyles.d.ts +32 -0
- package/dist/src/util/misc/toFixed.d.ts +8 -0
- package/dist/src/util/misc/vectors.d.ts +57 -0
- package/dist/src/util/path/index.d.ts +96 -0
- package/dist/src/util/path/regex.d.ts +3 -0
- package/dist/src/util/path/typechecks.d.ts +24 -0
- package/dist/src/util/path/typedefs.d.ts +220 -0
- package/dist/src/util/transform_matrix_removal.d.ts +14 -0
- package/dist/src/util/types.d.ts +19 -0
- package/fabric.ts +51 -0
- package/index.node.ts +37 -0
- package/index.ts +1 -0
- package/package.json +100 -40
- package/publish.js +0 -26
- package/rollup.config.mjs +91 -0
- package/rollup.test.config.js +24 -0
- package/scripts/build.mjs +50 -0
- package/scripts/buildLock.mjs +115 -0
- package/scripts/buildReporter.mjs +15 -0
- package/scripts/buildStats.mjs +139 -0
- package/scripts/dirname.mjs +14 -0
- package/scripts/git.mjs +36 -0
- package/scripts/index.mjs +564 -0
- package/scripts/sandbox.mjs +149 -0
- package/src/ClassRegistry.ts +56 -0
- package/src/Collection.ts +346 -0
- package/src/CommonMethods.ts +63 -0
- package/src/EventTypeDefs.ts +296 -0
- package/src/Intersection.ts +302 -0
- package/src/Observable.ts +181 -0
- package/src/Pattern.ts +227 -0
- package/src/Point.ts +388 -0
- package/src/Shadow.ts +214 -0
- package/src/brushes/{base_brush.class.js → BaseBrush.ts} +65 -42
- package/src/brushes/CircleBrush.ts +145 -0
- package/src/brushes/PatternBrush.ts +70 -0
- package/src/brushes/PencilBrush.ts +300 -0
- package/src/brushes/SprayBrush.ts +219 -0
- package/src/cache.ts +90 -0
- package/src/canvas/Canvas.ts +1607 -0
- package/src/canvas/SelectableCanvas.ts +1608 -0
- package/src/canvas/StaticCanvas.ts +1734 -0
- package/src/canvas/TextEditingManager.ts +48 -0
- package/src/canvas/canvas_gestures.mixin.ts +207 -0
- package/src/color/Color.ts +404 -0
- package/src/color/color_map.ts +154 -0
- package/src/color/constants.ts +26 -0
- package/src/color/util.ts +32 -0
- package/src/config.ts +159 -0
- package/src/constants.ts +20 -0
- package/src/controls/Control.ts +380 -0
- package/src/controls/changeWidth.ts +52 -0
- package/src/controls/commonControls.ts +105 -0
- package/src/controls/controlRendering.ts +138 -0
- package/src/controls/drag.ts +31 -0
- package/src/controls/index.ts +22 -0
- package/src/controls/polyControl.ts +135 -0
- package/src/controls/rotate.ts +87 -0
- package/src/controls/scale.ts +277 -0
- package/src/controls/scaleSkew.ts +92 -0
- package/src/controls/skew.ts +242 -0
- package/src/controls/util.ts +154 -0
- package/src/controls/wrapWithFireEvent.ts +25 -0
- package/src/controls/wrapWithFixedAnchor.ts +20 -0
- package/src/env/browser.ts +32 -0
- package/src/env/index.ts +24 -0
- package/src/env/node.ts +56 -0
- package/src/env/types.ts +15 -0
- package/src/filters/{base_filter.class.js → BaseFilter.ts} +192 -151
- package/src/filters/BlendColor.ts +217 -0
- package/src/filters/BlendImage.ts +228 -0
- package/src/filters/Blur.ts +179 -0
- package/src/filters/Boilerplate.ts +94 -0
- package/src/filters/Brightness.ts +83 -0
- package/src/filters/Canvas2dFilterBackend.ts +65 -0
- package/src/filters/ColorMatrix.ts +145 -0
- package/src/filters/ColorMatrixFilters.ts +77 -0
- package/src/filters/Composed.ts +76 -0
- package/src/filters/Contrast.ts +82 -0
- package/src/filters/Convolute.ts +184 -0
- package/src/filters/FilterBackend.ts +34 -0
- package/src/filters/GLProbes/GLProbe.ts +11 -0
- package/src/filters/GLProbes/NodeGLProbe.ts +15 -0
- package/src/filters/GLProbes/WebGLProbe.ts +46 -0
- package/src/filters/Gamma.ts +110 -0
- package/src/filters/Grayscale.ts +102 -0
- package/src/filters/HueRotation.ts +62 -0
- package/src/filters/Invert.ts +99 -0
- package/src/filters/Noise.ts +94 -0
- package/src/filters/Pixelate.ts +96 -0
- package/src/filters/RemoveColor.ts +135 -0
- package/src/filters/Resize.ts +538 -0
- package/src/filters/Saturation.ts +87 -0
- package/src/filters/Vibrance.ts +88 -0
- package/src/filters/WebGLFilterBackend.ts +430 -0
- package/src/filters/filters.ts +28 -0
- package/src/filters/index.ts +5 -0
- package/src/filters/shaders/baseFilter.ts +19 -0
- package/src/filters/shaders/blendColor.ts +33 -0
- package/src/filters/shaders/blendImage.ts +32 -0
- package/src/filters/shaders/blur.ts +24 -0
- package/src/filters/shaders/brightness.ts +11 -0
- package/src/filters/shaders/colorMatrix.ts +12 -0
- package/src/filters/shaders/constrast.ts +11 -0
- package/src/filters/shaders/convolute.ts +154 -0
- package/src/filters/shaders/gamma.ts +15 -0
- package/src/filters/shaders/grayscale.ts +36 -0
- package/src/filters/shaders/invert.ts +19 -0
- package/src/filters/shaders/noise.ts +16 -0
- package/src/filters/shaders/pixelate.ts +19 -0
- package/src/filters/shaders/removeColor.ts +13 -0
- package/src/filters/shaders/saturation.ts +15 -0
- package/src/filters/shaders/vibrance.ts +16 -0
- package/src/filters/typedefs.ts +65 -0
- package/src/gradient/Gradient.ts +406 -0
- package/src/gradient/constants.ts +12 -0
- package/src/gradient/parser/index.ts +3 -0
- package/src/gradient/parser/misc.ts +13 -0
- package/src/gradient/parser/parseColorStops.ts +56 -0
- package/src/gradient/parser/parseCoords.ts +73 -0
- package/src/gradient/typedefs.ts +104 -0
- package/src/mixins/{eraser_brush.mixin.js → eraser_brush.mixin.ts} +350 -239
- package/src/parkinglot/canvas_animation.mixin.ts +121 -0
- package/src/parkinglot/straighten.ts +58 -0
- package/src/parser/applyViewboxTransform.ts +157 -0
- package/src/parser/attributes.ts +25 -0
- package/src/parser/constants.ts +115 -0
- package/src/parser/doesSomeParentMatch.ts +19 -0
- package/src/parser/elementById.ts +21 -0
- package/src/parser/elementMatchesRule.ts +16 -0
- package/src/parser/elements_parser.ts +191 -0
- package/src/parser/getCSSRules.ts +62 -0
- package/src/parser/getGlobalStylesForElement.ts +19 -0
- package/src/parser/getGradientDefs.ts +31 -0
- package/src/parser/getMultipleNodes.ts +15 -0
- package/src/parser/getSvgRegex.ts +5 -0
- package/src/parser/hasAncestorWithNodeName.ts +14 -0
- package/src/parser/index.ts +9 -0
- package/src/parser/loadSVGFromString.ts +26 -0
- package/src/parser/loadSVGFromURL.ts +40 -0
- package/src/parser/normalizeAttr.ts +10 -0
- package/src/parser/normalizeValue.ts +63 -0
- package/src/parser/parseAttributes.ts +90 -0
- package/src/parser/parseElements.ts +28 -0
- package/src/parser/parseFontDeclaration.ts +44 -0
- package/src/parser/parsePointsAttribute.ts +34 -0
- package/src/parser/parseSVGDocument.ts +93 -0
- package/src/parser/parseStyleAttribute.ts +27 -0
- package/src/parser/parseStyleObject.ts +15 -0
- package/src/parser/parseStyleString.ts +16 -0
- package/src/parser/parseTransformAttribute.ts +155 -0
- package/src/parser/parseUseDirectives.ts +78 -0
- package/src/parser/percent.ts +27 -0
- package/src/parser/recursivelyParseGradientsXlink.ts +42 -0
- package/src/parser/rotateMatrix.ts +21 -0
- package/src/parser/scaleMatrix.ts +9 -0
- package/src/parser/selectorMatches.ts +25 -0
- package/src/parser/setStrokeFillOpacity.ts +40 -0
- package/src/parser/skewMatrix.ts +6 -0
- package/src/parser/translateMatrix.ts +8 -0
- package/src/shapes/ActiveSelection.ts +189 -0
- package/src/shapes/Circle.ts +242 -0
- package/src/shapes/Ellipse.ts +179 -0
- package/src/shapes/Group.ts +1100 -0
- package/src/shapes/IText/DraggableTextDelegate.ts +382 -0
- package/src/shapes/IText/IText.ts +693 -0
- package/src/shapes/IText/ITextBehavior.ts +1064 -0
- package/src/shapes/IText/ITextClickBehavior.ts +325 -0
- package/src/shapes/IText/ITextKeyBehavior.ts +685 -0
- package/src/shapes/IText/constants.ts +47 -0
- package/src/shapes/Image.ts +841 -0
- package/src/shapes/Line.ts +346 -0
- package/src/shapes/Object/AnimatableObject.ts +106 -0
- package/src/shapes/Object/FabricObject.ts +29 -0
- package/src/shapes/Object/FabricObjectSVGExportMixin.ts +277 -0
- package/src/shapes/Object/InteractiveObject.ts +672 -0
- package/src/shapes/Object/Object.ts +1561 -0
- package/src/shapes/Object/ObjectGeometry.ts +813 -0
- package/src/shapes/Object/ObjectOrigin.ts +276 -0
- package/src/shapes/Object/StackedObject.ts +206 -0
- package/src/shapes/Object/defaultValues.ts +108 -0
- package/src/shapes/Object/types/BaseProps.ts +96 -0
- package/src/shapes/Object/types/BorderProps.ts +40 -0
- package/src/shapes/Object/types/ControlProps.ts +69 -0
- package/src/shapes/Object/types/FabricObjectProps.ts +111 -0
- package/src/shapes/Object/types/FillStrokeProps.ts +90 -0
- package/src/shapes/Object/types/LockInteractionProps.ts +57 -0
- package/src/shapes/Object/types/ObjectProps.ts +46 -0
- package/src/shapes/Object/types/SerializedObjectProps.ts +73 -0
- package/src/shapes/Object/types/index.ts +8 -0
- package/src/shapes/Path.ts +416 -0
- package/src/shapes/Polygon.ts +20 -0
- package/src/shapes/Polyline.ts +359 -0
- package/src/shapes/Rect.ts +233 -0
- package/src/shapes/Text/StyledText.ts +329 -0
- package/src/shapes/Text/Text.ts +1884 -0
- package/src/shapes/Text/TextSVGExportMixin.ts +288 -0
- package/src/shapes/Text/constants.ts +91 -0
- package/src/shapes/Textbox.ts +477 -0
- package/src/shapes/Triangle.ts +60 -0
- package/src/typedefs.ts +115 -0
- package/src/util/animation/AnimationBase.ts +166 -0
- package/src/util/animation/AnimationFrameProvider.ts +9 -0
- package/src/util/animation/AnimationRegistry.ts +58 -0
- package/src/util/animation/ArrayAnimation.ts +27 -0
- package/src/util/animation/ColorAnimation.ts +74 -0
- package/src/util/animation/ValueAnimation.ts +29 -0
- package/src/util/animation/animate.ts +74 -0
- package/src/util/animation/easing.ts +327 -0
- package/src/util/animation/types.ts +136 -0
- package/src/util/applyMixins.ts +22 -0
- package/src/util/dom_event.ts +28 -0
- package/src/util/dom_misc.ts +121 -0
- package/src/util/dom_request.ts +64 -0
- package/src/util/dom_style.ts +20 -0
- package/src/util/fireEvent.ts +15 -0
- package/src/util/index.ts +102 -0
- package/src/util/internals/cloneDeep.ts +2 -0
- package/src/util/internals/getRandomInt.ts +8 -0
- package/src/util/internals/ifNaN.ts +9 -0
- package/src/util/internals/index.ts +3 -0
- package/src/util/internals/removeFromArray.ts +14 -0
- package/src/util/internals/uid.ts +3 -0
- package/src/util/lang_string.ts +79 -0
- package/src/util/misc/boundingBoxFromPoints.ts +37 -0
- package/src/util/misc/capValue.ts +2 -0
- package/src/util/misc/cos.ts +24 -0
- package/src/util/misc/dom.ts +50 -0
- package/src/util/misc/findScaleTo.ts +44 -0
- package/src/util/misc/groupSVGElements.ts +15 -0
- package/src/util/misc/isTransparent.ts +28 -0
- package/src/util/misc/matrix.ts +207 -0
- package/src/util/misc/mergeClipPaths.ts +40 -0
- package/src/util/misc/objectEnlive.ts +189 -0
- package/src/util/misc/objectTransforms.ts +129 -0
- package/src/util/misc/pick.ts +29 -0
- package/src/util/misc/planeChange.ts +136 -0
- package/src/util/misc/projectStroke/StrokeLineCapProjections.ts +112 -0
- package/src/util/misc/projectStroke/StrokeLineJoinProjections.ts +226 -0
- package/src/util/misc/projectStroke/StrokeProjectionsBase.ts +75 -0
- package/src/util/misc/projectStroke/index.ts +53 -0
- package/src/util/misc/projectStroke/types.ts +24 -0
- package/src/util/misc/radiansDegreesConversion.ts +18 -0
- package/src/util/misc/resolveOrigin.ts +22 -0
- package/src/util/misc/rotatePoint.ts +15 -0
- package/src/util/misc/sin.ts +26 -0
- package/src/util/misc/svgParsing.ts +181 -0
- package/src/util/misc/textStyles.ts +134 -0
- package/src/util/misc/toFixed.ts +8 -0
- package/src/util/misc/vectors.ts +82 -0
- package/src/util/path/index.ts +1038 -0
- package/src/util/path/regex.ts +41 -0
- package/src/util/path/typechecks.ts +145 -0
- package/src/util/path/typedefs.ts +305 -0
- package/src/util/transform_matrix_removal.ts +60 -0
- package/src/util/types.ts +78 -0
- package/tsconfig.json +106 -0
- package/HEADER.js +0 -203
- package/build.js +0 -287
- package/dist/fabric.js +0 -31187
- package/dist/fabric.min.js +0 -1
- package/old-travis-reference.yml +0 -97
- package/src/brushes/circle_brush.class.js +0 -144
- package/src/brushes/pattern_brush.class.js +0 -61
- package/src/brushes/pencil_brush.class.js +0 -310
- package/src/brushes/spray_brush.class.js +0 -219
- package/src/canvas.class.js +0 -1312
- package/src/color.class.js +0 -636
- package/src/control.class.js +0 -339
- package/src/controls.actions.js +0 -740
- package/src/controls.render.js +0 -99
- package/src/elements_parser.js +0 -152
- package/src/filters/2d_backend.class.js +0 -65
- package/src/filters/blendcolor_filter.class.js +0 -251
- package/src/filters/blendimage_filter.class.js +0 -247
- package/src/filters/blur_filter.class.js +0 -217
- package/src/filters/brightness_filter.class.js +0 -113
- package/src/filters/colormatrix_filter.class.js +0 -159
- package/src/filters/composed_filter.class.js +0 -72
- package/src/filters/contrast_filter.class.js +0 -113
- package/src/filters/convolute_filter.class.js +0 -352
- package/src/filters/filter_boilerplate.js +0 -111
- package/src/filters/filter_generator.js +0 -85
- package/src/filters/gamma_filter.class.js +0 -136
- package/src/filters/grayscale_filter.class.js +0 -154
- package/src/filters/hue_rotation.class.js +0 -107
- package/src/filters/invert_filter.class.js +0 -111
- package/src/filters/noise_filter.class.js +0 -134
- package/src/filters/pixelate_filter.class.js +0 -137
- package/src/filters/removecolor_filter.class.js +0 -173
- package/src/filters/resize_filter.class.js +0 -490
- package/src/filters/saturate_filter.class.js +0 -119
- package/src/filters/vibrance_filter.class.js +0 -122
- package/src/filters/webgl_backend.class.js +0 -396
- package/src/globalFabric.js +0 -4
- package/src/gradient.class.js +0 -490
- package/src/intersection.class.js +0 -172
- package/src/log.js +0 -11
- package/src/mixins/animation.mixin.js +0 -231
- package/src/mixins/canvas_dataurl_exporter.mixin.js +0 -97
- package/src/mixins/canvas_events.mixin.js +0 -974
- package/src/mixins/canvas_gestures.mixin.js +0 -149
- package/src/mixins/canvas_grouping.mixin.js +0 -177
- package/src/mixins/canvas_serialization.mixin.js +0 -228
- package/src/mixins/collection.mixin.js +0 -170
- package/src/mixins/default_controls.js +0 -114
- package/src/mixins/itext.svg_export.js +0 -241
- package/src/mixins/itext_behavior.mixin.js +0 -940
- package/src/mixins/itext_click_behavior.mixin.js +0 -278
- package/src/mixins/itext_key_behavior.mixin.js +0 -694
- package/src/mixins/object.svg_export.js +0 -258
- package/src/mixins/object_geometry.mixin.js +0 -683
- package/src/mixins/object_interactivity.mixin.js +0 -314
- package/src/mixins/object_origin.mixin.js +0 -255
- package/src/mixins/object_stacking.mixin.js +0 -80
- package/src/mixins/object_straightening.mixin.js +0 -80
- package/src/mixins/observable.mixin.js +0 -141
- package/src/mixins/shared_methods.mixin.js +0 -94
- package/src/mixins/stateful.mixin.js +0 -107
- package/src/mixins/text_style.mixin.js +0 -324
- package/src/parser.js +0 -1090
- package/src/pattern.class.js +0 -189
- package/src/point.class.js +0 -337
- package/src/shadow.class.js +0 -195
- package/src/shapes/active_selection.class.js +0 -155
- package/src/shapes/circle.class.js +0 -210
- package/src/shapes/ellipse.class.js +0 -181
- package/src/shapes/group.class.js +0 -593
- package/src/shapes/image.class.js +0 -764
- package/src/shapes/itext.class.js +0 -526
- package/src/shapes/line.class.js +0 -324
- package/src/shapes/object.class.js +0 -2008
- package/src/shapes/path.class.js +0 -384
- package/src/shapes/polygon.class.js +0 -81
- package/src/shapes/polyline.class.js +0 -268
- package/src/shapes/rect.class.js +0 -187
- package/src/shapes/text.class.js +0 -1696
- package/src/shapes/textbox.class.js +0 -461
- package/src/shapes/triangle.class.js +0 -93
- package/src/static_canvas.class.js +0 -1881
- package/src/util/anim_ease.js +0 -398
- package/src/util/animate.js +0 -254
- package/src/util/animate_color.js +0 -74
- package/src/util/dom_event.js +0 -50
- package/src/util/dom_misc.js +0 -300
- package/src/util/dom_request.js +0 -54
- package/src/util/dom_style.js +0 -70
- package/src/util/lang_array.js +0 -94
- package/src/util/lang_class.js +0 -115
- package/src/util/lang_object.js +0 -75
- package/src/util/lang_string.js +0 -110
- package/src/util/misc.js +0 -1330
- package/src/util/named_accessors.mixin.js +0 -428
- package/src/util/path.js +0 -829
|
@@ -0,0 +1,430 @@
|
|
|
1
|
+
import { getWindow } from '../env';
|
|
2
|
+
import { config } from '../config';
|
|
3
|
+
import { createCanvasElement } from '../util/misc/dom';
|
|
4
|
+
import {
|
|
5
|
+
TWebGLPipelineState,
|
|
6
|
+
TProgramCache,
|
|
7
|
+
TTextureCache,
|
|
8
|
+
TPipelineResources,
|
|
9
|
+
} from './typedefs';
|
|
10
|
+
|
|
11
|
+
export class WebGLFilterBackend {
|
|
12
|
+
declare tileSize: number;
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Define ...
|
|
16
|
+
**/
|
|
17
|
+
aPosition: Float32Array = new Float32Array([0, 0, 0, 1, 1, 0, 1, 1]);
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* If GLPut data is the fastest operation, or if forced, this buffer will be used
|
|
21
|
+
* to transfer the data back in the 2d logic
|
|
22
|
+
**/
|
|
23
|
+
declare imageBuffer?: ArrayBuffer;
|
|
24
|
+
|
|
25
|
+
declare canvas: HTMLCanvasElement;
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* The Webgl context that will execute the operations for filtering
|
|
29
|
+
**/
|
|
30
|
+
declare gl: WebGLRenderingContext;
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* Keyed map for shader cache
|
|
34
|
+
**/
|
|
35
|
+
declare programCache: TProgramCache;
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Keyed map for texture cache
|
|
39
|
+
**/
|
|
40
|
+
declare textureCache: TTextureCache;
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Contains GPU info for debug
|
|
44
|
+
**/
|
|
45
|
+
declare gpuInfo: any;
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* Experimental. This object is a sort of repository of help layers used to avoid
|
|
49
|
+
* of recreating them during frequent filtering. If you are previewing a filter with
|
|
50
|
+
* a slider you probably do not want to create help layers every filter step.
|
|
51
|
+
* in this object there will be appended some canvases, created once, resized sometimes
|
|
52
|
+
* cleared never. Clearing is left to the developer.
|
|
53
|
+
**/
|
|
54
|
+
resources: TPipelineResources = {};
|
|
55
|
+
|
|
56
|
+
constructor({ tileSize = config.textureSize } = {}) {
|
|
57
|
+
this.tileSize = tileSize;
|
|
58
|
+
this.setupGLContext(tileSize, tileSize);
|
|
59
|
+
this.captureGPUInfo();
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
/**
|
|
63
|
+
* Setup a WebGL context suitable for filtering, and bind any needed event handlers.
|
|
64
|
+
*/
|
|
65
|
+
setupGLContext(width: number, height: number): void {
|
|
66
|
+
this.dispose();
|
|
67
|
+
this.createWebGLCanvas(width, height);
|
|
68
|
+
// eslint-disable-next-line
|
|
69
|
+
this.chooseFastestCopyGLTo2DMethod(width, height);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* Pick a method to copy data from GL context to 2d canvas. In some browsers using
|
|
74
|
+
* drawImage should be faster, but is also bugged for a small combination of old hardware
|
|
75
|
+
* and drivers.
|
|
76
|
+
* putImageData is faster than drawImage for that specific operation.
|
|
77
|
+
*/
|
|
78
|
+
chooseFastestCopyGLTo2DMethod(width: number, height: number): void {
|
|
79
|
+
const targetCanvas = createCanvasElement();
|
|
80
|
+
// eslint-disable-next-line no-undef
|
|
81
|
+
const imageBuffer = new ArrayBuffer(width * height * 4);
|
|
82
|
+
if (config.forceGLPutImageData) {
|
|
83
|
+
this.imageBuffer = imageBuffer;
|
|
84
|
+
this.copyGLTo2D = copyGLTo2DPutImageData;
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
const testContext = {
|
|
89
|
+
imageBuffer: imageBuffer,
|
|
90
|
+
} as unknown as Required<WebGLFilterBackend>;
|
|
91
|
+
const testPipelineState = {
|
|
92
|
+
destinationWidth: width,
|
|
93
|
+
destinationHeight: height,
|
|
94
|
+
targetCanvas: targetCanvas,
|
|
95
|
+
} as unknown as TWebGLPipelineState;
|
|
96
|
+
let startTime;
|
|
97
|
+
targetCanvas.width = width;
|
|
98
|
+
targetCanvas.height = height;
|
|
99
|
+
|
|
100
|
+
startTime = getWindow().performance.now();
|
|
101
|
+
this.copyGLTo2D.call(testContext, this.gl, testPipelineState);
|
|
102
|
+
const drawImageTime = getWindow().performance.now() - startTime;
|
|
103
|
+
|
|
104
|
+
startTime = getWindow().performance.now();
|
|
105
|
+
copyGLTo2DPutImageData.call(testContext, this.gl, testPipelineState);
|
|
106
|
+
const putImageDataTime = getWindow().performance.now() - startTime;
|
|
107
|
+
|
|
108
|
+
if (drawImageTime > putImageDataTime) {
|
|
109
|
+
this.imageBuffer = imageBuffer;
|
|
110
|
+
this.copyGLTo2D = copyGLTo2DPutImageData;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* Create a canvas element and associated WebGL context and attaches them as
|
|
116
|
+
* class properties to the GLFilterBackend class.
|
|
117
|
+
*/
|
|
118
|
+
createWebGLCanvas(width: number, height: number): void {
|
|
119
|
+
const canvas = createCanvasElement();
|
|
120
|
+
canvas.width = width;
|
|
121
|
+
canvas.height = height;
|
|
122
|
+
const glOptions = {
|
|
123
|
+
alpha: true,
|
|
124
|
+
premultipliedAlpha: false,
|
|
125
|
+
depth: false,
|
|
126
|
+
stencil: false,
|
|
127
|
+
antialias: false,
|
|
128
|
+
},
|
|
129
|
+
gl = canvas.getContext('webgl', glOptions) as WebGLRenderingContext;
|
|
130
|
+
|
|
131
|
+
if (!gl) {
|
|
132
|
+
return;
|
|
133
|
+
}
|
|
134
|
+
gl.clearColor(0, 0, 0, 0);
|
|
135
|
+
// this canvas can fire webglcontextlost and webglcontextrestored
|
|
136
|
+
this.canvas = canvas;
|
|
137
|
+
this.gl = gl;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
/**
|
|
141
|
+
* Attempts to apply the requested filters to the source provided, drawing the filtered output
|
|
142
|
+
* to the provided target canvas.
|
|
143
|
+
*
|
|
144
|
+
* @param {Array} filters The filters to apply.
|
|
145
|
+
* @param {TexImageSource} source The source to be filtered.
|
|
146
|
+
* @param {Number} width The width of the source input.
|
|
147
|
+
* @param {Number} height The height of the source input.
|
|
148
|
+
* @param {HTMLCanvasElement} targetCanvas The destination for filtered output to be drawn.
|
|
149
|
+
* @param {String|undefined} cacheKey A key used to cache resources related to the source. If
|
|
150
|
+
* omitted, caching will be skipped.
|
|
151
|
+
*/
|
|
152
|
+
applyFilters(
|
|
153
|
+
filters: any[],
|
|
154
|
+
source: TexImageSource,
|
|
155
|
+
width: number,
|
|
156
|
+
height: number,
|
|
157
|
+
targetCanvas: HTMLCanvasElement,
|
|
158
|
+
cacheKey?: string
|
|
159
|
+
): TWebGLPipelineState | undefined {
|
|
160
|
+
const gl = this.gl;
|
|
161
|
+
const ctx = targetCanvas.getContext('2d');
|
|
162
|
+
if (!gl || !ctx) {
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
let cachedTexture;
|
|
166
|
+
if (cacheKey) {
|
|
167
|
+
cachedTexture = this.getCachedTexture(cacheKey, source);
|
|
168
|
+
}
|
|
169
|
+
const pipelineState: TWebGLPipelineState = {
|
|
170
|
+
// @ts-ignore
|
|
171
|
+
originalWidth: source.width || source.originalWidth || 0,
|
|
172
|
+
// @ts-ignore
|
|
173
|
+
originalHeight: source.height || source.originalHeight || 0,
|
|
174
|
+
sourceWidth: width,
|
|
175
|
+
sourceHeight: height,
|
|
176
|
+
destinationWidth: width,
|
|
177
|
+
destinationHeight: height,
|
|
178
|
+
context: gl,
|
|
179
|
+
sourceTexture: this.createTexture(
|
|
180
|
+
gl,
|
|
181
|
+
width,
|
|
182
|
+
height,
|
|
183
|
+
!cachedTexture ? source : undefined
|
|
184
|
+
),
|
|
185
|
+
targetTexture: this.createTexture(gl, width, height),
|
|
186
|
+
originalTexture:
|
|
187
|
+
cachedTexture ||
|
|
188
|
+
this.createTexture(
|
|
189
|
+
gl,
|
|
190
|
+
width,
|
|
191
|
+
height,
|
|
192
|
+
!cachedTexture ? source : undefined
|
|
193
|
+
),
|
|
194
|
+
passes: filters.length,
|
|
195
|
+
webgl: true,
|
|
196
|
+
aPosition: this.aPosition,
|
|
197
|
+
programCache: this.programCache,
|
|
198
|
+
pass: 0,
|
|
199
|
+
filterBackend: this,
|
|
200
|
+
targetCanvas: targetCanvas,
|
|
201
|
+
};
|
|
202
|
+
const tempFbo = gl.createFramebuffer();
|
|
203
|
+
gl.bindFramebuffer(gl.FRAMEBUFFER, tempFbo);
|
|
204
|
+
filters.forEach((filter: any) => {
|
|
205
|
+
filter && filter.applyTo(pipelineState);
|
|
206
|
+
});
|
|
207
|
+
resizeCanvasIfNeeded(pipelineState);
|
|
208
|
+
this.copyGLTo2D(gl, pipelineState);
|
|
209
|
+
gl.bindTexture(gl.TEXTURE_2D, null);
|
|
210
|
+
gl.deleteTexture(pipelineState.sourceTexture);
|
|
211
|
+
gl.deleteTexture(pipelineState.targetTexture);
|
|
212
|
+
gl.deleteFramebuffer(tempFbo);
|
|
213
|
+
ctx.setTransform(1, 0, 0, 1, 0, 0);
|
|
214
|
+
return pipelineState;
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
/**
|
|
218
|
+
* Detach event listeners, remove references, and clean up caches.
|
|
219
|
+
*/
|
|
220
|
+
dispose() {
|
|
221
|
+
if (this.canvas) {
|
|
222
|
+
// we are disposing, we don't care about the fact
|
|
223
|
+
// that the canvas shouldn't be null.
|
|
224
|
+
// @ts-ignore
|
|
225
|
+
this.canvas = null;
|
|
226
|
+
// @ts-ignore
|
|
227
|
+
this.gl = null;
|
|
228
|
+
}
|
|
229
|
+
this.clearWebGLCaches();
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
/**
|
|
233
|
+
* Wipe out WebGL-related caches.
|
|
234
|
+
*/
|
|
235
|
+
clearWebGLCaches() {
|
|
236
|
+
this.programCache = {};
|
|
237
|
+
this.textureCache = {};
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
/**
|
|
241
|
+
* Create a WebGL texture object.
|
|
242
|
+
*
|
|
243
|
+
* Accepts specific dimensions to initialize the texture to or a source image.
|
|
244
|
+
*
|
|
245
|
+
* @param {WebGLRenderingContext} gl The GL context to use for creating the texture.
|
|
246
|
+
* @param {Number} width The width to initialize the texture at.
|
|
247
|
+
* @param {Number} height The height to initialize the texture.
|
|
248
|
+
* @param {HTMLImageElement|HTMLCanvasElement} textureImageSource A source for the texture data.
|
|
249
|
+
* @returns {WebGLTexture}
|
|
250
|
+
*/
|
|
251
|
+
createTexture(
|
|
252
|
+
gl: WebGLRenderingContext,
|
|
253
|
+
width: number,
|
|
254
|
+
height: number,
|
|
255
|
+
textureImageSource?: TexImageSource
|
|
256
|
+
) {
|
|
257
|
+
const texture = gl.createTexture();
|
|
258
|
+
gl.bindTexture(gl.TEXTURE_2D, texture);
|
|
259
|
+
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);
|
|
260
|
+
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);
|
|
261
|
+
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);
|
|
262
|
+
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);
|
|
263
|
+
if (textureImageSource) {
|
|
264
|
+
gl.texImage2D(
|
|
265
|
+
gl.TEXTURE_2D,
|
|
266
|
+
0,
|
|
267
|
+
gl.RGBA,
|
|
268
|
+
gl.RGBA,
|
|
269
|
+
gl.UNSIGNED_BYTE,
|
|
270
|
+
textureImageSource
|
|
271
|
+
);
|
|
272
|
+
} else {
|
|
273
|
+
gl.texImage2D(
|
|
274
|
+
gl.TEXTURE_2D,
|
|
275
|
+
0,
|
|
276
|
+
gl.RGBA,
|
|
277
|
+
width,
|
|
278
|
+
height,
|
|
279
|
+
0,
|
|
280
|
+
gl.RGBA,
|
|
281
|
+
gl.UNSIGNED_BYTE,
|
|
282
|
+
null
|
|
283
|
+
);
|
|
284
|
+
}
|
|
285
|
+
return texture;
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
/**
|
|
289
|
+
* Can be optionally used to get a texture from the cache array
|
|
290
|
+
*
|
|
291
|
+
* If an existing texture is not found, a new texture is created and cached.
|
|
292
|
+
*
|
|
293
|
+
* @param {String} uniqueId A cache key to use to find an existing texture.
|
|
294
|
+
* @param {HTMLImageElement|HTMLCanvasElement} textureImageSource A source to use to create the
|
|
295
|
+
* texture cache entry if one does not already exist.
|
|
296
|
+
*/
|
|
297
|
+
getCachedTexture(uniqueId: string, textureImageSource: TexImageSource) {
|
|
298
|
+
if (this.textureCache[uniqueId]) {
|
|
299
|
+
return this.textureCache[uniqueId];
|
|
300
|
+
} else {
|
|
301
|
+
const texture = this.createTexture(
|
|
302
|
+
this.gl,
|
|
303
|
+
textureImageSource.width,
|
|
304
|
+
textureImageSource.height,
|
|
305
|
+
textureImageSource
|
|
306
|
+
);
|
|
307
|
+
this.textureCache[uniqueId] = texture;
|
|
308
|
+
return texture;
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
|
|
312
|
+
/**
|
|
313
|
+
* Clear out cached resources related to a source image that has been
|
|
314
|
+
* filtered previously.
|
|
315
|
+
*
|
|
316
|
+
* @param {String} cacheKey The cache key provided when the source image was filtered.
|
|
317
|
+
*/
|
|
318
|
+
evictCachesForKey(cacheKey: string) {
|
|
319
|
+
if (this.textureCache[cacheKey]) {
|
|
320
|
+
this.gl.deleteTexture(this.textureCache[cacheKey]);
|
|
321
|
+
delete this.textureCache[cacheKey];
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
|
|
325
|
+
/**
|
|
326
|
+
* Copy an input WebGL canvas on to an output 2D canvas.
|
|
327
|
+
*
|
|
328
|
+
* The WebGL canvas is assumed to be upside down, with the top-left pixel of the
|
|
329
|
+
* desired output image appearing in the bottom-left corner of the WebGL canvas.
|
|
330
|
+
*
|
|
331
|
+
* @param {WebGLRenderingContext} sourceContext The WebGL context to copy from.
|
|
332
|
+
* @param {Object} pipelineState The 2D target canvas to copy on to.
|
|
333
|
+
*/
|
|
334
|
+
copyGLTo2D(gl: WebGLRenderingContext, pipelineState: TWebGLPipelineState) {
|
|
335
|
+
const glCanvas = gl.canvas,
|
|
336
|
+
targetCanvas = pipelineState.targetCanvas,
|
|
337
|
+
ctx = targetCanvas.getContext('2d');
|
|
338
|
+
if (!ctx) {
|
|
339
|
+
return;
|
|
340
|
+
}
|
|
341
|
+
ctx.translate(0, targetCanvas.height); // move it down again
|
|
342
|
+
ctx.scale(1, -1); // vertical flip
|
|
343
|
+
// where is my image on the big glcanvas?
|
|
344
|
+
const sourceY = glCanvas.height - targetCanvas.height;
|
|
345
|
+
ctx.drawImage(
|
|
346
|
+
glCanvas,
|
|
347
|
+
0,
|
|
348
|
+
sourceY,
|
|
349
|
+
targetCanvas.width,
|
|
350
|
+
targetCanvas.height,
|
|
351
|
+
0,
|
|
352
|
+
0,
|
|
353
|
+
targetCanvas.width,
|
|
354
|
+
targetCanvas.height
|
|
355
|
+
);
|
|
356
|
+
}
|
|
357
|
+
|
|
358
|
+
/**
|
|
359
|
+
* Attempt to extract GPU information strings from a WebGL context.
|
|
360
|
+
*
|
|
361
|
+
* Useful information when debugging or blacklisting specific GPUs.
|
|
362
|
+
*
|
|
363
|
+
* @returns {Object} A GPU info object with renderer and vendor strings.
|
|
364
|
+
*/
|
|
365
|
+
captureGPUInfo() {
|
|
366
|
+
if (this.gpuInfo) {
|
|
367
|
+
return this.gpuInfo;
|
|
368
|
+
}
|
|
369
|
+
const gl = this.gl,
|
|
370
|
+
gpuInfo = { renderer: '', vendor: '' };
|
|
371
|
+
if (!gl) {
|
|
372
|
+
return gpuInfo;
|
|
373
|
+
}
|
|
374
|
+
const ext = gl.getExtension('WEBGL_debug_renderer_info');
|
|
375
|
+
if (ext) {
|
|
376
|
+
const renderer = gl.getParameter(ext.UNMASKED_RENDERER_WEBGL);
|
|
377
|
+
const vendor = gl.getParameter(ext.UNMASKED_VENDOR_WEBGL);
|
|
378
|
+
if (renderer) {
|
|
379
|
+
gpuInfo.renderer = renderer.toLowerCase();
|
|
380
|
+
}
|
|
381
|
+
if (vendor) {
|
|
382
|
+
gpuInfo.vendor = vendor.toLowerCase();
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
this.gpuInfo = gpuInfo;
|
|
386
|
+
return gpuInfo;
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
|
|
390
|
+
function resizeCanvasIfNeeded(pipelineState: TWebGLPipelineState): void {
|
|
391
|
+
const targetCanvas = pipelineState.targetCanvas,
|
|
392
|
+
width = targetCanvas.width,
|
|
393
|
+
height = targetCanvas.height,
|
|
394
|
+
dWidth = pipelineState.destinationWidth,
|
|
395
|
+
dHeight = pipelineState.destinationHeight;
|
|
396
|
+
|
|
397
|
+
if (width !== dWidth || height !== dHeight) {
|
|
398
|
+
targetCanvas.width = dWidth;
|
|
399
|
+
targetCanvas.height = dHeight;
|
|
400
|
+
}
|
|
401
|
+
}
|
|
402
|
+
|
|
403
|
+
/**
|
|
404
|
+
* Copy an input WebGL canvas on to an output 2D canvas using 2d canvas' putImageData
|
|
405
|
+
* API. Measurably faster than using ctx.drawImage in Firefox (version 54 on OSX Sierra).
|
|
406
|
+
*
|
|
407
|
+
* @param {WebGLRenderingContext} sourceContext The WebGL context to copy from.
|
|
408
|
+
* @param {HTMLCanvasElement} targetCanvas The 2D target canvas to copy on to.
|
|
409
|
+
* @param {Object} pipelineState The 2D target canvas to copy on to.
|
|
410
|
+
*/
|
|
411
|
+
function copyGLTo2DPutImageData(
|
|
412
|
+
this: Required<WebGLFilterBackend>,
|
|
413
|
+
gl: WebGLRenderingContext,
|
|
414
|
+
pipelineState: TWebGLPipelineState
|
|
415
|
+
) {
|
|
416
|
+
const targetCanvas = pipelineState.targetCanvas,
|
|
417
|
+
ctx = targetCanvas.getContext('2d'),
|
|
418
|
+
dWidth = pipelineState.destinationWidth,
|
|
419
|
+
dHeight = pipelineState.destinationHeight,
|
|
420
|
+
numBytes = dWidth * dHeight * 4;
|
|
421
|
+
if (!ctx) {
|
|
422
|
+
return;
|
|
423
|
+
}
|
|
424
|
+
const u8 = new Uint8Array(this.imageBuffer, 0, numBytes);
|
|
425
|
+
const u8Clamped = new Uint8ClampedArray(this.imageBuffer, 0, numBytes);
|
|
426
|
+
|
|
427
|
+
gl.readPixels(0, 0, dWidth, dHeight, gl.RGBA, gl.UNSIGNED_BYTE, u8);
|
|
428
|
+
const imgData = new ImageData(u8Clamped, dWidth, dHeight);
|
|
429
|
+
ctx.putImageData(imgData, 0, 0);
|
|
430
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export { BaseFilter } from './BaseFilter';
|
|
2
|
+
export { BlendColor } from './BlendColor';
|
|
3
|
+
export { BlendImage } from './BlendImage';
|
|
4
|
+
export { Blur } from './Blur';
|
|
5
|
+
export { Brightness } from './Brightness';
|
|
6
|
+
export { ColorMatrix } from './ColorMatrix';
|
|
7
|
+
export {
|
|
8
|
+
BlackWhite,
|
|
9
|
+
Brownie,
|
|
10
|
+
Kodachrome,
|
|
11
|
+
Polaroid,
|
|
12
|
+
Sepia,
|
|
13
|
+
Technicolor,
|
|
14
|
+
Vintage,
|
|
15
|
+
} from './ColorMatrixFilters';
|
|
16
|
+
export { Composed } from './Composed';
|
|
17
|
+
export { Contrast } from './Contrast';
|
|
18
|
+
export { Convolute } from './Convolute';
|
|
19
|
+
export { Gamma } from './Gamma';
|
|
20
|
+
export { Grayscale } from './Grayscale';
|
|
21
|
+
export { HueRotation } from './HueRotation';
|
|
22
|
+
export { Invert } from './Invert';
|
|
23
|
+
export { Noise } from './Noise';
|
|
24
|
+
export { Pixelate } from './Pixelate';
|
|
25
|
+
export { RemoveColor } from './RemoveColor';
|
|
26
|
+
export { Resize } from './Resize';
|
|
27
|
+
export { Saturation } from './Saturation';
|
|
28
|
+
export { Vibrance } from './Vibrance';
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { GLPrecision } from '../GLProbes/GLProbe';
|
|
2
|
+
|
|
3
|
+
export const highPsourceCode = `precision ${GLPrecision.high} float`;
|
|
4
|
+
|
|
5
|
+
export const identityFragmentShader = `
|
|
6
|
+
${highPsourceCode};
|
|
7
|
+
varying vec2 vTexCoord;
|
|
8
|
+
uniform sampler2D uTexture;
|
|
9
|
+
void main() {
|
|
10
|
+
gl_FragColor = texture2D(uTexture, vTexCoord);
|
|
11
|
+
}`;
|
|
12
|
+
|
|
13
|
+
export const vertexSource = `
|
|
14
|
+
attribute vec2 aPosition;
|
|
15
|
+
varying vec2 vTexCoord;
|
|
16
|
+
void main() {
|
|
17
|
+
vTexCoord = aPosition;
|
|
18
|
+
gl_Position = vec4(aPosition * 2.0 - 1.0, 0.0, 1.0);
|
|
19
|
+
}`;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
export const blendColorFragmentSource = {
|
|
2
|
+
multiply: 'gl_FragColor.rgb *= uColor.rgb;\n',
|
|
3
|
+
screen:
|
|
4
|
+
'gl_FragColor.rgb = 1.0 - (1.0 - gl_FragColor.rgb) * (1.0 - uColor.rgb);\n',
|
|
5
|
+
add: 'gl_FragColor.rgb += uColor.rgb;\n',
|
|
6
|
+
difference: 'gl_FragColor.rgb = abs(gl_FragColor.rgb - uColor.rgb);\n',
|
|
7
|
+
subtract: 'gl_FragColor.rgb -= uColor.rgb;\n',
|
|
8
|
+
lighten: 'gl_FragColor.rgb = max(gl_FragColor.rgb, uColor.rgb);\n',
|
|
9
|
+
darken: 'gl_FragColor.rgb = min(gl_FragColor.rgb, uColor.rgb);\n',
|
|
10
|
+
exclusion:
|
|
11
|
+
'gl_FragColor.rgb += uColor.rgb - 2.0 * (uColor.rgb * gl_FragColor.rgb);\n',
|
|
12
|
+
overlay: `
|
|
13
|
+
if (uColor.r < 0.5) {
|
|
14
|
+
gl_FragColor.r *= 2.0 * uColor.r;
|
|
15
|
+
} else {
|
|
16
|
+
gl_FragColor.r = 1.0 - 2.0 * (1.0 - gl_FragColor.r) * (1.0 - uColor.r);
|
|
17
|
+
}
|
|
18
|
+
if (uColor.g < 0.5) {
|
|
19
|
+
gl_FragColor.g *= 2.0 * uColor.g;
|
|
20
|
+
} else {
|
|
21
|
+
gl_FragColor.g = 1.0 - 2.0 * (1.0 - gl_FragColor.g) * (1.0 - uColor.g);
|
|
22
|
+
}
|
|
23
|
+
if (uColor.b < 0.5) {
|
|
24
|
+
gl_FragColor.b *= 2.0 * uColor.b;
|
|
25
|
+
} else {
|
|
26
|
+
gl_FragColor.b = 1.0 - 2.0 * (1.0 - gl_FragColor.b) * (1.0 - uColor.b);
|
|
27
|
+
}
|
|
28
|
+
`,
|
|
29
|
+
tint: `
|
|
30
|
+
gl_FragColor.rgb *= (1.0 - uColor.a);
|
|
31
|
+
gl_FragColor.rgb += uColor.rgb;
|
|
32
|
+
`,
|
|
33
|
+
} as const;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { TBlendImageMode } from '../BlendImage';
|
|
2
|
+
|
|
3
|
+
export const fragmentSource: Record<TBlendImageMode, string> = {
|
|
4
|
+
multiply: `
|
|
5
|
+
precision highp float;
|
|
6
|
+
uniform sampler2D uTexture;
|
|
7
|
+
uniform sampler2D uImage;
|
|
8
|
+
uniform vec4 uColor;
|
|
9
|
+
varying vec2 vTexCoord;
|
|
10
|
+
varying vec2 vTexCoord2;
|
|
11
|
+
void main() {
|
|
12
|
+
vec4 color = texture2D(uTexture, vTexCoord);
|
|
13
|
+
vec4 color2 = texture2D(uImage, vTexCoord2);
|
|
14
|
+
color.rgba *= color2.rgba;
|
|
15
|
+
gl_FragColor = color;
|
|
16
|
+
}
|
|
17
|
+
`,
|
|
18
|
+
mask: `
|
|
19
|
+
precision highp float;
|
|
20
|
+
uniform sampler2D uTexture;
|
|
21
|
+
uniform sampler2D uImage;
|
|
22
|
+
uniform vec4 uColor;
|
|
23
|
+
varying vec2 vTexCoord;
|
|
24
|
+
varying vec2 vTexCoord2;
|
|
25
|
+
void main() {
|
|
26
|
+
vec4 color = texture2D(uTexture, vTexCoord);
|
|
27
|
+
vec4 color2 = texture2D(uImage, vTexCoord2);
|
|
28
|
+
color.a = color2.a;
|
|
29
|
+
gl_FragColor = color;
|
|
30
|
+
}
|
|
31
|
+
`,
|
|
32
|
+
} as const;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export const fragmentSource = `
|
|
2
|
+
precision highp float;
|
|
3
|
+
uniform sampler2D uTexture;
|
|
4
|
+
uniform vec2 uDelta;
|
|
5
|
+
varying vec2 vTexCoord;
|
|
6
|
+
const float nSamples = 15.0;
|
|
7
|
+
vec3 v3offset = vec3(12.9898, 78.233, 151.7182);
|
|
8
|
+
float random(vec3 scale) {
|
|
9
|
+
/* use the fragment position for a different seed per-pixel */
|
|
10
|
+
return fract(sin(dot(gl_FragCoord.xyz, scale)) * 43758.5453);
|
|
11
|
+
}
|
|
12
|
+
void main() {
|
|
13
|
+
vec4 color = vec4(0.0);
|
|
14
|
+
float total = 0.0;
|
|
15
|
+
float offset = random(v3offset);
|
|
16
|
+
for (float t = -nSamples; t <= nSamples; t++) {
|
|
17
|
+
float percent = (t + offset - 0.5) / nSamples;
|
|
18
|
+
float weight = 1.0 - abs(percent);
|
|
19
|
+
color += texture2D(uTexture, vTexCoord + uDelta * percent) * weight;
|
|
20
|
+
total += weight;
|
|
21
|
+
}
|
|
22
|
+
gl_FragColor = color / total;
|
|
23
|
+
}
|
|
24
|
+
` as const;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export const fragmentSource = `
|
|
2
|
+
precision highp float;
|
|
3
|
+
uniform sampler2D uTexture;
|
|
4
|
+
uniform float uBrightness;
|
|
5
|
+
varying vec2 vTexCoord;
|
|
6
|
+
void main() {
|
|
7
|
+
vec4 color = texture2D(uTexture, vTexCoord);
|
|
8
|
+
color.rgb += uBrightness;
|
|
9
|
+
gl_FragColor = color;
|
|
10
|
+
}
|
|
11
|
+
`;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export const fragmentSource = `
|
|
2
|
+
precision highp float;
|
|
3
|
+
uniform sampler2D uTexture;
|
|
4
|
+
varying vec2 vTexCoord;
|
|
5
|
+
uniform mat4 uColorMatrix;
|
|
6
|
+
uniform vec4 uConstants;
|
|
7
|
+
void main() {
|
|
8
|
+
vec4 color = texture2D(uTexture, vTexCoord);
|
|
9
|
+
color *= uColorMatrix;
|
|
10
|
+
color += uConstants;
|
|
11
|
+
gl_FragColor = color;
|
|
12
|
+
}`;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export const fragmentSource = `
|
|
2
|
+
precision highp float;
|
|
3
|
+
uniform sampler2D uTexture;
|
|
4
|
+
uniform float uContrast;
|
|
5
|
+
varying vec2 vTexCoord;
|
|
6
|
+
void main() {
|
|
7
|
+
vec4 color = texture2D(uTexture, vTexCoord);
|
|
8
|
+
float contrastF = 1.015 * (uContrast + 1.0) / (1.0 * (1.015 - uContrast));
|
|
9
|
+
color.rgb = contrastF * (color.rgb - 0.5) + 0.5;
|
|
10
|
+
gl_FragColor = color;
|
|
11
|
+
}`;
|