ding-image-editor 3.15.3
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/README.md +193 -0
- package/dist/svg/icon-a.svg +376 -0
- package/dist/svg/icon-b.svg +369 -0
- package/dist/svg/icon-c.svg +369 -0
- package/dist/svg/icon-d.svg +369 -0
- package/dist/tui-image-editor.css +6 -0
- package/dist/tui-image-editor.js +62329 -0
- package/dist/tui-image-editor.min.css +5 -0
- package/dist/tui-image-editor.min.js +15 -0
- package/index.d.ts +334 -0
- package/package.json +52 -0
- package/src/css/buttons.styl +102 -0
- package/src/css/checkbox.styl +86 -0
- package/src/css/colorpicker.styl +98 -0
- package/src/css/gridtable.styl +45 -0
- package/src/css/icon.styl +44 -0
- package/src/css/index.styl +17 -0
- package/src/css/main.styl +163 -0
- package/src/css/position.styl +309 -0
- package/src/css/range.styl +91 -0
- package/src/css/submenu.styl +168 -0
- package/src/index.js +29 -0
- package/src/js/action.js +686 -0
- package/src/js/command/addIcon.js +42 -0
- package/src/js/command/addImageObject.js +34 -0
- package/src/js/command/addObject.js +43 -0
- package/src/js/command/addShape.js +51 -0
- package/src/js/command/addText.js +73 -0
- package/src/js/command/applyFilter.js +95 -0
- package/src/js/command/changeIconColor.js +48 -0
- package/src/js/command/changeSelection.js +31 -0
- package/src/js/command/changeShape.js +84 -0
- package/src/js/command/changeText.js +44 -0
- package/src/js/command/changeTextStyle.js +80 -0
- package/src/js/command/clearObjects.js +33 -0
- package/src/js/command/flip.js +36 -0
- package/src/js/command/loadImage.js +58 -0
- package/src/js/command/removeFilter.js +38 -0
- package/src/js/command/removeObject.js +37 -0
- package/src/js/command/resize.js +41 -0
- package/src/js/command/resizeCanvasDimension.js +40 -0
- package/src/js/command/rotate.js +64 -0
- package/src/js/command/setObjectPosition.js +50 -0
- package/src/js/command/setObjectProperties.js +55 -0
- package/src/js/component/cropper.js +407 -0
- package/src/js/component/filter.js +229 -0
- package/src/js/component/flip.js +146 -0
- package/src/js/component/freeDrawing.js +144 -0
- package/src/js/component/icon.js +246 -0
- package/src/js/component/imageLoader.js +84 -0
- package/src/js/component/line.js +205 -0
- package/src/js/component/resize.js +103 -0
- package/src/js/component/rotation.js +91 -0
- package/src/js/component/shape.js +601 -0
- package/src/js/component/text.js +572 -0
- package/src/js/component/zoom.js +708 -0
- package/src/js/consts.js +404 -0
- package/src/js/drawingMode/cropper.js +35 -0
- package/src/js/drawingMode/freeDrawing.js +36 -0
- package/src/js/drawingMode/icon.js +35 -0
- package/src/js/drawingMode/lineDrawing.js +36 -0
- package/src/js/drawingMode/resize.js +35 -0
- package/src/js/drawingMode/shape.js +35 -0
- package/src/js/drawingMode/text.js +35 -0
- package/src/js/drawingMode/zoom.js +37 -0
- package/src/js/extension/arrowLine.js +172 -0
- package/src/js/extension/blur.js +29 -0
- package/src/js/extension/colorFilter.js +104 -0
- package/src/js/extension/cropzone.js +568 -0
- package/src/js/extension/emboss.js +29 -0
- package/src/js/extension/mask.js +90 -0
- package/src/js/extension/sharpen.js +29 -0
- package/src/js/factory/command.js +36 -0
- package/src/js/factory/errorMessage.js +27 -0
- package/src/js/graphics.js +1539 -0
- package/src/js/helper/imagetracer.js +1396 -0
- package/src/js/helper/selectionModifyHelper.js +86 -0
- package/src/js/helper/shapeFilterFillHelper.js +564 -0
- package/src/js/helper/shapeResizeHelper.js +237 -0
- package/src/js/imageEditor.js +1795 -0
- package/src/js/interface/command.js +131 -0
- package/src/js/interface/component.js +127 -0
- package/src/js/interface/drawingMode.js +47 -0
- package/src/js/invoker.js +292 -0
- package/src/js/polyfill.js +498 -0
- package/src/js/ui/crop.js +139 -0
- package/src/js/ui/draw.js +187 -0
- package/src/js/ui/filter.js +510 -0
- package/src/js/ui/flip.js +87 -0
- package/src/js/ui/history.js +171 -0
- package/src/js/ui/icon.js +191 -0
- package/src/js/ui/locale/locale.js +19 -0
- package/src/js/ui/mask.js +96 -0
- package/src/js/ui/panelMenu.js +130 -0
- package/src/js/ui/resize.js +241 -0
- package/src/js/ui/rotate.js +123 -0
- package/src/js/ui/shape.js +265 -0
- package/src/js/ui/submenuBase.js +122 -0
- package/src/js/ui/template/controls.js +21 -0
- package/src/js/ui/template/mainContainer.js +38 -0
- package/src/js/ui/template/style.js +146 -0
- package/src/js/ui/template/submenu/crop.js +73 -0
- package/src/js/ui/template/submenu/draw.js +42 -0
- package/src/js/ui/template/submenu/filter.js +157 -0
- package/src/js/ui/template/submenu/flip.js +41 -0
- package/src/js/ui/template/submenu/history.js +22 -0
- package/src/js/ui/template/submenu/icon.js +108 -0
- package/src/js/ui/template/submenu/mask.js +30 -0
- package/src/js/ui/template/submenu/resize.js +54 -0
- package/src/js/ui/template/submenu/rotate.js +32 -0
- package/src/js/ui/template/submenu/shape.js +45 -0
- package/src/js/ui/template/submenu/text.js +67 -0
- package/src/js/ui/template/submenu/zoom.js +41 -0
- package/src/js/ui/text.js +279 -0
- package/src/js/ui/theme/standard.js +220 -0
- package/src/js/ui/theme/theme.js +249 -0
- package/src/js/ui/tools/colorpicker.js +250 -0
- package/src/js/ui/tools/range.js +390 -0
- package/src/js/ui.js +858 -0
- package/src/js/util.js +551 -0
- package/src/svg/default.svg +335 -0
- package/src/svg/icon-a/ic-apply.svg +6 -0
- package/src/svg/icon-a/ic-cancel.svg +6 -0
- package/src/svg/icon-a/ic-color-transparent-w.svg +12 -0
- package/src/svg/icon-a/ic-crop.svg +7 -0
- package/src/svg/icon-a/ic-delete-all.svg +6 -0
- package/src/svg/icon-a/ic-delete.svg +6 -0
- package/src/svg/icon-a/ic-draw-free.svg +5 -0
- package/src/svg/icon-a/ic-draw-line.svg +5 -0
- package/src/svg/icon-a/ic-draw.svg +6 -0
- package/src/svg/icon-a/ic-filter.svg +7 -0
- package/src/svg/icon-a/ic-flip-reset.svg +7 -0
- package/src/svg/icon-a/ic-flip-x.svg +6 -0
- package/src/svg/icon-a/ic-flip-y.svg +6 -0
- package/src/svg/icon-a/ic-flip.svg +6 -0
- package/src/svg/icon-a/ic-history-check.svg +5 -0
- package/src/svg/icon-a/ic-history-crop.svg +7 -0
- package/src/svg/icon-a/ic-history-delete.svg +9 -0
- package/src/svg/icon-a/ic-history-draw.svg +7 -0
- package/src/svg/icon-a/ic-history-filter.svg +8 -0
- package/src/svg/icon-a/ic-history-flip.svg +6 -0
- package/src/svg/icon-a/ic-history-group.svg +9 -0
- package/src/svg/icon-a/ic-history-icon.svg +6 -0
- package/src/svg/icon-a/ic-history-load.svg +7 -0
- package/src/svg/icon-a/ic-history-mask.svg +9 -0
- package/src/svg/icon-a/ic-history-resize.svg +12 -0
- package/src/svg/icon-a/ic-history-rotate.svg +16 -0
- package/src/svg/icon-a/ic-history-shape.svg +7 -0
- package/src/svg/icon-a/ic-history-text.svg +8 -0
- package/src/svg/icon-a/ic-history.svg +6 -0
- package/src/svg/icon-a/ic-icon-arrow-2.svg +5 -0
- package/src/svg/icon-a/ic-icon-arrow-3.svg +5 -0
- package/src/svg/icon-a/ic-icon-arrow.svg +5 -0
- package/src/svg/icon-a/ic-icon-bubble.svg +5 -0
- package/src/svg/icon-a/ic-icon-heart.svg +5 -0
- package/src/svg/icon-a/ic-icon-load.svg +8 -0
- package/src/svg/icon-a/ic-icon-location.svg +8 -0
- package/src/svg/icon-a/ic-icon-polygon.svg +5 -0
- package/src/svg/icon-a/ic-icon-star-2.svg +5 -0
- package/src/svg/icon-a/ic-icon-star.svg +5 -0
- package/src/svg/icon-a/ic-icon.svg +5 -0
- package/src/svg/icon-a/ic-mask-load.svg +8 -0
- package/src/svg/icon-a/ic-mask.svg +6 -0
- package/src/svg/icon-a/ic-redo.svg +7 -0
- package/src/svg/icon-a/ic-reset.svg +7 -0
- package/src/svg/icon-a/ic-resize.svg +13 -0
- package/src/svg/icon-a/ic-rotate-clockwise.svg +7 -0
- package/src/svg/icon-a/ic-rotate-counterclockwise.svg +7 -0
- package/src/svg/icon-a/ic-rotate.svg +7 -0
- package/src/svg/icon-a/ic-shape-circle.svg +5 -0
- package/src/svg/icon-a/ic-shape-rectangle.svg +5 -0
- package/src/svg/icon-a/ic-shape-triangle.svg +5 -0
- package/src/svg/icon-a/ic-shape.svg +6 -0
- package/src/svg/icon-a/ic-text-align-center.svg +6 -0
- package/src/svg/icon-a/ic-text-align-left.svg +6 -0
- package/src/svg/icon-a/ic-text-align-right.svg +6 -0
- package/src/svg/icon-a/ic-text-bold.svg +7 -0
- package/src/svg/icon-a/ic-text-italic.svg +6 -0
- package/src/svg/icon-a/ic-text-underline.svg +7 -0
- package/src/svg/icon-a/ic-text.svg +7 -0
- package/src/svg/icon-a/ic-undo.svg +7 -0
- package/src/svg/icon-a/ic-zoom-hand.svg +8 -0
- package/src/svg/icon-a/ic-zoom-zoom-in.svg +10 -0
- package/src/svg/icon-a/ic-zoom-zoom-out.svg +9 -0
- package/src/svg/icon-a/img-bi.svg +5 -0
- package/src/svg/icon-b/ic-apply.svg +6 -0
- package/src/svg/icon-b/ic-cancel.svg +6 -0
- package/src/svg/icon-b/ic-crop.svg +7 -0
- package/src/svg/icon-b/ic-delete-all.svg +6 -0
- package/src/svg/icon-b/ic-delete.svg +6 -0
- package/src/svg/icon-b/ic-draw-free.svg +5 -0
- package/src/svg/icon-b/ic-draw-line.svg +5 -0
- package/src/svg/icon-b/ic-draw.svg +6 -0
- package/src/svg/icon-b/ic-filter.svg +7 -0
- package/src/svg/icon-b/ic-flip-reset.svg +7 -0
- package/src/svg/icon-b/ic-flip-x.svg +6 -0
- package/src/svg/icon-b/ic-flip-y.svg +6 -0
- package/src/svg/icon-b/ic-flip.svg +6 -0
- package/src/svg/icon-b/ic-history-check.svg +5 -0
- package/src/svg/icon-b/ic-history-crop.svg +7 -0
- package/src/svg/icon-b/ic-history-delete.svg +9 -0
- package/src/svg/icon-b/ic-history-draw.svg +7 -0
- package/src/svg/icon-b/ic-history-filter.svg +8 -0
- package/src/svg/icon-b/ic-history-flip.svg +6 -0
- package/src/svg/icon-b/ic-history-group.svg +9 -0
- package/src/svg/icon-b/ic-history-icon.svg +6 -0
- package/src/svg/icon-b/ic-history-load.svg +7 -0
- package/src/svg/icon-b/ic-history-mask.svg +9 -0
- package/src/svg/icon-b/ic-history-resize.svg +12 -0
- package/src/svg/icon-b/ic-history-rotate.svg +16 -0
- package/src/svg/icon-b/ic-history-shape.svg +7 -0
- package/src/svg/icon-b/ic-history-text.svg +8 -0
- package/src/svg/icon-b/ic-history.svg +6 -0
- package/src/svg/icon-b/ic-icon-arrow-2.svg +5 -0
- package/src/svg/icon-b/ic-icon-arrow-3.svg +5 -0
- package/src/svg/icon-b/ic-icon-arrow.svg +5 -0
- package/src/svg/icon-b/ic-icon-bubble.svg +5 -0
- package/src/svg/icon-b/ic-icon-heart.svg +5 -0
- package/src/svg/icon-b/ic-icon-load.svg +8 -0
- package/src/svg/icon-b/ic-icon-location.svg +8 -0
- package/src/svg/icon-b/ic-icon-polygon.svg +5 -0
- package/src/svg/icon-b/ic-icon-star-2.svg +5 -0
- package/src/svg/icon-b/ic-icon-star.svg +5 -0
- package/src/svg/icon-b/ic-icon.svg +5 -0
- package/src/svg/icon-b/ic-mask-load.svg +8 -0
- package/src/svg/icon-b/ic-mask.svg +6 -0
- package/src/svg/icon-b/ic-redo.svg +7 -0
- package/src/svg/icon-b/ic-reset.svg +7 -0
- package/src/svg/icon-b/ic-resize.svg +13 -0
- package/src/svg/icon-b/ic-rotate-clockwise.svg +7 -0
- package/src/svg/icon-b/ic-rotate-counterclockwise.svg +7 -0
- package/src/svg/icon-b/ic-rotate.svg +7 -0
- package/src/svg/icon-b/ic-shape-circle.svg +5 -0
- package/src/svg/icon-b/ic-shape-rectangle.svg +5 -0
- package/src/svg/icon-b/ic-shape-triangle.svg +5 -0
- package/src/svg/icon-b/ic-shape.svg +6 -0
- package/src/svg/icon-b/ic-text-align-center.svg +6 -0
- package/src/svg/icon-b/ic-text-align-left.svg +6 -0
- package/src/svg/icon-b/ic-text-align-right.svg +6 -0
- package/src/svg/icon-b/ic-text-bold.svg +7 -0
- package/src/svg/icon-b/ic-text-italic.svg +6 -0
- package/src/svg/icon-b/ic-text-underline.svg +7 -0
- package/src/svg/icon-b/ic-text.svg +7 -0
- package/src/svg/icon-b/ic-undo.svg +7 -0
- package/src/svg/icon-b/ic-zoom-hand.svg +8 -0
- package/src/svg/icon-b/ic-zoom-zoom-in.svg +12 -0
- package/src/svg/icon-b/ic-zoom-zoom-out.svg +11 -0
- package/src/svg/icon-b/img-bi.svg +5 -0
- package/src/svg/icon-c/ic-apply.svg +6 -0
- package/src/svg/icon-c/ic-cancel.svg +6 -0
- package/src/svg/icon-c/ic-crop.svg +7 -0
- package/src/svg/icon-c/ic-delete-all.svg +6 -0
- package/src/svg/icon-c/ic-delete.svg +6 -0
- package/src/svg/icon-c/ic-draw-free.svg +5 -0
- package/src/svg/icon-c/ic-draw-line.svg +5 -0
- package/src/svg/icon-c/ic-draw.svg +6 -0
- package/src/svg/icon-c/ic-filter.svg +7 -0
- package/src/svg/icon-c/ic-flip-reset.svg +7 -0
- package/src/svg/icon-c/ic-flip-x.svg +6 -0
- package/src/svg/icon-c/ic-flip-y.svg +6 -0
- package/src/svg/icon-c/ic-flip.svg +6 -0
- package/src/svg/icon-c/ic-history-check.svg +5 -0
- package/src/svg/icon-c/ic-history-crop.svg +7 -0
- package/src/svg/icon-c/ic-history-delete.svg +9 -0
- package/src/svg/icon-c/ic-history-draw.svg +7 -0
- package/src/svg/icon-c/ic-history-filter.svg +8 -0
- package/src/svg/icon-c/ic-history-flip.svg +6 -0
- package/src/svg/icon-c/ic-history-group.svg +9 -0
- package/src/svg/icon-c/ic-history-icon.svg +6 -0
- package/src/svg/icon-c/ic-history-load.svg +7 -0
- package/src/svg/icon-c/ic-history-mask.svg +9 -0
- package/src/svg/icon-c/ic-history-resize.svg +12 -0
- package/src/svg/icon-c/ic-history-rotate.svg +16 -0
- package/src/svg/icon-c/ic-history-shape.svg +7 -0
- package/src/svg/icon-c/ic-history-text.svg +8 -0
- package/src/svg/icon-c/ic-history.svg +6 -0
- package/src/svg/icon-c/ic-icon-arrow-2.svg +5 -0
- package/src/svg/icon-c/ic-icon-arrow-3.svg +5 -0
- package/src/svg/icon-c/ic-icon-arrow.svg +5 -0
- package/src/svg/icon-c/ic-icon-bubble.svg +5 -0
- package/src/svg/icon-c/ic-icon-heart.svg +5 -0
- package/src/svg/icon-c/ic-icon-load.svg +8 -0
- package/src/svg/icon-c/ic-icon-location.svg +8 -0
- package/src/svg/icon-c/ic-icon-polygon.svg +5 -0
- package/src/svg/icon-c/ic-icon-star-2.svg +5 -0
- package/src/svg/icon-c/ic-icon-star.svg +5 -0
- package/src/svg/icon-c/ic-icon.svg +5 -0
- package/src/svg/icon-c/ic-mask-load.svg +8 -0
- package/src/svg/icon-c/ic-mask.svg +6 -0
- package/src/svg/icon-c/ic-redo.svg +7 -0
- package/src/svg/icon-c/ic-reset.svg +7 -0
- package/src/svg/icon-c/ic-resize.svg +13 -0
- package/src/svg/icon-c/ic-rotate-clockwise.svg +7 -0
- package/src/svg/icon-c/ic-rotate-counterclockwise.svg +7 -0
- package/src/svg/icon-c/ic-rotate.svg +7 -0
- package/src/svg/icon-c/ic-shape-circle.svg +5 -0
- package/src/svg/icon-c/ic-shape-rectangle.svg +5 -0
- package/src/svg/icon-c/ic-shape-triangle.svg +5 -0
- package/src/svg/icon-c/ic-shape.svg +6 -0
- package/src/svg/icon-c/ic-text-align-center.svg +6 -0
- package/src/svg/icon-c/ic-text-align-left.svg +6 -0
- package/src/svg/icon-c/ic-text-align-right.svg +6 -0
- package/src/svg/icon-c/ic-text-bold.svg +7 -0
- package/src/svg/icon-c/ic-text-italic.svg +6 -0
- package/src/svg/icon-c/ic-text-underline.svg +7 -0
- package/src/svg/icon-c/ic-text.svg +7 -0
- package/src/svg/icon-c/ic-undo.svg +7 -0
- package/src/svg/icon-c/ic-zoom-hand.svg +8 -0
- package/src/svg/icon-c/ic-zoom-zoom-in.svg +12 -0
- package/src/svg/icon-c/ic-zoom-zoom-out.svg +11 -0
- package/src/svg/icon-c/img-bi.svg +5 -0
- package/src/svg/icon-d/ic-apply.svg +6 -0
- package/src/svg/icon-d/ic-cancel.svg +6 -0
- package/src/svg/icon-d/ic-crop.svg +7 -0
- package/src/svg/icon-d/ic-delete-all.svg +6 -0
- package/src/svg/icon-d/ic-delete.svg +6 -0
- package/src/svg/icon-d/ic-draw-free.svg +5 -0
- package/src/svg/icon-d/ic-draw-line.svg +5 -0
- package/src/svg/icon-d/ic-draw.svg +6 -0
- package/src/svg/icon-d/ic-filter.svg +7 -0
- package/src/svg/icon-d/ic-flip-reset.svg +7 -0
- package/src/svg/icon-d/ic-flip-x.svg +6 -0
- package/src/svg/icon-d/ic-flip-y.svg +6 -0
- package/src/svg/icon-d/ic-flip.svg +6 -0
- package/src/svg/icon-d/ic-history-check.svg +5 -0
- package/src/svg/icon-d/ic-history-crop.svg +7 -0
- package/src/svg/icon-d/ic-history-delete.svg +9 -0
- package/src/svg/icon-d/ic-history-draw.svg +7 -0
- package/src/svg/icon-d/ic-history-filter.svg +8 -0
- package/src/svg/icon-d/ic-history-flip.svg +6 -0
- package/src/svg/icon-d/ic-history-group.svg +9 -0
- package/src/svg/icon-d/ic-history-icon.svg +6 -0
- package/src/svg/icon-d/ic-history-load.svg +7 -0
- package/src/svg/icon-d/ic-history-mask.svg +9 -0
- package/src/svg/icon-d/ic-history-resize.svg +12 -0
- package/src/svg/icon-d/ic-history-rotate.svg +16 -0
- package/src/svg/icon-d/ic-history-shape.svg +7 -0
- package/src/svg/icon-d/ic-history-text.svg +8 -0
- package/src/svg/icon-d/ic-history.svg +6 -0
- package/src/svg/icon-d/ic-icon-arrow-2.svg +5 -0
- package/src/svg/icon-d/ic-icon-arrow-3.svg +5 -0
- package/src/svg/icon-d/ic-icon-arrow.svg +5 -0
- package/src/svg/icon-d/ic-icon-bubble.svg +5 -0
- package/src/svg/icon-d/ic-icon-heart.svg +5 -0
- package/src/svg/icon-d/ic-icon-load.svg +8 -0
- package/src/svg/icon-d/ic-icon-location.svg +8 -0
- package/src/svg/icon-d/ic-icon-polygon.svg +5 -0
- package/src/svg/icon-d/ic-icon-star-2.svg +5 -0
- package/src/svg/icon-d/ic-icon-star.svg +5 -0
- package/src/svg/icon-d/ic-icon.svg +5 -0
- package/src/svg/icon-d/ic-mask-load.svg +8 -0
- package/src/svg/icon-d/ic-mask.svg +6 -0
- package/src/svg/icon-d/ic-redo.svg +7 -0
- package/src/svg/icon-d/ic-reset.svg +7 -0
- package/src/svg/icon-d/ic-resize.svg +13 -0
- package/src/svg/icon-d/ic-rotate-clockwise.svg +7 -0
- package/src/svg/icon-d/ic-rotate-counterclockwise.svg +7 -0
- package/src/svg/icon-d/ic-rotate.svg +7 -0
- package/src/svg/icon-d/ic-shape-circle.svg +5 -0
- package/src/svg/icon-d/ic-shape-rectangle.svg +5 -0
- package/src/svg/icon-d/ic-shape-triangle.svg +5 -0
- package/src/svg/icon-d/ic-shape.svg +6 -0
- package/src/svg/icon-d/ic-text-align-center.svg +6 -0
- package/src/svg/icon-d/ic-text-align-left.svg +6 -0
- package/src/svg/icon-d/ic-text-align-right.svg +6 -0
- package/src/svg/icon-d/ic-text-bold.svg +7 -0
- package/src/svg/icon-d/ic-text-italic.svg +6 -0
- package/src/svg/icon-d/ic-text-underline.svg +7 -0
- package/src/svg/icon-d/ic-text.svg +7 -0
- package/src/svg/icon-d/ic-undo.svg +7 -0
- package/src/svg/icon-d/ic-zoom-hand.svg +8 -0
- package/src/svg/icon-d/ic-zoom-zoom-in.svg +12 -0
- package/src/svg/icon-d/ic-zoom-zoom-out.svg +11 -0
- package/src/svg/icon-d/img-bi.svg +5 -0
@@ -0,0 +1,237 @@
|
|
1
|
+
const DIVISOR = {
|
2
|
+
rect: 1,
|
3
|
+
circle: 2,
|
4
|
+
triangle: 1,
|
5
|
+
};
|
6
|
+
const DIMENSION_KEYS = {
|
7
|
+
rect: {
|
8
|
+
w: 'width',
|
9
|
+
h: 'height',
|
10
|
+
},
|
11
|
+
circle: {
|
12
|
+
w: 'rx',
|
13
|
+
h: 'ry',
|
14
|
+
},
|
15
|
+
triangle: {
|
16
|
+
w: 'width',
|
17
|
+
h: 'height',
|
18
|
+
},
|
19
|
+
};
|
20
|
+
|
21
|
+
/**
|
22
|
+
* Set the start point value to the shape object
|
23
|
+
* @param {fabric.Object} shape - Shape object
|
24
|
+
* @ignore
|
25
|
+
*/
|
26
|
+
function setStartPoint(shape) {
|
27
|
+
const { originX, originY } = shape;
|
28
|
+
const originKey = originX.substring(0, 1) + originY.substring(0, 1);
|
29
|
+
|
30
|
+
shape.startPoint = shape.origins[originKey];
|
31
|
+
}
|
32
|
+
|
33
|
+
/**
|
34
|
+
* Get the positions of ratated origin by the pointer value
|
35
|
+
* @param {{x: number, y: number}} origin - Origin value
|
36
|
+
* @param {{x: number, y: number}} pointer - Pointer value
|
37
|
+
* @param {number} angle - Rotating angle
|
38
|
+
* @returns {Object} Postions of origin
|
39
|
+
* @ignore
|
40
|
+
*/
|
41
|
+
function getPositionsOfRotatedOrigin(origin, pointer, angle) {
|
42
|
+
const sx = origin.x;
|
43
|
+
const sy = origin.y;
|
44
|
+
const px = pointer.x;
|
45
|
+
const py = pointer.y;
|
46
|
+
const r = (angle * Math.PI) / 180;
|
47
|
+
const rx = (px - sx) * Math.cos(r) - (py - sy) * Math.sin(r) + sx;
|
48
|
+
const ry = (px - sx) * Math.sin(r) + (py - sy) * Math.cos(r) + sy;
|
49
|
+
|
50
|
+
return {
|
51
|
+
originX: sx > rx ? 'right' : 'left',
|
52
|
+
originY: sy > ry ? 'bottom' : 'top',
|
53
|
+
};
|
54
|
+
}
|
55
|
+
|
56
|
+
/**
|
57
|
+
* Whether the shape has the center origin or not
|
58
|
+
* @param {fabric.Object} shape - Shape object
|
59
|
+
* @returns {boolean} State
|
60
|
+
* @ignore
|
61
|
+
*/
|
62
|
+
function hasCenterOrigin(shape) {
|
63
|
+
return shape.originX === 'center' && shape.originY === 'center';
|
64
|
+
}
|
65
|
+
|
66
|
+
/**
|
67
|
+
* Adjust the origin of shape by the start point
|
68
|
+
* @param {{x: number, y: number}} pointer - Pointer value
|
69
|
+
* @param {fabric.Object} shape - Shape object
|
70
|
+
* @ignore
|
71
|
+
*/
|
72
|
+
function adjustOriginByStartPoint(pointer, shape) {
|
73
|
+
const centerPoint = shape.getPointByOrigin('center', 'center');
|
74
|
+
const angle = -shape.angle;
|
75
|
+
const originPositions = getPositionsOfRotatedOrigin(centerPoint, pointer, angle);
|
76
|
+
const { originX, originY } = originPositions;
|
77
|
+
const origin = shape.getPointByOrigin(originX, originY);
|
78
|
+
const left = shape.left - (centerPoint.x - origin.x);
|
79
|
+
const top = shape.top - (centerPoint.y - origin.y);
|
80
|
+
|
81
|
+
shape.set({
|
82
|
+
originX,
|
83
|
+
originY,
|
84
|
+
left,
|
85
|
+
top,
|
86
|
+
});
|
87
|
+
|
88
|
+
shape.setCoords();
|
89
|
+
}
|
90
|
+
|
91
|
+
/**
|
92
|
+
* Adjust the origin of shape by the moving pointer value
|
93
|
+
* @param {{x: number, y: number}} pointer - Pointer value
|
94
|
+
* @param {fabric.Object} shape - Shape object
|
95
|
+
* @ignore
|
96
|
+
*/
|
97
|
+
function adjustOriginByMovingPointer(pointer, shape) {
|
98
|
+
const origin = shape.startPoint;
|
99
|
+
const angle = -shape.angle;
|
100
|
+
const originPositions = getPositionsOfRotatedOrigin(origin, pointer, angle);
|
101
|
+
const { originX, originY } = originPositions;
|
102
|
+
|
103
|
+
shape.setPositionByOrigin(origin, originX, originY);
|
104
|
+
shape.setCoords();
|
105
|
+
}
|
106
|
+
|
107
|
+
/**
|
108
|
+
* Adjust the dimension of shape on firing scaling event
|
109
|
+
* @param {fabric.Object} shape - Shape object
|
110
|
+
* @ignore
|
111
|
+
*/
|
112
|
+
function adjustDimensionOnScaling(shape) {
|
113
|
+
const { type, scaleX, scaleY } = shape;
|
114
|
+
const dimensionKeys = DIMENSION_KEYS[type];
|
115
|
+
let width = shape[dimensionKeys.w] * scaleX;
|
116
|
+
let height = shape[dimensionKeys.h] * scaleY;
|
117
|
+
|
118
|
+
if (shape.isRegular) {
|
119
|
+
const maxScale = Math.max(scaleX, scaleY);
|
120
|
+
|
121
|
+
width = shape[dimensionKeys.w] * maxScale;
|
122
|
+
height = shape[dimensionKeys.h] * maxScale;
|
123
|
+
}
|
124
|
+
|
125
|
+
const options = {
|
126
|
+
hasControls: false,
|
127
|
+
hasBorders: false,
|
128
|
+
scaleX: 1,
|
129
|
+
scaleY: 1,
|
130
|
+
};
|
131
|
+
|
132
|
+
options[dimensionKeys.w] = width;
|
133
|
+
options[dimensionKeys.h] = height;
|
134
|
+
|
135
|
+
shape.set(options);
|
136
|
+
}
|
137
|
+
|
138
|
+
/**
|
139
|
+
* Adjust the dimension of shape on firing mouse move event
|
140
|
+
* @param {{x: number, y: number}} pointer - Pointer value
|
141
|
+
* @param {fabric.Object} shape - Shape object
|
142
|
+
* @ignore
|
143
|
+
*/
|
144
|
+
function adjustDimensionOnMouseMove(pointer, shape) {
|
145
|
+
const { type, strokeWidth, startPoint: origin } = shape;
|
146
|
+
const divisor = DIVISOR[type];
|
147
|
+
const dimensionKeys = DIMENSION_KEYS[type];
|
148
|
+
const isTriangle = !!(shape.type === 'triangle');
|
149
|
+
const options = {};
|
150
|
+
let width = Math.abs(origin.x - pointer.x) / divisor;
|
151
|
+
let height = Math.abs(origin.y - pointer.y) / divisor;
|
152
|
+
|
153
|
+
if (width > strokeWidth) {
|
154
|
+
width -= strokeWidth / divisor;
|
155
|
+
}
|
156
|
+
|
157
|
+
if (height > strokeWidth) {
|
158
|
+
height -= strokeWidth / divisor;
|
159
|
+
}
|
160
|
+
|
161
|
+
if (shape.isRegular) {
|
162
|
+
width = height = Math.max(width, height);
|
163
|
+
|
164
|
+
if (isTriangle) {
|
165
|
+
height = (Math.sqrt(3) / 2) * width;
|
166
|
+
}
|
167
|
+
}
|
168
|
+
|
169
|
+
options[dimensionKeys.w] = width;
|
170
|
+
options[dimensionKeys.h] = height;
|
171
|
+
|
172
|
+
shape.set(options);
|
173
|
+
}
|
174
|
+
|
175
|
+
module.exports = {
|
176
|
+
/**
|
177
|
+
* Set each origin value to shape
|
178
|
+
* @param {fabric.Object} shape - Shape object
|
179
|
+
*/
|
180
|
+
setOrigins(shape) {
|
181
|
+
const leftTopPoint = shape.getPointByOrigin('left', 'top');
|
182
|
+
const rightTopPoint = shape.getPointByOrigin('right', 'top');
|
183
|
+
const rightBottomPoint = shape.getPointByOrigin('right', 'bottom');
|
184
|
+
const leftBottomPoint = shape.getPointByOrigin('left', 'bottom');
|
185
|
+
|
186
|
+
shape.origins = {
|
187
|
+
lt: leftTopPoint,
|
188
|
+
rt: rightTopPoint,
|
189
|
+
rb: rightBottomPoint,
|
190
|
+
lb: leftBottomPoint,
|
191
|
+
};
|
192
|
+
},
|
193
|
+
|
194
|
+
/**
|
195
|
+
* Resize the shape
|
196
|
+
* @param {fabric.Object} shape - Shape object
|
197
|
+
* @param {{x: number, y: number}} pointer - Mouse pointer values on canvas
|
198
|
+
* @param {boolean} isScaling - Whether the resizing action is scaling or not
|
199
|
+
*/
|
200
|
+
resize(shape, pointer, isScaling) {
|
201
|
+
if (hasCenterOrigin(shape)) {
|
202
|
+
adjustOriginByStartPoint(pointer, shape);
|
203
|
+
setStartPoint(shape);
|
204
|
+
}
|
205
|
+
|
206
|
+
if (isScaling) {
|
207
|
+
adjustDimensionOnScaling(shape, pointer);
|
208
|
+
} else {
|
209
|
+
adjustDimensionOnMouseMove(pointer, shape);
|
210
|
+
}
|
211
|
+
|
212
|
+
adjustOriginByMovingPointer(pointer, shape);
|
213
|
+
},
|
214
|
+
|
215
|
+
/**
|
216
|
+
* Adjust the origin position of shape to center
|
217
|
+
* @param {fabric.Object} shape - Shape object
|
218
|
+
*/
|
219
|
+
adjustOriginToCenter(shape) {
|
220
|
+
const centerPoint = shape.getPointByOrigin('center', 'center');
|
221
|
+
const { originX, originY } = shape;
|
222
|
+
const origin = shape.getPointByOrigin(originX, originY);
|
223
|
+
const left = shape.left + (centerPoint.x - origin.x);
|
224
|
+
const top = shape.top + (centerPoint.y - origin.y);
|
225
|
+
|
226
|
+
shape.set({
|
227
|
+
hasControls: true,
|
228
|
+
hasBorders: true,
|
229
|
+
originX: 'center',
|
230
|
+
originY: 'center',
|
231
|
+
left,
|
232
|
+
top,
|
233
|
+
});
|
234
|
+
|
235
|
+
shape.setCoords(); // For left, top properties
|
236
|
+
},
|
237
|
+
};
|