@nice2dev/ui-graphics 1.0.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/CHANGELOG.md +84 -0
- package/LICENSE +21 -0
- package/README.md +339 -0
- package/dist/cjs/animation/AnimatedPerson.js +153 -0
- package/dist/cjs/animation/AnimatedPerson.js.map +1 -0
- package/dist/cjs/animation/AnimationEditor.js +106 -0
- package/dist/cjs/animation/AnimationEditor.js.map +1 -0
- package/dist/cjs/animation/Audience.js +59 -0
- package/dist/cjs/animation/Audience.js.map +1 -0
- package/dist/cjs/animation/BodyRenderer.js +33 -0
- package/dist/cjs/animation/BodyRenderer.js.map +1 -0
- package/dist/cjs/animation/animationHelper.js +272 -0
- package/dist/cjs/animation/animationHelper.js.map +1 -0
- package/dist/cjs/animation/characterTypes.js +75 -0
- package/dist/cjs/animation/characterTypes.js.map +1 -0
- package/dist/cjs/animation/choreoDSL.js +190 -0
- package/dist/cjs/animation/choreoDSL.js.map +1 -0
- package/dist/cjs/animation/choreography.js +41 -0
- package/dist/cjs/animation/choreography.js.map +1 -0
- package/dist/cjs/animation/karaokeIntegration.js +98 -0
- package/dist/cjs/animation/karaokeIntegration.js.map +1 -0
- package/dist/cjs/animation/lottieExport.js +128 -0
- package/dist/cjs/animation/lottieExport.js.map +1 -0
- package/dist/cjs/animation/motionPath.js +196 -0
- package/dist/cjs/animation/motionPath.js.map +1 -0
- package/dist/cjs/animation/physics.js +201 -0
- package/dist/cjs/animation/physics.js.map +1 -0
- package/dist/cjs/animation/rig/RigPlayer.js +63 -0
- package/dist/cjs/animation/rig/RigPlayer.js.map +1 -0
- package/dist/cjs/animation/rig/RiggedBody.js +30 -0
- package/dist/cjs/animation/rig/RiggedBody.js.map +1 -0
- package/dist/cjs/animation/rig/choreoRigBridge.js +63 -0
- package/dist/cjs/animation/rig/choreoRigBridge.js.map +1 -0
- package/dist/cjs/animation/rig/ik.js +22 -0
- package/dist/cjs/animation/rig/ik.js.map +1 -0
- package/dist/cjs/animation/rig/poseOps.js +49 -0
- package/dist/cjs/animation/rig/poseOps.js.map +1 -0
- package/dist/cjs/animation/rig/presets.js +60 -0
- package/dist/cjs/animation/rig/presets.js.map +1 -0
- package/dist/cjs/animation/rig/rigMath.js +41 -0
- package/dist/cjs/animation/rig/rigMath.js.map +1 -0
- package/dist/cjs/animation/rig/rigTypes.js +44 -0
- package/dist/cjs/animation/rig/rigTypes.js.map +1 -0
- package/dist/cjs/animation/shapes/arms.js +15 -0
- package/dist/cjs/animation/shapes/arms.js.map +1 -0
- package/dist/cjs/animation/shapes/eyes.js +52 -0
- package/dist/cjs/animation/shapes/eyes.js.map +1 -0
- package/dist/cjs/animation/shapes/hair.js +55 -0
- package/dist/cjs/animation/shapes/hair.js.map +1 -0
- package/dist/cjs/animation/shapes/heads.js +62 -0
- package/dist/cjs/animation/shapes/heads.js.map +1 -0
- package/dist/cjs/animation/shapes/headwear.js +44 -0
- package/dist/cjs/animation/shapes/headwear.js.map +1 -0
- package/dist/cjs/animation/shapes/legs.js +15 -0
- package/dist/cjs/animation/shapes/legs.js.map +1 -0
- package/dist/cjs/animation/shapes/mouths.js +53 -0
- package/dist/cjs/animation/shapes/mouths.js.map +1 -0
- package/dist/cjs/animation/shapes/noses.js +31 -0
- package/dist/cjs/animation/shapes/noses.js.map +1 -0
- package/dist/cjs/animation/shapes/outfits.js +43 -0
- package/dist/cjs/animation/shapes/outfits.js.map +1 -0
- package/dist/cjs/animation/shapes/torsos.js +13 -0
- package/dist/cjs/animation/shapes/torsos.js.map +1 -0
- package/dist/cjs/animation/spineExport.js +132 -0
- package/dist/cjs/animation/spineExport.js.map +1 -0
- package/dist/cjs/core/LocalUI.js +54 -0
- package/dist/cjs/core/LocalUI.js.map +1 -0
- package/dist/cjs/core/collaboration.js +259 -0
- package/dist/cjs/core/collaboration.js.map +1 -0
- package/dist/cjs/core/colorBlindness.js +97 -0
- package/dist/cjs/core/colorBlindness.js.map +1 -0
- package/dist/cjs/core/dragDrop.js +168 -0
- package/dist/cjs/core/dragDrop.js.map +1 -0
- package/dist/cjs/core/fixes.js +185 -0
- package/dist/cjs/core/fixes.js.map +1 -0
- package/dist/cjs/core/gridGuides.js +245 -0
- package/dist/cjs/core/gridGuides.js.map +1 -0
- package/dist/cjs/core/historyVisual.js +124 -0
- package/dist/cjs/core/historyVisual.js.map +1 -0
- package/dist/cjs/core/i18n.js +16 -0
- package/dist/cjs/core/i18n.js.map +1 -0
- package/dist/cjs/core/integrations.js +261 -0
- package/dist/cjs/core/integrations.js.map +1 -0
- package/dist/cjs/core/minimap.js +142 -0
- package/dist/cjs/core/minimap.js.map +1 -0
- package/dist/cjs/core/plugins.js +129 -0
- package/dist/cjs/core/plugins.js.map +1 -0
- package/dist/cjs/core/rtl.js +102 -0
- package/dist/cjs/core/rtl.js.map +1 -0
- package/dist/cjs/core/shortcuts.js +205 -0
- package/dist/cjs/core/shortcuts.js.map +1 -0
- package/dist/cjs/core/theme.js +171 -0
- package/dist/cjs/core/theme.js.map +1 -0
- package/dist/cjs/font/NiceFontEditor.js +193 -0
- package/dist/cjs/font/NiceFontEditor.js.map +1 -0
- package/dist/cjs/game/GameAsset2dEditor.js +371 -0
- package/dist/cjs/game/GameAsset2dEditor.js.map +1 -0
- package/dist/cjs/game/GameAsset2dEditor.module.css.js +6 -0
- package/dist/cjs/game/GameAsset2dEditor.module.css.js.map +1 -0
- package/dist/cjs/game/gameAssetTypes.js +20 -0
- package/dist/cjs/game/gameAssetTypes.js.map +1 -0
- package/dist/cjs/game/gameAssetUtils.js +475 -0
- package/dist/cjs/game/gameAssetUtils.js.map +1 -0
- package/dist/cjs/game/useGameAssetEditor.js +761 -0
- package/dist/cjs/game/useGameAssetEditor.js.map +1 -0
- package/dist/cjs/icon/NiceIconEditor.js +249 -0
- package/dist/cjs/icon/NiceIconEditor.js.map +1 -0
- package/dist/cjs/index.js +264 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/nice2dev-ui/dist/index.js +32070 -0
- package/dist/cjs/nice2dev-ui/dist/index.js.map +1 -0
- package/dist/cjs/nice2dev-ui-graphics.css +1 -0
- package/dist/cjs/photo/FilterThumb.js +29 -0
- package/dist/cjs/photo/FilterThumb.js.map +1 -0
- package/dist/cjs/photo/PhotoEditor.js +20 -0
- package/dist/cjs/photo/PhotoEditor.js.map +1 -0
- package/dist/cjs/photo/PhotoEditor.module.css.js +6 -0
- package/dist/cjs/photo/PhotoEditor.module.css.js.map +1 -0
- package/dist/cjs/photo/PhotoEditorCanvas.js +59 -0
- package/dist/cjs/photo/PhotoEditorCanvas.js.map +1 -0
- package/dist/cjs/photo/PhotoEditorLeftPanel.js +174 -0
- package/dist/cjs/photo/PhotoEditorLeftPanel.js.map +1 -0
- package/dist/cjs/photo/PhotoEditorToolbar.js +15 -0
- package/dist/cjs/photo/PhotoEditorToolbar.js.map +1 -0
- package/dist/cjs/photo/photoEditorActions.js +80 -0
- package/dist/cjs/photo/photoEditorActions.js.map +1 -0
- package/dist/cjs/photo/photoEditorTypes.js +40 -0
- package/dist/cjs/photo/photoEditorTypes.js.map +1 -0
- package/dist/cjs/photo/photoFilters.js +880 -0
- package/dist/cjs/photo/photoFilters.js.map +1 -0
- package/dist/cjs/photo/photoOverlays.js +651 -0
- package/dist/cjs/photo/photoOverlays.js.map +1 -0
- package/dist/cjs/photo/photoSelection.js +547 -0
- package/dist/cjs/photo/photoSelection.js.map +1 -0
- package/dist/cjs/photo/usePhotoEditor.js +640 -0
- package/dist/cjs/photo/usePhotoEditor.js.map +1 -0
- package/dist/cjs/pixel/HSVPicker.js +173 -0
- package/dist/cjs/pixel/HSVPicker.js.map +1 -0
- package/dist/cjs/pixel/PixelEditor.js +28 -0
- package/dist/cjs/pixel/PixelEditor.js.map +1 -0
- package/dist/cjs/pixel/PixelEditor.module.css.js +6 -0
- package/dist/cjs/pixel/PixelEditor.module.css.js.map +1 -0
- package/dist/cjs/pixel/PixelEditorCanvas.js +15 -0
- package/dist/cjs/pixel/PixelEditorCanvas.js.map +1 -0
- package/dist/cjs/pixel/PixelEditorMenuBar.js +11 -0
- package/dist/cjs/pixel/PixelEditorMenuBar.js.map +1 -0
- package/dist/cjs/pixel/PixelEditorRightPanel.js +15 -0
- package/dist/cjs/pixel/PixelEditorRightPanel.js.map +1 -0
- package/dist/cjs/pixel/PixelEditorStatusBar.js +15 -0
- package/dist/cjs/pixel/PixelEditorStatusBar.js.map +1 -0
- package/dist/cjs/pixel/PixelEditorTimeline.js +11 -0
- package/dist/cjs/pixel/PixelEditorTimeline.js.map +1 -0
- package/dist/cjs/pixel/PixelEditorToolbar.js +16 -0
- package/dist/cjs/pixel/PixelEditorToolbar.js.map +1 -0
- package/dist/cjs/pixel/asepriteFormat.js +512 -0
- package/dist/cjs/pixel/asepriteFormat.js.map +1 -0
- package/dist/cjs/pixel/pixelEditorExports.js +471 -0
- package/dist/cjs/pixel/pixelEditorExports.js.map +1 -0
- package/dist/cjs/pixel/pixelEditorTypes.js +102 -0
- package/dist/cjs/pixel/pixelEditorTypes.js.map +1 -0
- package/dist/cjs/pixel/pixelEditorUtils.js +664 -0
- package/dist/cjs/pixel/pixelEditorUtils.js.map +1 -0
- package/dist/cjs/pixel/usePixelEditor.js +1112 -0
- package/dist/cjs/pixel/usePixelEditor.js.map +1 -0
- package/dist/cjs/texture/Nice3DTexturePainter.js +236 -0
- package/dist/cjs/texture/Nice3DTexturePainter.js.map +1 -0
- package/dist/cjs/ui/NiceUIDesigner.js +191 -0
- package/dist/cjs/ui/NiceUIDesigner.js.map +1 -0
- package/dist/cjs/vector/VectorEditor.js +31 -0
- package/dist/cjs/vector/VectorEditor.js.map +1 -0
- package/dist/cjs/vector/VectorEditor.module.css.js +6 -0
- package/dist/cjs/vector/VectorEditor.module.css.js.map +1 -0
- package/dist/cjs/vector/VectorEditorMenuBar.js +16 -0
- package/dist/cjs/vector/VectorEditorMenuBar.js.map +1 -0
- package/dist/cjs/vector/VectorEditorRightPanel.js +126 -0
- package/dist/cjs/vector/VectorEditorRightPanel.js.map +1 -0
- package/dist/cjs/vector/VectorEditorShapeRenderer.js +55 -0
- package/dist/cjs/vector/VectorEditorShapeRenderer.js.map +1 -0
- package/dist/cjs/vector/VectorEditorStatusBar.js +14 -0
- package/dist/cjs/vector/VectorEditorStatusBar.js.map +1 -0
- package/dist/cjs/vector/useVectorEditor.js +613 -0
- package/dist/cjs/vector/useVectorEditor.js.map +1 -0
- package/dist/cjs/vector/vectorBooleanOps.js +511 -0
- package/dist/cjs/vector/vectorBooleanOps.js.map +1 -0
- package/dist/cjs/vector/vectorEditorExport.js +159 -0
- package/dist/cjs/vector/vectorEditorExport.js.map +1 -0
- package/dist/cjs/vector/vectorEditorImport.js +150 -0
- package/dist/cjs/vector/vectorEditorImport.js.map +1 -0
- package/dist/cjs/vector/vectorEditorTypes.js +72 -0
- package/dist/cjs/vector/vectorEditorTypes.js.map +1 -0
- package/dist/cjs/vector/vectorGradients.js +201 -0
- package/dist/cjs/vector/vectorGradients.js.map +1 -0
- package/dist/esm/animation/AnimatedPerson.js +151 -0
- package/dist/esm/animation/AnimatedPerson.js.map +1 -0
- package/dist/esm/animation/AnimationEditor.js +104 -0
- package/dist/esm/animation/AnimationEditor.js.map +1 -0
- package/dist/esm/animation/Audience.js +57 -0
- package/dist/esm/animation/Audience.js.map +1 -0
- package/dist/esm/animation/BodyRenderer.js +28 -0
- package/dist/esm/animation/BodyRenderer.js.map +1 -0
- package/dist/esm/animation/animationHelper.js +268 -0
- package/dist/esm/animation/animationHelper.js.map +1 -0
- package/dist/esm/animation/characterTypes.js +70 -0
- package/dist/esm/animation/characterTypes.js.map +1 -0
- package/dist/esm/animation/choreoDSL.js +182 -0
- package/dist/esm/animation/choreoDSL.js.map +1 -0
- package/dist/esm/animation/choreography.js +36 -0
- package/dist/esm/animation/choreography.js.map +1 -0
- package/dist/esm/animation/karaokeIntegration.js +91 -0
- package/dist/esm/animation/karaokeIntegration.js.map +1 -0
- package/dist/esm/animation/lottieExport.js +123 -0
- package/dist/esm/animation/lottieExport.js.map +1 -0
- package/dist/esm/animation/motionPath.js +185 -0
- package/dist/esm/animation/motionPath.js.map +1 -0
- package/dist/esm/animation/physics.js +192 -0
- package/dist/esm/animation/physics.js.map +1 -0
- package/dist/esm/animation/rig/RigPlayer.js +61 -0
- package/dist/esm/animation/rig/RigPlayer.js.map +1 -0
- package/dist/esm/animation/rig/RiggedBody.js +28 -0
- package/dist/esm/animation/rig/RiggedBody.js.map +1 -0
- package/dist/esm/animation/rig/choreoRigBridge.js +60 -0
- package/dist/esm/animation/rig/choreoRigBridge.js.map +1 -0
- package/dist/esm/animation/rig/ik.js +20 -0
- package/dist/esm/animation/rig/ik.js.map +1 -0
- package/dist/esm/animation/rig/poseOps.js +45 -0
- package/dist/esm/animation/rig/poseOps.js.map +1 -0
- package/dist/esm/animation/rig/presets.js +53 -0
- package/dist/esm/animation/rig/presets.js.map +1 -0
- package/dist/esm/animation/rig/rigMath.js +37 -0
- package/dist/esm/animation/rig/rigMath.js.map +1 -0
- package/dist/esm/animation/rig/rigTypes.js +40 -0
- package/dist/esm/animation/rig/rigTypes.js.map +1 -0
- package/dist/esm/animation/shapes/arms.js +13 -0
- package/dist/esm/animation/shapes/arms.js.map +1 -0
- package/dist/esm/animation/shapes/eyes.js +45 -0
- package/dist/esm/animation/shapes/eyes.js.map +1 -0
- package/dist/esm/animation/shapes/hair.js +46 -0
- package/dist/esm/animation/shapes/hair.js.map +1 -0
- package/dist/esm/animation/shapes/heads.js +52 -0
- package/dist/esm/animation/shapes/heads.js.map +1 -0
- package/dist/esm/animation/shapes/headwear.js +36 -0
- package/dist/esm/animation/shapes/headwear.js.map +1 -0
- package/dist/esm/animation/shapes/legs.js +13 -0
- package/dist/esm/animation/shapes/legs.js.map +1 -0
- package/dist/esm/animation/shapes/mouths.js +45 -0
- package/dist/esm/animation/shapes/mouths.js.map +1 -0
- package/dist/esm/animation/shapes/noses.js +23 -0
- package/dist/esm/animation/shapes/noses.js.map +1 -0
- package/dist/esm/animation/shapes/outfits.js +37 -0
- package/dist/esm/animation/shapes/outfits.js.map +1 -0
- package/dist/esm/animation/shapes/torsos.js +11 -0
- package/dist/esm/animation/shapes/torsos.js.map +1 -0
- package/dist/esm/animation/spineExport.js +128 -0
- package/dist/esm/animation/spineExport.js.map +1 -0
- package/dist/esm/core/LocalUI.js +50 -0
- package/dist/esm/core/LocalUI.js.map +1 -0
- package/dist/esm/core/collaboration.js +252 -0
- package/dist/esm/core/collaboration.js.map +1 -0
- package/dist/esm/core/colorBlindness.js +90 -0
- package/dist/esm/core/colorBlindness.js.map +1 -0
- package/dist/esm/core/dragDrop.js +165 -0
- package/dist/esm/core/dragDrop.js.map +1 -0
- package/dist/esm/core/fixes.js +179 -0
- package/dist/esm/core/fixes.js.map +1 -0
- package/dist/esm/core/gridGuides.js +232 -0
- package/dist/esm/core/gridGuides.js.map +1 -0
- package/dist/esm/core/historyVisual.js +121 -0
- package/dist/esm/core/historyVisual.js.map +1 -0
- package/dist/esm/core/i18n.js +13 -0
- package/dist/esm/core/i18n.js.map +1 -0
- package/dist/esm/core/integrations.js +254 -0
- package/dist/esm/core/integrations.js.map +1 -0
- package/dist/esm/core/minimap.js +139 -0
- package/dist/esm/core/minimap.js.map +1 -0
- package/dist/esm/core/plugins.js +124 -0
- package/dist/esm/core/plugins.js.map +1 -0
- package/dist/esm/core/rtl.js +95 -0
- package/dist/esm/core/rtl.js.map +1 -0
- package/dist/esm/core/shortcuts.js +200 -0
- package/dist/esm/core/shortcuts.js.map +1 -0
- package/dist/esm/core/theme.js +162 -0
- package/dist/esm/core/theme.js.map +1 -0
- package/dist/esm/font/NiceFontEditor.js +189 -0
- package/dist/esm/font/NiceFontEditor.js.map +1 -0
- package/dist/esm/game/GameAsset2dEditor.js +369 -0
- package/dist/esm/game/GameAsset2dEditor.js.map +1 -0
- package/dist/esm/game/GameAsset2dEditor.module.css.js +4 -0
- package/dist/esm/game/GameAsset2dEditor.module.css.js.map +1 -0
- package/dist/esm/game/gameAssetTypes.js +18 -0
- package/dist/esm/game/gameAssetTypes.js.map +1 -0
- package/dist/esm/game/gameAssetUtils.js +456 -0
- package/dist/esm/game/gameAssetUtils.js.map +1 -0
- package/dist/esm/game/useGameAssetEditor.js +759 -0
- package/dist/esm/game/useGameAssetEditor.js.map +1 -0
- package/dist/esm/icon/NiceIconEditor.js +246 -0
- package/dist/esm/icon/NiceIconEditor.js.map +1 -0
- package/dist/esm/index.js +59 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/nice2dev-ui/dist/index.js +31720 -0
- package/dist/esm/nice2dev-ui/dist/index.js.map +1 -0
- package/dist/esm/nice2dev-ui-graphics.css +1 -0
- package/dist/esm/photo/FilterThumb.js +27 -0
- package/dist/esm/photo/FilterThumb.js.map +1 -0
- package/dist/esm/photo/PhotoEditor.js +18 -0
- package/dist/esm/photo/PhotoEditor.js.map +1 -0
- package/dist/esm/photo/PhotoEditor.module.css.js +4 -0
- package/dist/esm/photo/PhotoEditor.module.css.js.map +1 -0
- package/dist/esm/photo/PhotoEditorCanvas.js +57 -0
- package/dist/esm/photo/PhotoEditorCanvas.js.map +1 -0
- package/dist/esm/photo/PhotoEditorLeftPanel.js +172 -0
- package/dist/esm/photo/PhotoEditorLeftPanel.js.map +1 -0
- package/dist/esm/photo/PhotoEditorToolbar.js +13 -0
- package/dist/esm/photo/PhotoEditorToolbar.js.map +1 -0
- package/dist/esm/photo/photoEditorActions.js +75 -0
- package/dist/esm/photo/photoEditorActions.js.map +1 -0
- package/dist/esm/photo/photoEditorTypes.js +36 -0
- package/dist/esm/photo/photoEditorTypes.js.map +1 -0
- package/dist/esm/photo/photoFilters.js +871 -0
- package/dist/esm/photo/photoFilters.js.map +1 -0
- package/dist/esm/photo/photoOverlays.js +636 -0
- package/dist/esm/photo/photoOverlays.js.map +1 -0
- package/dist/esm/photo/photoSelection.js +535 -0
- package/dist/esm/photo/photoSelection.js.map +1 -0
- package/dist/esm/photo/usePhotoEditor.js +638 -0
- package/dist/esm/photo/usePhotoEditor.js.map +1 -0
- package/dist/esm/pixel/HSVPicker.js +171 -0
- package/dist/esm/pixel/HSVPicker.js.map +1 -0
- package/dist/esm/pixel/PixelEditor.js +26 -0
- package/dist/esm/pixel/PixelEditor.js.map +1 -0
- package/dist/esm/pixel/PixelEditor.module.css.js +4 -0
- package/dist/esm/pixel/PixelEditor.module.css.js.map +1 -0
- package/dist/esm/pixel/PixelEditorCanvas.js +13 -0
- package/dist/esm/pixel/PixelEditorCanvas.js.map +1 -0
- package/dist/esm/pixel/PixelEditorMenuBar.js +9 -0
- package/dist/esm/pixel/PixelEditorMenuBar.js.map +1 -0
- package/dist/esm/pixel/PixelEditorRightPanel.js +13 -0
- package/dist/esm/pixel/PixelEditorRightPanel.js.map +1 -0
- package/dist/esm/pixel/PixelEditorStatusBar.js +13 -0
- package/dist/esm/pixel/PixelEditorStatusBar.js.map +1 -0
- package/dist/esm/pixel/PixelEditorTimeline.js +9 -0
- package/dist/esm/pixel/PixelEditorTimeline.js.map +1 -0
- package/dist/esm/pixel/PixelEditorToolbar.js +14 -0
- package/dist/esm/pixel/PixelEditorToolbar.js.map +1 -0
- package/dist/esm/pixel/asepriteFormat.js +505 -0
- package/dist/esm/pixel/asepriteFormat.js.map +1 -0
- package/dist/esm/pixel/pixelEditorExports.js +461 -0
- package/dist/esm/pixel/pixelEditorExports.js.map +1 -0
- package/dist/esm/pixel/pixelEditorTypes.js +90 -0
- package/dist/esm/pixel/pixelEditorTypes.js.map +1 -0
- package/dist/esm/pixel/pixelEditorUtils.js +631 -0
- package/dist/esm/pixel/pixelEditorUtils.js.map +1 -0
- package/dist/esm/pixel/usePixelEditor.js +1110 -0
- package/dist/esm/pixel/usePixelEditor.js.map +1 -0
- package/dist/esm/texture/Nice3DTexturePainter.js +233 -0
- package/dist/esm/texture/Nice3DTexturePainter.js.map +1 -0
- package/dist/esm/ui/NiceUIDesigner.js +187 -0
- package/dist/esm/ui/NiceUIDesigner.js.map +1 -0
- package/dist/esm/vector/VectorEditor.js +29 -0
- package/dist/esm/vector/VectorEditor.js.map +1 -0
- package/dist/esm/vector/VectorEditor.module.css.js +4 -0
- package/dist/esm/vector/VectorEditor.module.css.js.map +1 -0
- package/dist/esm/vector/VectorEditorMenuBar.js +14 -0
- package/dist/esm/vector/VectorEditorMenuBar.js.map +1 -0
- package/dist/esm/vector/VectorEditorRightPanel.js +124 -0
- package/dist/esm/vector/VectorEditorRightPanel.js.map +1 -0
- package/dist/esm/vector/VectorEditorShapeRenderer.js +53 -0
- package/dist/esm/vector/VectorEditorShapeRenderer.js.map +1 -0
- package/dist/esm/vector/VectorEditorStatusBar.js +12 -0
- package/dist/esm/vector/VectorEditorStatusBar.js.map +1 -0
- package/dist/esm/vector/useVectorEditor.js +611 -0
- package/dist/esm/vector/useVectorEditor.js.map +1 -0
- package/dist/esm/vector/vectorBooleanOps.js +507 -0
- package/dist/esm/vector/vectorBooleanOps.js.map +1 -0
- package/dist/esm/vector/vectorEditorExport.js +152 -0
- package/dist/esm/vector/vectorEditorExport.js.map +1 -0
- package/dist/esm/vector/vectorEditorImport.js +148 -0
- package/dist/esm/vector/vectorEditorImport.js.map +1 -0
- package/dist/esm/vector/vectorEditorTypes.js +63 -0
- package/dist/esm/vector/vectorEditorTypes.js.map +1 -0
- package/dist/esm/vector/vectorGradients.js +193 -0
- package/dist/esm/vector/vectorGradients.js.map +1 -0
- package/dist/types/__benchmarks__/bench.d.ts +13 -0
- package/dist/types/__tests__/setup.d.ts +4 -0
- package/dist/types/animation/AnimatedPerson.d.ts +14 -0
- package/dist/types/animation/AnimationEditor.d.ts +20 -0
- package/dist/types/animation/Audience.d.ts +11 -0
- package/dist/types/animation/BodyRenderer.d.ts +12 -0
- package/dist/types/animation/animationHelper.d.ts +28 -0
- package/dist/types/animation/characterTypes.d.ts +37 -0
- package/dist/types/animation/choreoDSL.d.ts +88 -0
- package/dist/types/animation/choreography.d.ts +8 -0
- package/dist/types/animation/karaokeIntegration.d.ts +31 -0
- package/dist/types/animation/lottieExport.d.ts +77 -0
- package/dist/types/animation/motionPath.d.ts +60 -0
- package/dist/types/animation/physics.d.ts +73 -0
- package/dist/types/animation/rig/RigPlayer.d.ts +32 -0
- package/dist/types/animation/rig/RiggedBody.d.ts +19 -0
- package/dist/types/animation/rig/choreoRigBridge.d.ts +9 -0
- package/dist/types/animation/rig/ik.d.ts +8 -0
- package/dist/types/animation/rig/poseOps.d.ts +14 -0
- package/dist/types/animation/rig/presets.d.ts +13 -0
- package/dist/types/animation/rig/rigMath.d.ts +7 -0
- package/dist/types/animation/rig/rigTypes.d.ts +38 -0
- package/dist/types/animation/shapes/arms.d.ts +10 -0
- package/dist/types/animation/shapes/eyes.d.ts +17 -0
- package/dist/types/animation/shapes/hair.d.ts +17 -0
- package/dist/types/animation/shapes/heads.d.ts +18 -0
- package/dist/types/animation/shapes/headwear.d.ts +16 -0
- package/dist/types/animation/shapes/legs.d.ts +10 -0
- package/dist/types/animation/shapes/mouths.d.ts +17 -0
- package/dist/types/animation/shapes/noses.d.ts +17 -0
- package/dist/types/animation/shapes/outfits.d.ts +14 -0
- package/dist/types/animation/shapes/torsos.d.ts +9 -0
- package/dist/types/animation/spineExport.d.ts +66 -0
- package/dist/types/core/LocalUI.d.ts +21 -0
- package/dist/types/core/collaboration.d.ts +164 -0
- package/dist/types/core/colorBlindness.d.ts +24 -0
- package/dist/types/core/dragDrop.d.ts +46 -0
- package/dist/types/core/fixes.d.ts +80 -0
- package/dist/types/core/gridGuides.d.ts +70 -0
- package/dist/types/core/historyVisual.d.ts +915 -0
- package/dist/types/core/i18n.d.ts +27 -0
- package/dist/types/core/integrations.d.ts +103 -0
- package/dist/types/core/minimap.d.ts +49 -0
- package/dist/types/core/plugins.d.ts +111 -0
- package/dist/types/core/rtl.d.ts +32 -0
- package/dist/types/core/shortcuts.d.ts +150 -0
- package/dist/types/core/theme.d.ts +78 -0
- package/dist/types/core/useGamepad.d.ts +64 -0
- package/dist/types/core/usePointerPressure.d.ts +88 -0
- package/dist/types/font/NiceFontEditor.d.ts +62 -0
- package/dist/types/game/AnimationPreviewPlayer.d.ts +29 -0
- package/dist/types/game/CollisionEditor.d.ts +101 -0
- package/dist/types/game/GameAsset2dEditor.d.ts +17 -0
- package/dist/types/game/GameAssetExportPanel.d.ts +20 -0
- package/dist/types/game/IsometricEditor.d.ts +22 -0
- package/dist/types/game/IsometricTilePanel.d.ts +18 -0
- package/dist/types/game/gameAssetExport.d.ts +160 -0
- package/dist/types/game/gameAssetTypes.d.ts +238 -0
- package/dist/types/game/gameAssetUtils.d.ts +23 -0
- package/dist/types/game/index.d.ts +8 -0
- package/dist/types/game/isometricTiles.d.ts +250 -0
- package/dist/types/game/useAnimationPreview.d.ts +63 -0
- package/dist/types/game/useCollisionEditor.d.ts +96 -0
- package/dist/types/game/useGameAssetEditor.d.ts +79 -0
- package/dist/types/game/useGameAssetExport.d.ts +82 -0
- package/dist/types/icon/NiceIconEditor.d.ts +79 -0
- package/dist/types/index.d.ts +85 -0
- package/dist/types/photo/BatchProcessingPanel.d.ts +13 -0
- package/dist/types/photo/FaceDetectionPanel.d.ts +18 -0
- package/dist/types/photo/FilterThumb.d.ts +14 -0
- package/dist/types/photo/PerspectiveCorrectionPanel.d.ts +17 -0
- package/dist/types/photo/PhotoEditor.d.ts +2 -0
- package/dist/types/photo/PhotoEditorCanvas.d.ts +14 -0
- package/dist/types/photo/PhotoEditorLeftPanel.d.ts +13 -0
- package/dist/types/photo/PhotoEditorToolbar.d.ts +13 -0
- package/dist/types/photo/RawFilePanel.d.ts +14 -0
- package/dist/types/photo/StyleTransferPanel.d.ts +15 -0
- package/dist/types/photo/aiStyleTransfer.d.ts +58 -0
- package/dist/types/photo/batchProcessing.d.ts +95 -0
- package/dist/types/photo/faceDetection.d.ts +103 -0
- package/dist/types/photo/index.d.ts +17 -0
- package/dist/types/photo/perspectiveCorrection.d.ts +134 -0
- package/dist/types/photo/photoEditorActions.d.ts +40 -0
- package/dist/types/photo/photoEditorTypes.d.ts +34 -0
- package/dist/types/photo/photoFilters.d.ts +55 -0
- package/dist/types/photo/photoOverlays.d.ts +126 -0
- package/dist/types/photo/photoSelection.d.ts +56 -0
- package/dist/types/photo/rawFileSupport.d.ts +124 -0
- package/dist/types/photo/usePhotoEditor.d.ts +123 -0
- package/dist/types/pixel/HSVPicker.d.ts +11 -0
- package/dist/types/pixel/PaletteExtractorPanel.d.ts +16 -0
- package/dist/types/pixel/PixelEditor.d.ts +17 -0
- package/dist/types/pixel/PixelEditorCanvas.d.ts +10 -0
- package/dist/types/pixel/PixelEditorMenuBar.d.ts +11 -0
- package/dist/types/pixel/PixelEditorRightPanel.d.ts +11 -0
- package/dist/types/pixel/PixelEditorStatusBar.d.ts +11 -0
- package/dist/types/pixel/PixelEditorTimeline.d.ts +11 -0
- package/dist/types/pixel/PixelEditorToolbar.d.ts +11 -0
- package/dist/types/pixel/TileMapPanel.d.ts +14 -0
- package/dist/types/pixel/asepriteFormat.d.ts +62 -0
- package/dist/types/pixel/paletteExtractor.d.ts +73 -0
- package/dist/types/pixel/pixelEditorExports.d.ts +31 -0
- package/dist/types/pixel/pixelEditorTypes.d.ts +51 -0
- package/dist/types/pixel/pixelEditorUtils.d.ts +136 -0
- package/dist/types/pixel/tileMapMode.d.ts +122 -0
- package/dist/types/pixel/usePixelEditor.d.ts +114 -0
- package/dist/types/texture/Nice3DTexturePainter.d.ts +55 -0
- package/dist/types/ui/NiceUIDesigner.d.ts +43 -0
- package/dist/types/vector/PathSimplificationPanel.d.ts +15 -0
- package/dist/types/vector/PdfExportPanel.d.ts +20 -0
- package/dist/types/vector/TextOnPathPanel.d.ts +26 -0
- package/dist/types/vector/VectorEditor.d.ts +32 -0
- package/dist/types/vector/VectorEditorMenuBar.d.ts +8 -0
- package/dist/types/vector/VectorEditorRightPanel.d.ts +7 -0
- package/dist/types/vector/VectorEditorShapeRenderer.d.ts +9 -0
- package/dist/types/vector/VectorEditorStatusBar.d.ts +9 -0
- package/dist/types/vector/VectorFilterPanel.d.ts +19 -0
- package/dist/types/vector/VectorPatternPanel.d.ts +21 -0
- package/dist/types/vector/pathSimplification.d.ts +135 -0
- package/dist/types/vector/pdfExport.d.ts +65 -0
- package/dist/types/vector/textOnPath.d.ts +145 -0
- package/dist/types/vector/useVectorEditor.d.ts +90 -0
- package/dist/types/vector/vectorBooleanOps.d.ts +22 -0
- package/dist/types/vector/vectorEditorExport.d.ts +8 -0
- package/dist/types/vector/vectorEditorImport.d.ts +7 -0
- package/dist/types/vector/vectorEditorTypes.d.ts +47 -0
- package/dist/types/vector/vectorGradients.d.ts +64 -0
- package/dist/types/vector/vectorPatternFills.d.ts +101 -0
- package/dist/types/vector/vectorSvgFilters.d.ts +134 -0
- package/package.json +93 -0
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vectorEditorTypes = require('./vectorEditorTypes.js');
|
|
4
|
+
|
|
5
|
+
/** Build SVG markup string from shapes */
|
|
6
|
+
function buildSVGString(shapes, artW, artH) {
|
|
7
|
+
const parts = [
|
|
8
|
+
`<svg xmlns="http://www.w3.org/2000/svg" width="${artW}" height="${artH}" viewBox="0 0 ${artW} ${artH}">`,
|
|
9
|
+
];
|
|
10
|
+
// Arrow marker definition
|
|
11
|
+
parts.push(` <defs><marker id="arrowhead" markerWidth="10" markerHeight="7" refX="10" refY="3.5" orient="auto"><polygon points="0 0, 10 3.5, 0 7" fill="context-stroke"/></marker></defs>`);
|
|
12
|
+
for (const s of shapes) {
|
|
13
|
+
const opacityAttr = s.opacity < 1 ? ` opacity="${s.opacity.toFixed(2)}"` : "";
|
|
14
|
+
const rotAttr = s.rotation ? ` transform="rotate(${s.rotation} ${s.x + s.w / 2} ${s.y + s.h / 2})"` : "";
|
|
15
|
+
switch (s.type) {
|
|
16
|
+
case "rect":
|
|
17
|
+
parts.push(` <rect x="${s.x}" y="${s.y}" width="${s.w}" height="${s.h}" fill="${s.fill}" stroke="${s.stroke}" stroke-width="${s.strokeWidth}"${opacityAttr}${rotAttr} />`);
|
|
18
|
+
break;
|
|
19
|
+
case "roundrect":
|
|
20
|
+
parts.push(` <rect x="${s.x}" y="${s.y}" width="${s.w}" height="${s.h}" rx="${s.rx || 12}" fill="${s.fill}" stroke="${s.stroke}" stroke-width="${s.strokeWidth}"${opacityAttr}${rotAttr} />`);
|
|
21
|
+
break;
|
|
22
|
+
case "ellipse":
|
|
23
|
+
parts.push(` <ellipse cx="${s.x + s.w / 2}" cy="${s.y + s.h / 2}" rx="${s.w / 2}" ry="${s.h / 2}" fill="${s.fill}" stroke="${s.stroke}" stroke-width="${s.strokeWidth}"${opacityAttr}${rotAttr} />`);
|
|
24
|
+
break;
|
|
25
|
+
case "line":
|
|
26
|
+
parts.push(` <line x1="${s.x}" y1="${s.y}" x2="${s.x2}" y2="${s.y2}" stroke="${s.stroke}" stroke-width="${s.strokeWidth}"${opacityAttr} />`);
|
|
27
|
+
break;
|
|
28
|
+
case "arrow":
|
|
29
|
+
parts.push(` <line x1="${s.x}" y1="${s.y}" x2="${s.x2}" y2="${s.y2}" stroke="${s.stroke}" stroke-width="${s.strokeWidth}" marker-end="url(#arrowhead)"${opacityAttr} />`);
|
|
30
|
+
break;
|
|
31
|
+
case "polyline":
|
|
32
|
+
if (s.points) {
|
|
33
|
+
const pts = s.points.map((p) => `${p.x},${p.y}`).join(" ");
|
|
34
|
+
parts.push(` <polyline points="${pts}" fill="${s.fill}" stroke="${s.stroke}" stroke-width="${s.strokeWidth}"${opacityAttr} />`);
|
|
35
|
+
}
|
|
36
|
+
break;
|
|
37
|
+
case "polygon": {
|
|
38
|
+
const cx2 = s.x + s.w / 2;
|
|
39
|
+
const cy2 = s.y + s.h / 2;
|
|
40
|
+
const r2 = Math.min(s.w, s.h) / 2;
|
|
41
|
+
const pts = vectorEditorTypes.polygonPoints(cx2, cy2, r2, s.sides || 6, s.rotation);
|
|
42
|
+
parts.push(` <polygon points="${pts}" fill="${s.fill}" stroke="${s.stroke}" stroke-width="${s.strokeWidth}"${opacityAttr} />`);
|
|
43
|
+
break;
|
|
44
|
+
}
|
|
45
|
+
case "star": {
|
|
46
|
+
const cx2 = s.x + s.w / 2;
|
|
47
|
+
const cy2 = s.y + s.h / 2;
|
|
48
|
+
const r2 = Math.min(s.w, s.h) / 2;
|
|
49
|
+
const ir = r2 * (s.innerRadius || 0.4);
|
|
50
|
+
const pts = vectorEditorTypes.starPoints(cx2, cy2, r2, ir, s.sides || 5, s.rotation);
|
|
51
|
+
parts.push(` <polygon points="${pts}" fill="${s.fill}" stroke="${s.stroke}" stroke-width="${s.strokeWidth}"${opacityAttr} />`);
|
|
52
|
+
break;
|
|
53
|
+
}
|
|
54
|
+
case "text": {
|
|
55
|
+
const esc = (s.text || "").replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">");
|
|
56
|
+
const ff = (s.fontFamily || "sans-serif").replace(/"/g, """);
|
|
57
|
+
parts.push(` <text x="${s.x}" y="${s.y + (s.fontSize || 24)}" font-size="${s.fontSize || 24}" font-family="${ff}" fill="${s.fill}"${opacityAttr}>${esc}</text>`);
|
|
58
|
+
break;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
parts.push("</svg>");
|
|
63
|
+
return parts.join("\n");
|
|
64
|
+
}
|
|
65
|
+
/** Helper to render SVG to an Image, then invoke a callback with the loaded image */
|
|
66
|
+
function svgToImage(svg, onLoad, onError) {
|
|
67
|
+
const img = new Image();
|
|
68
|
+
if (onError)
|
|
69
|
+
img.onerror = onError;
|
|
70
|
+
img.onload = () => onLoad(img);
|
|
71
|
+
img.src = "data:image/svg+xml;charset=utf-8," + encodeURIComponent(svg);
|
|
72
|
+
}
|
|
73
|
+
function exportSVGFile(shapes, artW, artH) {
|
|
74
|
+
const svg = buildSVGString(shapes, artW, artH);
|
|
75
|
+
vectorEditorTypes.downloadBlob(new Blob([svg], { type: "image/svg+xml" }), "drawing.svg");
|
|
76
|
+
}
|
|
77
|
+
function exportPNGFile(shapes, artW, artH) {
|
|
78
|
+
const svg = buildSVGString(shapes, artW, artH);
|
|
79
|
+
svgToImage(svg, (img) => {
|
|
80
|
+
const cv = document.createElement("canvas");
|
|
81
|
+
cv.width = artW;
|
|
82
|
+
cv.height = artH;
|
|
83
|
+
cv.getContext("2d").drawImage(img, 0, 0);
|
|
84
|
+
cv.toBlob((b) => b && vectorEditorTypes.downloadBlob(b, "drawing.png"));
|
|
85
|
+
}, () => alert("Failed to export PNG."));
|
|
86
|
+
}
|
|
87
|
+
function exportJPGFile(shapes, artW, artH) {
|
|
88
|
+
const svg = buildSVGString(shapes, artW, artH);
|
|
89
|
+
svgToImage(svg, (img) => {
|
|
90
|
+
const cv = document.createElement("canvas");
|
|
91
|
+
cv.width = artW;
|
|
92
|
+
cv.height = artH;
|
|
93
|
+
const ctx = cv.getContext("2d");
|
|
94
|
+
ctx.fillStyle = "#ffffff";
|
|
95
|
+
ctx.fillRect(0, 0, artW, artH);
|
|
96
|
+
ctx.drawImage(img, 0, 0);
|
|
97
|
+
cv.toBlob((b) => b && vectorEditorTypes.downloadBlob(b, "drawing.jpg"), "image/jpeg", 0.92);
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
function exportWebPFile(shapes, artW, artH) {
|
|
101
|
+
const svg = buildSVGString(shapes, artW, artH);
|
|
102
|
+
svgToImage(svg, (img) => {
|
|
103
|
+
const cv = document.createElement("canvas");
|
|
104
|
+
cv.width = artW;
|
|
105
|
+
cv.height = artH;
|
|
106
|
+
cv.getContext("2d").drawImage(img, 0, 0);
|
|
107
|
+
cv.toBlob((b) => b && vectorEditorTypes.downloadBlob(b, "drawing.webp"), "image/webp", 0.92);
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
function exportBMPFile(shapes, artW, artH) {
|
|
111
|
+
const svg = buildSVGString(shapes, artW, artH);
|
|
112
|
+
svgToImage(svg, (img) => {
|
|
113
|
+
const cv = document.createElement("canvas");
|
|
114
|
+
cv.width = artW;
|
|
115
|
+
cv.height = artH;
|
|
116
|
+
const ctx = cv.getContext("2d");
|
|
117
|
+
ctx.fillStyle = "#ffffff";
|
|
118
|
+
ctx.fillRect(0, 0, artW, artH);
|
|
119
|
+
ctx.drawImage(img, 0, 0);
|
|
120
|
+
const id = ctx.getImageData(0, 0, artW, artH);
|
|
121
|
+
const w = artW, h = artH;
|
|
122
|
+
const rowSize = Math.ceil((w * 3) / 4) * 4;
|
|
123
|
+
const pixelDataSize = rowSize * h;
|
|
124
|
+
const fileSize = 54 + pixelDataSize;
|
|
125
|
+
const buf = new ArrayBuffer(fileSize);
|
|
126
|
+
const view = new DataView(buf);
|
|
127
|
+
view.setUint8(0, 0x42);
|
|
128
|
+
view.setUint8(1, 0x4d);
|
|
129
|
+
view.setUint32(2, fileSize, true);
|
|
130
|
+
view.setUint32(10, 54, true);
|
|
131
|
+
view.setUint32(14, 40, true);
|
|
132
|
+
view.setInt32(18, w, true);
|
|
133
|
+
view.setInt32(22, h, true);
|
|
134
|
+
view.setUint16(26, 1, true);
|
|
135
|
+
view.setUint16(28, 24, true);
|
|
136
|
+
view.setUint32(34, pixelDataSize, true);
|
|
137
|
+
const d = id.data;
|
|
138
|
+
for (let y = 0; y < h; y++) {
|
|
139
|
+
const srcRow = (h - 1 - y) * w * 4;
|
|
140
|
+
const dstRow = 54 + y * rowSize;
|
|
141
|
+
for (let x = 0; x < w; x++) {
|
|
142
|
+
const si = srcRow + x * 4;
|
|
143
|
+
const di = dstRow + x * 3;
|
|
144
|
+
view.setUint8(di, d[si + 2]);
|
|
145
|
+
view.setUint8(di + 1, d[si + 1]);
|
|
146
|
+
view.setUint8(di + 2, d[si]);
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
vectorEditorTypes.downloadBlob(new Blob([buf], { type: "image/bmp" }), "drawing.bmp");
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
exports.buildSVGString = buildSVGString;
|
|
154
|
+
exports.exportBMPFile = exportBMPFile;
|
|
155
|
+
exports.exportJPGFile = exportJPGFile;
|
|
156
|
+
exports.exportPNGFile = exportPNGFile;
|
|
157
|
+
exports.exportSVGFile = exportSVGFile;
|
|
158
|
+
exports.exportWebPFile = exportWebPFile;
|
|
159
|
+
//# sourceMappingURL=vectorEditorExport.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vectorEditorExport.js","sources":["../../../src/vector/vectorEditorExport.ts"],"sourcesContent":[null],"names":["polygonPoints","starPoints","downloadBlob"],"mappings":"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"}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vectorEditorTypes = require('./vectorEditorTypes.js');
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Parse an SVG string and return an array of VShape objects.
|
|
7
|
+
* Throws an Error if the SVG is malformed.
|
|
8
|
+
* Returns an empty array if no supported shapes are found.
|
|
9
|
+
*/
|
|
10
|
+
function parseSVGToShapes(raw) {
|
|
11
|
+
const parser = new DOMParser();
|
|
12
|
+
const doc = parser.parseFromString(raw, "image/svg+xml");
|
|
13
|
+
const errs = doc.querySelector("parsererror");
|
|
14
|
+
if (errs) {
|
|
15
|
+
throw new Error("Invalid SVG");
|
|
16
|
+
}
|
|
17
|
+
const imported = [];
|
|
18
|
+
const elems = doc.querySelectorAll("rect, ellipse, circle, line, polyline, polygon, text");
|
|
19
|
+
elems.forEach((el) => {
|
|
20
|
+
const tag = el.tagName.toLowerCase();
|
|
21
|
+
const fill = el.getAttribute("fill") || (tag === "line" ? "none" : "#cccccc");
|
|
22
|
+
const stroke = el.getAttribute("stroke") || "none";
|
|
23
|
+
const sw = parseFloat(el.getAttribute("stroke-width") || "1");
|
|
24
|
+
const base = {
|
|
25
|
+
id: vectorEditorTypes.sid(),
|
|
26
|
+
fill,
|
|
27
|
+
stroke,
|
|
28
|
+
strokeWidth: sw,
|
|
29
|
+
opacity: 1,
|
|
30
|
+
rotation: 0,
|
|
31
|
+
};
|
|
32
|
+
switch (tag) {
|
|
33
|
+
case "rect": {
|
|
34
|
+
const x = parseFloat(el.getAttribute("x") || "0");
|
|
35
|
+
const y = parseFloat(el.getAttribute("y") || "0");
|
|
36
|
+
const w = parseFloat(el.getAttribute("width") || "0");
|
|
37
|
+
const h = parseFloat(el.getAttribute("height") || "0");
|
|
38
|
+
const rxVal = parseFloat(el.getAttribute("rx") || "0");
|
|
39
|
+
if (rxVal > 0) {
|
|
40
|
+
imported.push({
|
|
41
|
+
...base,
|
|
42
|
+
type: "roundrect",
|
|
43
|
+
x, y, w, h,
|
|
44
|
+
rx: rxVal,
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
imported.push({
|
|
49
|
+
...base,
|
|
50
|
+
type: "rect",
|
|
51
|
+
x, y, w, h,
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
break;
|
|
55
|
+
}
|
|
56
|
+
case "ellipse": {
|
|
57
|
+
const cx2 = parseFloat(el.getAttribute("cx") || "0");
|
|
58
|
+
const cy2 = parseFloat(el.getAttribute("cy") || "0");
|
|
59
|
+
const rx = parseFloat(el.getAttribute("rx") || "0");
|
|
60
|
+
const ry = parseFloat(el.getAttribute("ry") || "0");
|
|
61
|
+
imported.push({
|
|
62
|
+
...base,
|
|
63
|
+
type: "ellipse",
|
|
64
|
+
x: cx2 - rx,
|
|
65
|
+
y: cy2 - ry,
|
|
66
|
+
w: rx * 2,
|
|
67
|
+
h: ry * 2,
|
|
68
|
+
});
|
|
69
|
+
break;
|
|
70
|
+
}
|
|
71
|
+
case "circle": {
|
|
72
|
+
const cx2 = parseFloat(el.getAttribute("cx") || "0");
|
|
73
|
+
const cy2 = parseFloat(el.getAttribute("cy") || "0");
|
|
74
|
+
const r = parseFloat(el.getAttribute("r") || "0");
|
|
75
|
+
imported.push({
|
|
76
|
+
...base,
|
|
77
|
+
type: "ellipse",
|
|
78
|
+
x: cx2 - r,
|
|
79
|
+
y: cy2 - r,
|
|
80
|
+
w: r * 2,
|
|
81
|
+
h: r * 2,
|
|
82
|
+
});
|
|
83
|
+
break;
|
|
84
|
+
}
|
|
85
|
+
case "line": {
|
|
86
|
+
const x1 = parseFloat(el.getAttribute("x1") || "0");
|
|
87
|
+
const y1 = parseFloat(el.getAttribute("y1") || "0");
|
|
88
|
+
const x2 = parseFloat(el.getAttribute("x2") || "0");
|
|
89
|
+
const y2 = parseFloat(el.getAttribute("y2") || "0");
|
|
90
|
+
imported.push({
|
|
91
|
+
...base,
|
|
92
|
+
type: "line",
|
|
93
|
+
x: x1,
|
|
94
|
+
y: y1,
|
|
95
|
+
x2: x2,
|
|
96
|
+
y2: y2,
|
|
97
|
+
w: Math.abs(x2 - x1),
|
|
98
|
+
h: Math.abs(y2 - y1),
|
|
99
|
+
});
|
|
100
|
+
break;
|
|
101
|
+
}
|
|
102
|
+
case "polyline":
|
|
103
|
+
case "polygon": {
|
|
104
|
+
const raw2 = el.getAttribute("points") || "";
|
|
105
|
+
const pts = raw2
|
|
106
|
+
.trim()
|
|
107
|
+
.split(/\s+/)
|
|
108
|
+
.map((p) => {
|
|
109
|
+
const [x, y] = p.split(",").map(Number);
|
|
110
|
+
return { x: x || 0, y: y || 0 };
|
|
111
|
+
});
|
|
112
|
+
if (pts.length > 0) {
|
|
113
|
+
const xs = pts.map((p) => p.x);
|
|
114
|
+
const ys = pts.map((p) => p.y);
|
|
115
|
+
imported.push({
|
|
116
|
+
...base,
|
|
117
|
+
type: "polyline",
|
|
118
|
+
x: Math.min(...xs),
|
|
119
|
+
y: Math.min(...ys),
|
|
120
|
+
w: Math.max(...xs) - Math.min(...xs),
|
|
121
|
+
h: Math.max(...ys) - Math.min(...ys),
|
|
122
|
+
points: pts,
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
break;
|
|
126
|
+
}
|
|
127
|
+
case "text": {
|
|
128
|
+
const x = parseFloat(el.getAttribute("x") || "0");
|
|
129
|
+
const y = parseFloat(el.getAttribute("y") || "0");
|
|
130
|
+
const fs = parseFloat(el.getAttribute("font-size") || "24");
|
|
131
|
+
const txt = el.textContent || "";
|
|
132
|
+
imported.push({
|
|
133
|
+
...base,
|
|
134
|
+
type: "text",
|
|
135
|
+
x,
|
|
136
|
+
y: y - fs,
|
|
137
|
+
w: txt.length * fs * 0.6,
|
|
138
|
+
h: fs,
|
|
139
|
+
text: txt,
|
|
140
|
+
fontSize: fs,
|
|
141
|
+
});
|
|
142
|
+
break;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
});
|
|
146
|
+
return imported;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
exports.parseSVGToShapes = parseSVGToShapes;
|
|
150
|
+
//# sourceMappingURL=vectorEditorImport.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vectorEditorImport.js","sources":["../../../src/vector/vectorEditorImport.ts"],"sourcesContent":[null],"names":["sid"],"mappings":"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"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
/* ─── types ─── */
|
|
4
|
+
/* ─── helpers ─── */
|
|
5
|
+
let _sid = 0;
|
|
6
|
+
const sid = () => `s${++_sid}`;
|
|
7
|
+
const cloneShapes = (s) => JSON.parse(JSON.stringify(s));
|
|
8
|
+
const downloadBlob = (blob, name) => {
|
|
9
|
+
const a = document.createElement("a");
|
|
10
|
+
const url = URL.createObjectURL(blob);
|
|
11
|
+
a.href = url;
|
|
12
|
+
a.download = name;
|
|
13
|
+
a.click();
|
|
14
|
+
setTimeout(() => URL.revokeObjectURL(url), 3000);
|
|
15
|
+
};
|
|
16
|
+
const TOOLS = [
|
|
17
|
+
{ id: "pointer", icon: "↖", label: "Select", key: "V" },
|
|
18
|
+
{ id: "rect", icon: "▢", label: "Rectangle", key: "R" },
|
|
19
|
+
{ id: "roundrect", icon: "▣", label: "Rounded Rect", key: "U" },
|
|
20
|
+
{ id: "ellipse", icon: "◯", label: "Ellipse", key: "C" },
|
|
21
|
+
{ id: "line", icon: "╱", label: "Line", key: "L" },
|
|
22
|
+
{ id: "arrow", icon: "→", label: "Arrow", key: "A" },
|
|
23
|
+
{ id: "polygon", icon: "⬡", label: "Polygon", key: "G" },
|
|
24
|
+
{ id: "star", icon: "★", label: "Star", key: "S" },
|
|
25
|
+
{ id: "pen", icon: "✎", label: "Pen (polyline)", key: "P" },
|
|
26
|
+
{ id: "text", icon: "T", label: "Text", key: "T" },
|
|
27
|
+
];
|
|
28
|
+
const FONTS = [
|
|
29
|
+
"sans-serif",
|
|
30
|
+
"serif",
|
|
31
|
+
"monospace",
|
|
32
|
+
"cursive",
|
|
33
|
+
"fantasy",
|
|
34
|
+
"Arial",
|
|
35
|
+
"Georgia",
|
|
36
|
+
"Courier New",
|
|
37
|
+
"Times New Roman",
|
|
38
|
+
"Verdana",
|
|
39
|
+
];
|
|
40
|
+
/** Generate polygon points string for n-sided regular polygon */
|
|
41
|
+
function polygonPoints(cx, cy, r, sides, rotation) {
|
|
42
|
+
const pts = [];
|
|
43
|
+
for (let i = 0; i < sides; i++) {
|
|
44
|
+
const angle = (Math.PI * 2 * i) / sides - Math.PI / 2 + (rotation * Math.PI) / 180;
|
|
45
|
+
pts.push(`${cx + r * Math.cos(angle)},${cy + r * Math.sin(angle)}`);
|
|
46
|
+
}
|
|
47
|
+
return pts.join(" ");
|
|
48
|
+
}
|
|
49
|
+
/** Generate star points string */
|
|
50
|
+
function starPoints(cx, cy, outerR, innerR, points, rotation) {
|
|
51
|
+
const pts = [];
|
|
52
|
+
for (let i = 0; i < points * 2; i++) {
|
|
53
|
+
const angle = (Math.PI * i) / points - Math.PI / 2 + (rotation * Math.PI) / 180;
|
|
54
|
+
const r = i % 2 === 0 ? outerR : innerR;
|
|
55
|
+
pts.push(`${cx + r * Math.cos(angle)},${cy + r * Math.sin(angle)}`);
|
|
56
|
+
}
|
|
57
|
+
return pts.join(" ");
|
|
58
|
+
}
|
|
59
|
+
/** Snap a value to grid */
|
|
60
|
+
function snapToGrid(val, gridSize) {
|
|
61
|
+
return Math.round(val / gridSize) * gridSize;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
exports.FONTS = FONTS;
|
|
65
|
+
exports.TOOLS = TOOLS;
|
|
66
|
+
exports.cloneShapes = cloneShapes;
|
|
67
|
+
exports.downloadBlob = downloadBlob;
|
|
68
|
+
exports.polygonPoints = polygonPoints;
|
|
69
|
+
exports.sid = sid;
|
|
70
|
+
exports.snapToGrid = snapToGrid;
|
|
71
|
+
exports.starPoints = starPoints;
|
|
72
|
+
//# sourceMappingURL=vectorEditorTypes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vectorEditorTypes.js","sources":["../../../src/vector/vectorEditorTypes.ts"],"sourcesContent":[null],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Gradient types and utilities for VectorEditor
|
|
5
|
+
*/
|
|
6
|
+
/* ────────────────────────────────────────────────────────────────
|
|
7
|
+
GRADIENT ID GENERATOR
|
|
8
|
+
──────────────────────────────────────────────────────────────── */
|
|
9
|
+
let _gradId = 0;
|
|
10
|
+
const gradientId = () => `grad${++_gradId}`;
|
|
11
|
+
/* ────────────────────────────────────────────────────────────────
|
|
12
|
+
PRESET GRADIENTS
|
|
13
|
+
──────────────────────────────────────────────────────────────── */
|
|
14
|
+
const PRESET_GRADIENTS = [
|
|
15
|
+
// Linear gradients
|
|
16
|
+
{
|
|
17
|
+
type: "linear",
|
|
18
|
+
id: gradientId(),
|
|
19
|
+
angle: 0,
|
|
20
|
+
stops: [
|
|
21
|
+
{ offset: 0, color: "#ff0000" },
|
|
22
|
+
{ offset: 1, color: "#0000ff" },
|
|
23
|
+
],
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
type: "linear",
|
|
27
|
+
id: gradientId(),
|
|
28
|
+
angle: 45,
|
|
29
|
+
stops: [
|
|
30
|
+
{ offset: 0, color: "#00ff00" },
|
|
31
|
+
{ offset: 0.5, color: "#ffff00" },
|
|
32
|
+
{ offset: 1, color: "#ff0000" },
|
|
33
|
+
],
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
type: "linear",
|
|
37
|
+
id: gradientId(),
|
|
38
|
+
angle: 90,
|
|
39
|
+
stops: [
|
|
40
|
+
{ offset: 0, color: "#ffffff" },
|
|
41
|
+
{ offset: 1, color: "#000000" },
|
|
42
|
+
],
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
type: "linear",
|
|
46
|
+
id: gradientId(),
|
|
47
|
+
angle: 0,
|
|
48
|
+
stops: [
|
|
49
|
+
{ offset: 0, color: "#667eea" },
|
|
50
|
+
{ offset: 1, color: "#764ba2" },
|
|
51
|
+
],
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
type: "linear",
|
|
55
|
+
id: gradientId(),
|
|
56
|
+
angle: 45,
|
|
57
|
+
stops: [
|
|
58
|
+
{ offset: 0, color: "#f093fb" },
|
|
59
|
+
{ offset: 1, color: "#f5576c" },
|
|
60
|
+
],
|
|
61
|
+
},
|
|
62
|
+
// Radial gradients
|
|
63
|
+
{
|
|
64
|
+
type: "radial",
|
|
65
|
+
id: gradientId(),
|
|
66
|
+
cx: 0.5,
|
|
67
|
+
cy: 0.5,
|
|
68
|
+
r: 0.7,
|
|
69
|
+
stops: [
|
|
70
|
+
{ offset: 0, color: "#ffffff" },
|
|
71
|
+
{ offset: 1, color: "#000000" },
|
|
72
|
+
],
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
type: "radial",
|
|
76
|
+
id: gradientId(),
|
|
77
|
+
cx: 0.3,
|
|
78
|
+
cy: 0.3,
|
|
79
|
+
r: 0.8,
|
|
80
|
+
stops: [
|
|
81
|
+
{ offset: 0, color: "#ffff88" },
|
|
82
|
+
{ offset: 0.5, color: "#ff8800" },
|
|
83
|
+
{ offset: 1, color: "#880000" },
|
|
84
|
+
],
|
|
85
|
+
},
|
|
86
|
+
{
|
|
87
|
+
type: "radial",
|
|
88
|
+
id: gradientId(),
|
|
89
|
+
cx: 0.5,
|
|
90
|
+
cy: 0.5,
|
|
91
|
+
r: 0.5,
|
|
92
|
+
stops: [
|
|
93
|
+
{ offset: 0, color: "#00ffff", opacity: 1 },
|
|
94
|
+
{ offset: 1, color: "#00ffff", opacity: 0 },
|
|
95
|
+
],
|
|
96
|
+
},
|
|
97
|
+
];
|
|
98
|
+
/* ────────────────────────────────────────────────────────────────
|
|
99
|
+
GRADIENT TO SVG CONVERSION
|
|
100
|
+
──────────────────────────────────────────────────────────────── */
|
|
101
|
+
function gradientToSVGDef(gradient) {
|
|
102
|
+
const stopsSVG = gradient.stops
|
|
103
|
+
.map((stop) => `<stop offset="${stop.offset * 100}%" stop-color="${stop.color}"${stop.opacity !== undefined ? ` stop-opacity="${stop.opacity}"` : ""}/>`)
|
|
104
|
+
.join("\n ");
|
|
105
|
+
switch (gradient.type) {
|
|
106
|
+
case "linear": {
|
|
107
|
+
const rad = (gradient.angle * Math.PI) / 180;
|
|
108
|
+
const x1 = 50 - Math.cos(rad) * 50;
|
|
109
|
+
const y1 = 50 - Math.sin(rad) * 50;
|
|
110
|
+
const x2 = 50 + Math.cos(rad) * 50;
|
|
111
|
+
const y2 = 50 + Math.sin(rad) * 50;
|
|
112
|
+
return `<linearGradient id="${gradient.id}" x1="${x1}%" y1="${y1}%" x2="${x2}%" y2="${y2}%">
|
|
113
|
+
${stopsSVG}
|
|
114
|
+
</linearGradient>`;
|
|
115
|
+
}
|
|
116
|
+
case "radial": {
|
|
117
|
+
const fxAttr = gradient.fx !== undefined ? ` fx="${gradient.fx * 100}%"` : "";
|
|
118
|
+
const fyAttr = gradient.fy !== undefined ? ` fy="${gradient.fy * 100}%"` : "";
|
|
119
|
+
return `<radialGradient id="${gradient.id}" cx="${gradient.cx * 100}%" cy="${gradient.cy * 100}%" r="${gradient.r * 100}%"${fxAttr}${fyAttr}>
|
|
120
|
+
${stopsSVG}
|
|
121
|
+
</radialGradient>`;
|
|
122
|
+
}
|
|
123
|
+
case "conic": {
|
|
124
|
+
// SVG doesn't support conic gradients natively, so we approximate with many linear stops
|
|
125
|
+
// This creates a radial gradient with the same appearance
|
|
126
|
+
return `<radialGradient id="${gradient.id}" cx="${gradient.cx * 100}%" cy="${gradient.cy * 100}%" r="50%">
|
|
127
|
+
${stopsSVG}
|
|
128
|
+
</radialGradient>`;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
/* ────────────────────────────────────────────────────────────────
|
|
133
|
+
GRADIENT TO CSS
|
|
134
|
+
──────────────────────────────────────────────────────────────── */
|
|
135
|
+
function gradientToCSS(gradient) {
|
|
136
|
+
const stops = gradient.stops
|
|
137
|
+
.map((stop) => {
|
|
138
|
+
const opacity = stop.opacity !== undefined ? stop.opacity : 1;
|
|
139
|
+
const color = hexToRGBA(stop.color, opacity);
|
|
140
|
+
return `${color} ${stop.offset * 100}%`;
|
|
141
|
+
})
|
|
142
|
+
.join(", ");
|
|
143
|
+
switch (gradient.type) {
|
|
144
|
+
case "linear":
|
|
145
|
+
return `linear-gradient(${gradient.angle}deg, ${stops})`;
|
|
146
|
+
case "radial":
|
|
147
|
+
return `radial-gradient(ellipse ${gradient.r * 100}% ${gradient.r * 100}% at ${gradient.cx * 100}% ${gradient.cy * 100}%, ${stops})`;
|
|
148
|
+
case "conic":
|
|
149
|
+
return `conic-gradient(from ${gradient.angle}deg at ${gradient.cx * 100}% ${gradient.cy * 100}%, ${stops})`;
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
function hexToRGBA(hex, opacity) {
|
|
153
|
+
const result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
|
|
154
|
+
if (!result)
|
|
155
|
+
return hex;
|
|
156
|
+
const r = parseInt(result[1], 16);
|
|
157
|
+
const g = parseInt(result[2], 16);
|
|
158
|
+
const b = parseInt(result[3], 16);
|
|
159
|
+
return `rgba(${r}, ${g}, ${b}, ${opacity})`;
|
|
160
|
+
}
|
|
161
|
+
/* ────────────────────────────────────────────────────────────────
|
|
162
|
+
GRADIENT MANIPULATION
|
|
163
|
+
──────────────────────────────────────────────────────────────── */
|
|
164
|
+
function cloneGradient(gradient) {
|
|
165
|
+
return JSON.parse(JSON.stringify(gradient));
|
|
166
|
+
}
|
|
167
|
+
function createLinearGradient(colors, angle = 0) {
|
|
168
|
+
const stops = colors.map((color, i) => ({
|
|
169
|
+
offset: i / (colors.length - 1),
|
|
170
|
+
color,
|
|
171
|
+
}));
|
|
172
|
+
return {
|
|
173
|
+
type: "linear",
|
|
174
|
+
id: gradientId(),
|
|
175
|
+
angle,
|
|
176
|
+
stops,
|
|
177
|
+
};
|
|
178
|
+
}
|
|
179
|
+
function createRadialGradient(colors, cx = 0.5, cy = 0.5, r = 0.7) {
|
|
180
|
+
const stops = colors.map((color, i) => ({
|
|
181
|
+
offset: i / (colors.length - 1),
|
|
182
|
+
color,
|
|
183
|
+
}));
|
|
184
|
+
return {
|
|
185
|
+
type: "radial",
|
|
186
|
+
id: gradientId(),
|
|
187
|
+
cx,
|
|
188
|
+
cy,
|
|
189
|
+
r,
|
|
190
|
+
stops,
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
exports.PRESET_GRADIENTS = PRESET_GRADIENTS;
|
|
195
|
+
exports.cloneGradient = cloneGradient;
|
|
196
|
+
exports.createLinearGradient = createLinearGradient;
|
|
197
|
+
exports.createRadialGradient = createRadialGradient;
|
|
198
|
+
exports.gradientId = gradientId;
|
|
199
|
+
exports.gradientToCSS = gradientToCSS;
|
|
200
|
+
exports.gradientToSVGDef = gradientToSVGDef;
|
|
201
|
+
//# sourceMappingURL=vectorGradients.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vectorGradients.js","sources":["../../../src/vector/vectorGradients.ts"],"sourcesContent":[null],"names":[],"mappings":"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"}
|