cbvirtua 1.0.57 → 1.0.59
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/package.json +1 -1
- package/tinylib-analysis-main.zip +0 -0
- package//346/226/260/345/273/272 /346/226/207/346/234/254/346/226/207/346/241/243.txt" +9 -0
- package/README.md +0 -270
- package/Signature.vue +0 -493
- package/canvas-demo-master/canvas-demo-master/README.md +0 -7
- package/canvas-demo-master/canvas-demo-master/countShowBall/README.md +0 -7
- package/canvas-demo-master/canvas-demo-master/countShowBall/countdown.js +0 -227
- package/canvas-demo-master/canvas-demo-master/countShowBall/digit.js +0 -135
- package/canvas-demo-master/canvas-demo-master/countShowBall/index.html +0 -23
- package/canvas-demo-master/canvas-demo-master/write/README.md +0 -17
- package/canvas-demo-master/canvas-demo-master/write/css/write.css +0 -40
- package/canvas-demo-master/canvas-demo-master/write/index.html +0 -26
- package/canvas-demo-master/canvas-demo-master/write/js/controller.js +0 -43
- package/canvas-demo-master/canvas-demo-master/write/js/index.js +0 -10
- package/canvas-demo-master/canvas-demo-master/write/js/paper.js +0 -63
- package/canvas-demo-master/canvas-demo-master/write/js/require.js +0 -36
- package/canvas-demo-master/canvas-demo-master/write/js/write.js +0 -143
- package/canvas-demo-master/canvas-demo-master/writeRxJS/README.md +0 -17
- package/canvas-demo-master/canvas-demo-master/writeRxJS/css/write.css +0 -40
- package/canvas-demo-master/canvas-demo-master/writeRxJS/index.html +0 -27
- package/canvas-demo-master/canvas-demo-master/writeRxJS/js/controller.js +0 -43
- package/canvas-demo-master/canvas-demo-master/writeRxJS/js/index.js +0 -10
- package/canvas-demo-master/canvas-demo-master/writeRxJS/js/paper.js +0 -65
- package/canvas-demo-master/canvas-demo-master/writeRxJS/js/require.js +0 -36
- package/canvas-demo-master/canvas-demo-master/writeRxJS/js/write.js +0 -107
- package/canvas-event-system/.babelrc +0 -17
- package/canvas-event-system/.prettierrc +0 -9
- package/canvas-event-system/build/canvas-event-system/EventSimulator.d.ts +0 -20
- package/canvas-event-system/build/canvas-event-system/EventSimulator.js +0 -51
- package/canvas-event-system/build/canvas-event-system/helpers.d.ts +0 -3
- package/canvas-event-system/build/canvas-event-system/helpers.js +0 -21
- package/canvas-event-system/build/canvas-event-system/index.d.ts +0 -20
- package/canvas-event-system/build/canvas-event-system/index.js +0 -51
- package/canvas-event-system/build/canvas-event-system/shapes/Base.d.ts +0 -12
- package/canvas-event-system/build/canvas-event-system/shapes/Base.js +0 -26
- package/canvas-event-system/build/canvas-event-system/shapes/Circle.d.ts +0 -15
- package/canvas-event-system/build/canvas-event-system/shapes/Circle.js +0 -34
- package/canvas-event-system/build/canvas-event-system/shapes/Path.d.ts +0 -0
- package/canvas-event-system/build/canvas-event-system/shapes/Path.js +0 -0
- package/canvas-event-system/build/canvas-event-system/shapes/Rect.d.ts +0 -16
- package/canvas-event-system/build/canvas-event-system/shapes/Rect.js +0 -33
- package/canvas-event-system/build/canvas-event-system/shapes/index.d.ts +0 -4
- package/canvas-event-system/build/canvas-event-system/shapes/index.js +0 -4
- package/canvas-event-system/build/canvas-event-system/shapes/types.d.ts +0 -19
- package/canvas-event-system/build/canvas-event-system/shapes/types.js +0 -9
- package/canvas-event-system/build/index.d.ts +0 -1
- package/canvas-event-system/build/index.js +0 -24
- package/canvas-event-system/package-lock.json +0 -6825
- package/canvas-event-system/package.json +0 -40
- package/canvas-event-system/readme.md +0 -13
- package/canvas-event-system/src/canvas-event-system/EventSimulator.ts +0 -75
- package/canvas-event-system/src/canvas-event-system/helpers.ts +0 -27
- package/canvas-event-system/src/canvas-event-system/index.ts +0 -64
- package/canvas-event-system/src/canvas-event-system/shapes/Base.ts +0 -32
- package/canvas-event-system/src/canvas-event-system/shapes/Circle.ts +0 -46
- package/canvas-event-system/src/canvas-event-system/shapes/Path.ts +0 -0
- package/canvas-event-system/src/canvas-event-system/shapes/Rect.ts +0 -46
- package/canvas-event-system/src/canvas-event-system/shapes/index.ts +0 -5
- package/canvas-event-system/src/canvas-event-system/shapes/types.ts +0 -22
- package/canvas-event-system/src/index.html +0 -12
- package/canvas-event-system/src/index.ts +0 -30
- package/canvas-event-system/tsconfig.json +0 -17
- package/canvas-event-system/webpack.config.js +0 -28
- package/canvas-example-main/canvas-example-main/.github/workflows/main.yml +0 -62
- package/canvas-example-main/canvas-example-main/README.md +0 -13
- package/canvas-example-main/canvas-example-main/curved.html +0 -52
- package/canvas-example-main/canvas-example-main/eslint.config.js +0 -30
- package/canvas-example-main/canvas-example-main/index.html +0 -13
- package/canvas-example-main/canvas-example-main/package.json +0 -51
- package/canvas-example-main/canvas-example-main/pnpm-lock.yaml +0 -4760
- package/canvas-example-main/canvas-example-main/postcss.config.js +0 -6
- package/canvas-example-main/canvas-example-main/public/vite.svg +0 -1
- package/canvas-example-main/canvas-example-main/src/App.tsx +0 -17
- package/canvas-example-main/canvas-example-main/src/assets/github.svg +0 -1
- package/canvas-example-main/canvas-example-main/src/assets/react.svg +0 -1
- package/canvas-example-main/canvas-example-main/src/components/Iconfont/demo.css +0 -539
- package/canvas-example-main/canvas-example-main/src/components/Iconfont/demo_index.html +0 -418
- package/canvas-example-main/canvas-example-main/src/components/Iconfont/iconfont.css +0 -55
- package/canvas-example-main/canvas-example-main/src/components/Iconfont/iconfont.js +0 -1
- package/canvas-example-main/canvas-example-main/src/components/Iconfont/iconfont.json +0 -79
- package/canvas-example-main/canvas-example-main/src/components/Iconfont/iconfont.ttf +0 -0
- package/canvas-example-main/canvas-example-main/src/components/Iconfont/iconfont.woff +0 -0
- package/canvas-example-main/canvas-example-main/src/components/Iconfont/iconfont.woff2 +0 -0
- package/canvas-example-main/canvas-example-main/src/components/Iconfont/index.tsx +0 -39
- package/canvas-example-main/canvas-example-main/src/main.css +0 -9
- package/canvas-example-main/canvas-example-main/src/main.tsx +0 -10
- package/canvas-example-main/canvas-example-main/src/pages/2048/g2048.ts +0 -14
- package/canvas-example-main/canvas-example-main/src/pages/2048/index.tsx +0 -21
- package/canvas-example-main/canvas-example-main/src/pages/clock/index.tsx +0 -103
- package/canvas-example-main/canvas-example-main/src/pages/demo/index.tsx +0 -21
- package/canvas-example-main/canvas-example-main/src/pages/editor/components/editor/index.module.less +0 -3
- package/canvas-example-main/canvas-example-main/src/pages/editor/components/editor/index.tsx +0 -99
- package/canvas-example-main/canvas-example-main/src/pages/editor/components/header/index.module.less +0 -5
- package/canvas-example-main/canvas-example-main/src/pages/editor/components/header/index.tsx +0 -5
- package/canvas-example-main/canvas-example-main/src/pages/editor/components/material/index.module.less +0 -59
- package/canvas-example-main/canvas-example-main/src/pages/editor/components/material/index.tsx +0 -85
- package/canvas-example-main/canvas-example-main/src/pages/editor/components/setting/index.module.less +0 -7
- package/canvas-example-main/canvas-example-main/src/pages/editor/components/setting/index.tsx +0 -5
- package/canvas-example-main/canvas-example-main/src/pages/editor/core/application.ts +0 -35
- package/canvas-example-main/canvas-example-main/src/pages/editor/core/cmp/base.ts +0 -17
- package/canvas-example-main/canvas-example-main/src/pages/editor/core/cmp/factory.ts +0 -14
- package/canvas-example-main/canvas-example-main/src/pages/editor/core/cmp/shape.tsx +0 -43
- package/canvas-example-main/canvas-example-main/src/pages/editor/core/editor.ts +0 -61
- package/canvas-example-main/canvas-example-main/src/pages/editor/core/type.ts +0 -6
- package/canvas-example-main/canvas-example-main/src/pages/editor/index.module.less +0 -7
- package/canvas-example-main/canvas-example-main/src/pages/editor/index.tsx +0 -32
- package/canvas-example-main/canvas-example-main/src/pages/editor/store/component-config.ts +0 -61
- package/canvas-example-main/canvas-example-main/src/pages/editor/store/components.ts +0 -43
- package/canvas-example-main/canvas-example-main/src/pages/editor/store/layout.ts +0 -40
- package/canvas-example-main/canvas-example-main/src/pages/home/index.tsx +0 -59
- package/canvas-example-main/canvas-example-main/src/pages/jigsaw/index.tsx +0 -3
- package/canvas-example-main/canvas-example-main/src/pages/minesweeper/bomber.png +0 -0
- package/canvas-example-main/canvas-example-main/src/pages/minesweeper/index.tsx +0 -138
- package/canvas-example-main/canvas-example-main/src/pages/minesweeper/mark.png +0 -0
- package/canvas-example-main/canvas-example-main/src/pages/minesweeper/minesweeper.ts +0 -345
- package/canvas-example-main/canvas-example-main/src/pages/minesweeper/utils.ts +0 -24
- package/canvas-example-main/canvas-example-main/src/pages/pageflip/index.tsx +0 -200
- package/canvas-example-main/canvas-example-main/src/pages/pageflip/page1.jpg +0 -0
- package/canvas-example-main/canvas-example-main/src/pages/practice/draw/index.ts +0 -367
- package/canvas-example-main/canvas-example-main/src/pages/practice/index.module.less +0 -26
- package/canvas-example-main/canvas-example-main/src/pages/practice/index.tsx +0 -54
- package/canvas-example-main/canvas-example-main/src/pages/shape-editor/control.ts +0 -174
- package/canvas-example-main/canvas-example-main/src/pages/shape-editor/editor.ts +0 -91
- package/canvas-example-main/canvas-example-main/src/pages/shape-editor/index.raw.tsx +0 -159
- package/canvas-example-main/canvas-example-main/src/pages/shape-editor/index.tsx +0 -36
- package/canvas-example-main/canvas-example-main/src/pages/shape-editor/shape.ts +0 -248
- package/canvas-example-main/canvas-example-main/src/router.tsx +0 -53
- package/canvas-example-main/canvas-example-main/src/utils/storage.ts +0 -48
- package/canvas-example-main/canvas-example-main/src/vite-env.d.ts +0 -1
- package/canvas-example-main/canvas-example-main/tailwind.config.js +0 -8
- package/canvas-example-main/canvas-example-main/tsconfig.app.json +0 -30
- package/canvas-example-main/canvas-example-main/tsconfig.json +0 -7
- package/canvas-example-main/canvas-example-main/tsconfig.node.json +0 -22
- package/canvas-example-main/canvas-example-main/vite.config.ts +0 -18
- package/drawingBoard-main/drawingBoard-main/README.md +0 -32
- package/drawingBoard-main/drawingBoard-main/index.html +0 -13
- package/drawingBoard-main/drawingBoard-main/package.json +0 -31
- package/drawingBoard-main/drawingBoard-main/pnpm-lock.yaml +0 -2378
- package/drawingBoard-main/drawingBoard-main/public/vite.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/App.vue +0 -64
- package/drawingBoard-main/drawingBoard-main/src/assets/huabi.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/assets/huabigongju-juxing.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/assets/huabigongju-tuoyuan.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/assets/huabigongju-wenben.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/assets/jiantougongju-hover.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/assets/layer.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/assets/layer_1.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/assets/tuceng.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/assets/tuceng_1.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/assets/wujiaoxing.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/assets/xiangpigongju.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/assets/xuanzegongju.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/assets/zhixiangongju.svg +0 -1
- package/drawingBoard-main/drawingBoard-main/src/components/plugins/LayerOptions.tsx +0 -67
- package/drawingBoard-main/drawingBoard-main/src/components/plugins/LineSegmentBackgroundColorPlugin.tsx +0 -25
- package/drawingBoard-main/drawingBoard-main/src/components/plugins/LineSegmentColorPlugin.tsx +0 -25
- package/drawingBoard-main/drawingBoard-main/src/components/plugins/LineSegmentSizePlugin.tsx +0 -26
- package/drawingBoard-main/drawingBoard-main/src/components/plugins/TextColor.tsx +0 -25
- package/drawingBoard-main/drawingBoard-main/src/components/plugins/TextSize.tsx +0 -27
- package/drawingBoard-main/drawingBoard-main/src/components/tools/Menu.scss +0 -10
- package/drawingBoard-main/drawingBoard-main/src/components/tools/Menu.tsx +0 -33
- package/drawingBoard-main/drawingBoard-main/src/components/tools/Tips.scss +0 -16
- package/drawingBoard-main/drawingBoard-main/src/components/tools/Tips.tsx +0 -5
- package/drawingBoard-main/drawingBoard-main/src/components/tools/Toolbar.scss +0 -26
- package/drawingBoard-main/drawingBoard-main/src/components/tools/Toolbar.tsx +0 -39
- package/drawingBoard-main/drawingBoard-main/src/components/tools/ToolbarMenu.scss +0 -45
- package/drawingBoard-main/drawingBoard-main/src/components/tools/ToolbarMenu.tsx +0 -61
- package/drawingBoard-main/drawingBoard-main/src/components/tools/index.tsx +0 -22
- package/drawingBoard-main/drawingBoard-main/src/main.scss +0 -4
- package/drawingBoard-main/drawingBoard-main/src/main.ts +0 -11
- package/drawingBoard-main/drawingBoard-main/src/shims-vue.d.ts +0 -5
- package/drawingBoard-main/drawingBoard-main/src/utils/App.ts +0 -24
- package/drawingBoard-main/drawingBoard-main/src/utils/DrawingBoard.ts +0 -213
- package/drawingBoard-main/drawingBoard-main/src/utils/History.ts +0 -70
- package/drawingBoard-main/drawingBoard-main/src/utils/Tools.ts +0 -241
- package/drawingBoard-main/drawingBoard-main/src/utils/types.ts +0 -55
- package/drawingBoard-main/drawingBoard-main/src/vite-env.d.ts +0 -1
- package/drawingBoard-main/drawingBoard-main/tsconfig.app.json +0 -36
- package/drawingBoard-main/drawingBoard-main/tsconfig.json +0 -7
- package/drawingBoard-main/drawingBoard-main/tsconfig.node.json +0 -23
- package/drawingBoard-main/drawingBoard-main/vite.config.ts +0 -16
- package/hidpi-canvas-polyfill-master.zip +0 -0
- package/index.js +0 -1
- package/src/dom.js +0 -227
- package/src/index.js +0 -106
- package/src/packages/alert/index.js +0 -8
- package/src/packages/alert/src/main.vue +0 -94
- package/src/packages/aside/index.js +0 -8
- package/src/packages/aside/src/main.vue +0 -20
- package/src/packages/autocomplete/index.js +0 -8
- package/src/packages/autocomplete/src/autocomplete-suggestions.vue +0 -76
- package/src/packages/autocomplete/src/autocomplete.vue +0 -285
- package/src/packages/avatar/index.js +0 -8
- package/src/packages/avatar/src/main.vue +0 -107
- package/src/packages/backtop/index.js +0 -8
- package/src/packages/backtop/src/main.vue +0 -110
- package/src/packages/badge/index.js +0 -8
- package/src/packages/badge/src/main.vue +0 -53
- package/src/packages/breadcrumb/index.js +0 -8
- package/src/packages/breadcrumb/src/breadcrumb-item.vue +0 -41
- package/src/packages/breadcrumb/src/breadcrumb.vue +0 -34
- package/src/packages/breadcrumb-item/index.js +0 -8
- package/src/packages/button/index.js +0 -8
- package/src/packages/button/src/button-group.vue +0 -10
- package/src/packages/button/src/button.vue +0 -78
- package/src/packages/button-group/index.js +0 -8
- package/src/packages/calendar/index.js +0 -8
- package/src/packages/calendar/src/date-table.vue +0 -200
- package/src/packages/calendar/src/main.vue +0 -280
- package/src/packages/card/index.js +0 -8
- package/src/packages/card/src/main.vue +0 -23
- package/src/packages/carousel/index.js +0 -8
- package/src/packages/carousel/src/item.vue +0 -138
- package/src/packages/carousel/src/main.vue +0 -315
- package/src/packages/carousel-item/index.js +0 -8
- package/src/packages/cascader/index.js +0 -8
- package/src/packages/cascader/src/cascader.vue +0 -663
- package/src/packages/cascader-panel/index.js +0 -8
- package/src/packages/cascader-panel/src/cascader-menu.vue +0 -138
- package/src/packages/cascader-panel/src/cascader-node.vue +0 -246
- package/src/packages/cascader-panel/src/cascader-panel.vue +0 -391
- package/src/packages/cascader-panel/src/node.js +0 -166
- package/src/packages/cascader-panel/src/store.js +0 -58
- package/src/packages/checkbox/index.js +0 -8
- package/src/packages/checkbox/src/checkbox-button.vue +0 -199
- package/src/packages/checkbox/src/checkbox-group.vue +0 -48
- package/src/packages/checkbox/src/checkbox.vue +0 -222
- package/src/packages/checkbox-button/index.js +0 -8
- package/src/packages/checkbox-group/index.js +0 -8
- package/src/packages/col/index.js +0 -9
- package/src/packages/col/src/col.js +0 -71
- package/src/packages/collapse/index.js +0 -9
- package/src/packages/collapse/src/collapse-item.vue +0 -114
- package/src/packages/collapse/src/collapse.vue +0 -73
- package/src/packages/collapse-item/index.js +0 -8
- package/src/packages/color-picker/index.js +0 -8
- package/src/packages/color-picker/src/color.js +0 -317
- package/src/packages/color-picker/src/components/alpha-slider.vue +0 -132
- package/src/packages/color-picker/src/components/hue-slider.vue +0 -123
- package/src/packages/color-picker/src/components/picker-dropdown.vue +0 -121
- package/src/packages/color-picker/src/components/predefine.vue +0 -61
- package/src/packages/color-picker/src/components/sv-panel.vue +0 -100
- package/src/packages/color-picker/src/draggable.js +0 -36
- package/src/packages/color-picker/src/main.vue +0 -188
- package/src/packages/container/index.js +0 -8
- package/src/packages/container/src/main.vue +0 -33
- package/src/packages/date-picker/index.js +0 -8
- package/src/packages/date-picker/src/basic/date-table.vue +0 -441
- package/src/packages/date-picker/src/basic/month-table.vue +0 -269
- package/src/packages/date-picker/src/basic/time-spinner.vue +0 -304
- package/src/packages/date-picker/src/basic/year-table.vue +0 -111
- package/src/packages/date-picker/src/panel/date-range.vue +0 -680
- package/src/packages/date-picker/src/panel/date.vue +0 -609
- package/src/packages/date-picker/src/panel/month-range.vue +0 -289
- package/src/packages/date-picker/src/panel/time-range.vue +0 -248
- package/src/packages/date-picker/src/panel/time-select.vue +0 -178
- package/src/packages/date-picker/src/panel/time.vue +0 -186
- package/src/packages/date-picker/src/picker/date-picker.js +0 -43
- package/src/packages/date-picker/src/picker/time-picker.js +0 -39
- package/src/packages/date-picker/src/picker/time-select.js +0 -21
- package/src/packages/date-picker/src/picker.vue +0 -956
- package/src/packages/descriptions/index.js +0 -8
- package/src/packages/descriptions/src/descriptions-item.js +0 -30
- package/src/packages/descriptions/src/descriptions-row.js +0 -116
- package/src/packages/descriptions/src/index.js +0 -180
- package/src/packages/descriptions-item/index.js +0 -8
- package/src/packages/dialog/index.js +0 -8
- package/src/packages/dialog/src/component.vue +0 -212
- package/src/packages/divider/index.js +0 -8
- package/src/packages/divider/src/main.vue +0 -37
- package/src/packages/drawer/index.js +0 -8
- package/src/packages/drawer/src/main.vue +0 -205
- package/src/packages/dropdown/index.js +0 -8
- package/src/packages/dropdown/src/dropdown-item.vue +0 -37
- package/src/packages/dropdown/src/dropdown-menu.vue +0 -63
- package/src/packages/dropdown/src/dropdown.vue +0 -293
- package/src/packages/dropdown-item/index.js +0 -8
- package/src/packages/dropdown-menu/index.js +0 -8
- package/src/packages/empty/index.js +0 -7
- package/src/packages/empty/src/img-empty.vue +0 -132
- package/src/packages/empty/src/index.vue +0 -50
- package/src/packages/footer/index.js +0 -8
- package/src/packages/footer/src/main.vue +0 -20
- package/src/packages/form/index.js +0 -8
- package/src/packages/form/src/form-item.vue +0 -324
- package/src/packages/form/src/form.vue +0 -182
- package/src/packages/form/src/label-wrap.vue +0 -78
- package/src/packages/form-item/index.js +0 -8
- package/src/packages/header/index.js +0 -8
- package/src/packages/header/src/main.vue +0 -20
- package/src/packages/icon/index.js +0 -8
- package/src/packages/icon/src/icon.vue +0 -13
- package/src/packages/image/index.js +0 -8
- package/src/packages/image/src/image-viewer.vue +0 -330
- package/src/packages/image/src/main.vue +0 -249
- package/src/packages/infinite-scroll/index.js +0 -8
- package/src/packages/infinite-scroll/src/main.js +0 -150
- package/src/packages/input/index.js +0 -8
- package/src/packages/input/src/calcTextareaHeight.js +0 -104
- package/src/packages/input/src/input.vue +0 -440
- package/src/packages/input-number/index.js +0 -8
- package/src/packages/input-number/src/input-number.vue +0 -283
- package/src/packages/link/index.js +0 -8
- package/src/packages/link/src/main.vue +0 -53
- package/src/packages/loading/index.js +0 -11
- package/src/packages/loading/src/directive.js +0 -133
- package/src/packages/loading/src/index.js +0 -106
- package/src/packages/loading/src/loading.vue +0 -41
- package/src/packages/main/index.js +0 -8
- package/src/packages/main/src/main.vue +0 -12
- package/src/packages/menu/index.js +0 -8
- package/src/packages/menu/src/menu-item-group.vue +0 -45
- package/src/packages/menu/src/menu-item.vue +0 -112
- package/src/packages/menu/src/menu-mixin.js +0 -44
- package/src/packages/menu/src/menu.vue +0 -325
- package/src/packages/menu/src/submenu.vue +0 -349
- package/src/packages/menu-item/index.js +0 -8
- package/src/packages/menu-item-group/index.js +0 -8
- package/src/packages/message/index.js +0 -2
- package/src/packages/message/src/main.js +0 -91
- package/src/packages/message/src/main.vue +0 -117
- package/src/packages/message-box/index.js +0 -2
- package/src/packages/message-box/src/main.js +0 -216
- package/src/packages/message-box/src/main.vue +0 -332
- package/src/packages/notification/index.js +0 -2
- package/src/packages/notification/src/main.js +0 -94
- package/src/packages/notification/src/main.vue +0 -152
- package/src/packages/option/index.js +0 -8
- package/src/packages/option-group/index.js +0 -8
- package/src/packages/page-header/index.js +0 -8
- package/src/packages/page-header/src/main.vue +0 -30
- package/src/packages/pagination/index.js +0 -8
- package/src/packages/pagination/src/pager.vue +0 -163
- package/src/packages/pagination/src/pagination.js +0 -386
- package/src/packages/popconfirm/index.js +0 -8
- package/src/packages/popconfirm/src/main.vue +0 -104
- package/src/packages/popover/index.js +0 -14
- package/src/packages/popover/src/directive.js +0 -20
- package/src/packages/popover/src/main.vue +0 -237
- package/src/packages/progress/index.js +0 -8
- package/src/packages/progress/src/progress.vue +0 -235
- package/src/packages/radio/index.js +0 -8
- package/src/packages/radio/src/radio-button.vue +0 -115
- package/src/packages/radio/src/radio-group.vue +0 -113
- package/src/packages/radio/src/radio.vue +0 -134
- package/src/packages/radio-button/index.js +0 -8
- package/src/packages/radio-group/index.js +0 -8
- package/src/packages/rate/index.js +0 -8
- package/src/packages/rate/src/main.vue +0 -348
- package/src/packages/result/index.js +0 -8
- package/src/packages/result/src/icon-error.vue +0 -13
- package/src/packages/result/src/icon-info.vue +0 -13
- package/src/packages/result/src/icon-success.vue +0 -13
- package/src/packages/result/src/icon-warning.vue +0 -13
- package/src/packages/result/src/index.vue +0 -65
- package/src/packages/row/index.js +0 -9
- package/src/packages/row/src/row.js +0 -44
- package/src/packages/scrollbar/index.js +0 -8
- package/src/packages/scrollbar/src/bar.js +0 -92
- package/src/packages/scrollbar/src/main.js +0 -130
- package/src/packages/scrollbar/src/util.js +0 -34
- package/src/packages/select/index.js +0 -8
- package/src/packages/select/src/navigation-mixin.js +0 -54
- package/src/packages/select/src/option-group.vue +0 -60
- package/src/packages/select/src/option.vue +0 -168
- package/src/packages/select/src/select-dropdown.vue +0 -74
- package/src/packages/select/src/select.vue +0 -900
- package/src/packages/skeleton/index.js +0 -8
- package/src/packages/skeleton/src/img-placeholder.vue +0 -16
- package/src/packages/skeleton/src/index.vue +0 -76
- package/src/packages/skeleton/src/item.vue +0 -22
- package/src/packages/skeleton-item/index.js +0 -8
- package/src/packages/slider/index.js +0 -8
- package/src/packages/slider/src/button.vue +0 -238
- package/src/packages/slider/src/main.vue +0 -427
- package/src/packages/slider/src/marker.js +0 -18
- package/src/packages/spinner/index.js +0 -8
- package/src/packages/spinner/src/spinner.vue +0 -27
- package/src/packages/statistic/index.js +0 -8
- package/src/packages/statistic/src/main.vue +0 -204
- package/src/packages/step/index.js +0 -8
- package/src/packages/steps/README.md +0 -69
- package/src/packages/steps/index.js +0 -8
- package/src/packages/steps/src/step.vue +0 -184
- package/src/packages/steps/src/steps.vue +0 -68
- package/src/packages/submenu/index.js +0 -8
- package/src/packages/switch/index.js +0 -9
- package/src/packages/switch/src/component.vue +0 -174
- package/src/packages/tab-pane/index.js +0 -8
- package/src/packages/table/index.js +0 -8
- package/src/packages/table/src/config.js +0 -124
- package/src/packages/table/src/dropdown.js +0 -28
- package/src/packages/table/src/filter-panel.vue +0 -194
- package/src/packages/table/src/layout-observer.js +0 -68
- package/src/packages/table/src/store/current.js +0 -76
- package/src/packages/table/src/store/expand.js +0 -65
- package/src/packages/table/src/store/helper.js +0 -41
- package/src/packages/table/src/store/index.js +0 -147
- package/src/packages/table/src/store/tree.js +0 -209
- package/src/packages/table/src/store/watcher.js +0 -381
- package/src/packages/table/src/table-body.js +0 -469
- package/src/packages/table/src/table-column.js +0 -319
- package/src/packages/table/src/table-footer.js +0 -153
- package/src/packages/table/src/table-header.js +0 -511
- package/src/packages/table/src/table-layout.js +0 -249
- package/src/packages/table/src/table-row.js +0 -101
- package/src/packages/table/src/table.vue +0 -712
- package/src/packages/table/src/util.js +0 -273
- package/src/packages/table-column/index.js +0 -8
- package/src/packages/tabs/index.js +0 -8
- package/src/packages/tabs/src/tab-bar.vue +0 -57
- package/src/packages/tabs/src/tab-nav.vue +0 -294
- package/src/packages/tabs/src/tab-pane.vue +0 -56
- package/src/packages/tabs/src/tabs.vue +0 -191
- package/src/packages/tag/index.js +0 -8
- package/src/packages/tag/src/tag.vue +0 -58
- package/src/packages/theme-chalk/README.md +0 -33
- package/src/packages/theme-chalk/gulpfile.js +0 -25
- package/src/packages/theme-chalk/package.json +0 -35
- package/src/packages/theme-chalk/src/alert.scss +0 -147
- package/src/packages/theme-chalk/src/aside.scss +0 -7
- package/src/packages/theme-chalk/src/autocomplete.scss +0 -80
- package/src/packages/theme-chalk/src/avatar.scss +0 -51
- package/src/packages/theme-chalk/src/backtop.scss +0 -22
- package/src/packages/theme-chalk/src/badge.scss +0 -57
- package/src/packages/theme-chalk/src/base.scss +0 -2
- package/src/packages/theme-chalk/src/breadcrumb-item.scss +0 -0
- package/src/packages/theme-chalk/src/breadcrumb.scss +0 -55
- package/src/packages/theme-chalk/src/button-group.scss +0 -0
- package/src/packages/theme-chalk/src/button.scss +0 -262
- package/src/packages/theme-chalk/src/calendar.scss +0 -79
- package/src/packages/theme-chalk/src/card.scss +0 -32
- package/src/packages/theme-chalk/src/carousel-item.scss +0 -50
- package/src/packages/theme-chalk/src/carousel.scss +0 -161
- package/src/packages/theme-chalk/src/cascader-panel.scss +0 -120
- package/src/packages/theme-chalk/src/cascader.scss +0 -182
- package/src/packages/theme-chalk/src/checkbox-button.scss +0 -0
- package/src/packages/theme-chalk/src/checkbox-group.scss +0 -0
- package/src/packages/theme-chalk/src/checkbox.scss +0 -359
- package/src/packages/theme-chalk/src/col.scss +0 -156
- package/src/packages/theme-chalk/src/collapse-item.scss +0 -0
- package/src/packages/theme-chalk/src/collapse.scss +0 -63
- package/src/packages/theme-chalk/src/color-picker.scss +0 -384
- package/src/packages/theme-chalk/src/common/popup.scss +0 -42
- package/src/packages/theme-chalk/src/common/transition.scss +0 -99
- package/src/packages/theme-chalk/src/common/var.scss +0 -1028
- package/src/packages/theme-chalk/src/container.scss +0 -14
- package/src/packages/theme-chalk/src/date-picker/date-picker.scss +0 -97
- package/src/packages/theme-chalk/src/date-picker/date-range-picker.scss +0 -101
- package/src/packages/theme-chalk/src/date-picker/date-table.scss +0 -151
- package/src/packages/theme-chalk/src/date-picker/month-table.scss +0 -82
- package/src/packages/theme-chalk/src/date-picker/picker-panel.scss +0 -117
- package/src/packages/theme-chalk/src/date-picker/picker.scss +0 -197
- package/src/packages/theme-chalk/src/date-picker/time-picker.scss +0 -85
- package/src/packages/theme-chalk/src/date-picker/time-range-picker.scss +0 -31
- package/src/packages/theme-chalk/src/date-picker/time-spinner.scss +0 -110
- package/src/packages/theme-chalk/src/date-picker/year-table.scss +0 -51
- package/src/packages/theme-chalk/src/date-picker.scss +0 -12
- package/src/packages/theme-chalk/src/descriptions-item.scss +0 -42
- package/src/packages/theme-chalk/src/descriptions.scss +0 -111
- package/src/packages/theme-chalk/src/dialog.scss +0 -123
- package/src/packages/theme-chalk/src/display.scss +0 -12
- package/src/packages/theme-chalk/src/divider.scss +0 -47
- package/src/packages/theme-chalk/src/drawer.scss +0 -219
- package/src/packages/theme-chalk/src/dropdown-item.scss +0 -0
- package/src/packages/theme-chalk/src/dropdown-menu.scss +0 -0
- package/src/packages/theme-chalk/src/dropdown.scss +0 -182
- package/src/packages/theme-chalk/src/empty.scss +0 -45
- package/src/packages/theme-chalk/src/fonts/element-icons.ttf +0 -0
- package/src/packages/theme-chalk/src/fonts/element-icons.woff +0 -0
- package/src/packages/theme-chalk/src/footer.scss +0 -8
- package/src/packages/theme-chalk/src/form-item.scss +0 -0
- package/src/packages/theme-chalk/src/form.scss +0 -167
- package/src/packages/theme-chalk/src/header.scss +0 -8
- package/src/packages/theme-chalk/src/icon.scss +0 -1167
- package/src/packages/theme-chalk/src/image.scss +0 -179
- package/src/packages/theme-chalk/src/index.scss +0 -87
- package/src/packages/theme-chalk/src/infinite-scroll.scss +0 -0
- package/src/packages/theme-chalk/src/infiniteScroll.scss +0 -0
- package/src/packages/theme-chalk/src/input-number.scss +0 -180
- package/src/packages/theme-chalk/src/input.scss +0 -360
- package/src/packages/theme-chalk/src/link.scss +0 -81
- package/src/packages/theme-chalk/src/loading.scss +0 -96
- package/src/packages/theme-chalk/src/main.scss +0 -12
- package/src/packages/theme-chalk/src/menu-item-group.scss +0 -0
- package/src/packages/theme-chalk/src/menu-item.scss +0 -0
- package/src/packages/theme-chalk/src/menu.scss +0 -289
- package/src/packages/theme-chalk/src/message-box.scss +0 -226
- package/src/packages/theme-chalk/src/message.scss +0 -120
- package/src/packages/theme-chalk/src/mixins/_button.scss +0 -81
- package/src/packages/theme-chalk/src/mixins/config.scss +0 -4
- package/src/packages/theme-chalk/src/mixins/function.scss +0 -44
- package/src/packages/theme-chalk/src/mixins/mixins.scss +0 -190
- package/src/packages/theme-chalk/src/mixins/utils.scss +0 -39
- package/src/packages/theme-chalk/src/notification.scss +0 -99
- package/src/packages/theme-chalk/src/option-group.scss +0 -42
- package/src/packages/theme-chalk/src/option.scss +0 -36
- package/src/packages/theme-chalk/src/page-header.scss +0 -41
- package/src/packages/theme-chalk/src/pagination.scss +0 -295
- package/src/packages/theme-chalk/src/popconfirm.scss +0 -16
- package/src/packages/theme-chalk/src/popover.scss +0 -40
- package/src/packages/theme-chalk/src/popper.scss +0 -101
- package/src/packages/theme-chalk/src/progress.scss +0 -141
- package/src/packages/theme-chalk/src/radio-button.scss +0 -113
- package/src/packages/theme-chalk/src/radio-group.scss +0 -9
- package/src/packages/theme-chalk/src/radio.scss +0 -199
- package/src/packages/theme-chalk/src/rate.scss +0 -49
- package/src/packages/theme-chalk/src/reset.scss +0 -79
- package/src/packages/theme-chalk/src/result.scss +0 -61
- package/src/packages/theme-chalk/src/row.scss +0 -43
- package/src/packages/theme-chalk/src/scrollbar.scss +0 -72
- package/src/packages/theme-chalk/src/select-dropdown.scss +0 -62
- package/src/packages/theme-chalk/src/select.scss +0 -152
- package/src/packages/theme-chalk/src/skeleton-item.scss +0 -84
- package/src/packages/theme-chalk/src/skeleton.scss +0 -40
- package/src/packages/theme-chalk/src/slider.scss +0 -250
- package/src/packages/theme-chalk/src/spinner.scss +0 -44
- package/src/packages/theme-chalk/src/statistic.scss +0 -38
- package/src/packages/theme-chalk/src/step.scss +0 -317
- package/src/packages/theme-chalk/src/steps.scss +0 -20
- package/src/packages/theme-chalk/src/submenu.scss +0 -0
- package/src/packages/theme-chalk/src/switch.scss +0 -116
- package/src/packages/theme-chalk/src/tab-pane.scss +0 -0
- package/src/packages/theme-chalk/src/table-column.scss +0 -97
- package/src/packages/theme-chalk/src/table.scss +0 -564
- package/src/packages/theme-chalk/src/tabs.scss +0 -602
- package/src/packages/theme-chalk/src/tag.scss +0 -163
- package/src/packages/theme-chalk/src/time-picker.scss +0 -8
- package/src/packages/theme-chalk/src/time-select.scss +0 -37
- package/src/packages/theme-chalk/src/timeline-item.scss +0 -86
- package/src/packages/theme-chalk/src/timeline.scss +0 -14
- package/src/packages/theme-chalk/src/tooltip.scss +0 -141
- package/src/packages/theme-chalk/src/transfer.scss +0 -227
- package/src/packages/theme-chalk/src/tree.scss +0 -123
- package/src/packages/theme-chalk/src/upload.scss +0 -603
- package/src/packages/time-picker/index.js +0 -8
- package/src/packages/time-select/index.js +0 -8
- package/src/packages/timeline/index.js +0 -8
- package/src/packages/timeline/src/item.vue +0 -73
- package/src/packages/timeline/src/main.vue +0 -33
- package/src/packages/timeline-item/index.js +0 -8
- package/src/packages/tooltip/index.js +0 -8
- package/src/packages/tooltip/src/main.js +0 -242
- package/src/packages/transfer/index.js +0 -8
- package/src/packages/transfer/src/main.vue +0 -231
- package/src/packages/transfer/src/transfer-panel.vue +0 -251
- package/src/packages/tree/index.js +0 -8
- package/src/packages/tree/src/model/node.js +0 -484
- package/src/packages/tree/src/model/tree-store.js +0 -340
- package/src/packages/tree/src/model/util.js +0 -27
- package/src/packages/tree/src/tree-node.vue +0 -279
- package/src/packages/tree/src/tree.vue +0 -496
- package/src/packages/upload/index.js +0 -8
- package/src/packages/upload/src/ajax.js +0 -85
- package/src/packages/upload/src/index.vue +0 -338
- package/src/packages/upload/src/upload-dragger.vue +0 -70
- package/src/packages/upload/src/upload-list.vue +0 -105
- package/src/packages/upload/src/upload.vue +0 -211
- package/src/src/directives/mousewheel.js +0 -18
- package/src/src/directives/repeat-click.js +0 -26
- package/src/src/index.js +0 -309
- package/src/src/locale/format.js +0 -46
- package/src/src/locale/index.js +0 -48
- package/src/src/locale/lang/af-ZA.js +0 -123
- package/src/src/locale/lang/ar.js +0 -122
- package/src/src/locale/lang/az.js +0 -126
- package/src/src/locale/lang/bg.js +0 -123
- package/src/src/locale/lang/bn.js +0 -126
- package/src/src/locale/lang/ca.js +0 -122
- package/src/src/locale/lang/cs-CZ.js +0 -125
- package/src/src/locale/lang/da.js +0 -122
- package/src/src/locale/lang/de.js +0 -124
- package/src/src/locale/lang/ee.js +0 -123
- package/src/src/locale/lang/el.js +0 -123
- package/src/src/locale/lang/en.js +0 -123
- package/src/src/locale/lang/eo.js +0 -123
- package/src/src/locale/lang/es.js +0 -122
- package/src/src/locale/lang/eu.js +0 -123
- package/src/src/locale/lang/fa.js +0 -123
- package/src/src/locale/lang/fi.js +0 -123
- package/src/src/locale/lang/fr.js +0 -122
- package/src/src/locale/lang/he.js +0 -123
- package/src/src/locale/lang/hr.js +0 -123
- package/src/src/locale/lang/hu.js +0 -122
- package/src/src/locale/lang/hy-AM.js +0 -123
- package/src/src/locale/lang/id.js +0 -123
- package/src/src/locale/lang/is.js +0 -124
- package/src/src/locale/lang/it.js +0 -122
- package/src/src/locale/lang/ja.js +0 -123
- package/src/src/locale/lang/kg.js +0 -123
- package/src/src/locale/lang/km.js +0 -123
- package/src/src/locale/lang/ko.js +0 -123
- package/src/src/locale/lang/ku.js +0 -123
- package/src/src/locale/lang/kz.js +0 -123
- package/src/src/locale/lang/lo-LA.js +0 -126
- package/src/src/locale/lang/lt.js +0 -123
- package/src/src/locale/lang/lv.js +0 -123
- package/src/src/locale/lang/mn.js +0 -123
- package/src/src/locale/lang/ms.js +0 -122
- package/src/src/locale/lang/nb-NO.js +0 -122
- package/src/src/locale/lang/nl.js +0 -123
- package/src/src/locale/lang/pl.js +0 -123
- package/src/src/locale/lang/pt-br.js +0 -123
- package/src/src/locale/lang/pt.js +0 -123
- package/src/src/locale/lang/ro.js +0 -123
- package/src/src/locale/lang/ru-RU.js +0 -123
- package/src/src/locale/lang/si.js +0 -123
- package/src/src/locale/lang/sk.js +0 -125
- package/src/src/locale/lang/sl.js +0 -123
- package/src/src/locale/lang/sr-Latn.js +0 -123
- package/src/src/locale/lang/sr.js +0 -123
- package/src/src/locale/lang/sv-SE.js +0 -123
- package/src/src/locale/lang/sw.js +0 -123
- package/src/src/locale/lang/ta.js +0 -122
- package/src/src/locale/lang/th.js +0 -123
- package/src/src/locale/lang/tk.js +0 -123
- package/src/src/locale/lang/tr-TR.js +0 -123
- package/src/src/locale/lang/ua.js +0 -123
- package/src/src/locale/lang/ug-CN.js +0 -123
- package/src/src/locale/lang/uz-UZ.js +0 -123
- package/src/src/locale/lang/vi.js +0 -123
- package/src/src/locale/lang/zh-CN.js +0 -123
- package/src/src/locale/lang/zh-TW.js +0 -123
- package/src/src/mixins/emitter.js +0 -33
- package/src/src/mixins/focus.js +0 -9
- package/src/src/mixins/locale.js +0 -9
- package/src/src/mixins/migrating.js +0 -54
- package/src/src/transitions/collapse-transition.js +0 -77
- package/src/src/utils/after-leave.js +0 -27
- package/src/src/utils/aria-dialog.js +0 -90
- package/src/src/utils/aria-utils.js +0 -122
- package/src/src/utils/clickoutside.js +0 -76
- package/src/src/utils/date-util.js +0 -282
- package/src/src/utils/date.js +0 -368
- package/src/src/utils/dom.js +0 -227
- package/src/src/utils/lodash.js +0 -18075
- package/src/src/utils/menu/aria-menubar.js +0 -14
- package/src/src/utils/menu/aria-menuitem.js +0 -49
- package/src/src/utils/menu/aria-submenu.js +0 -59
- package/src/src/utils/merge.js +0 -15
- package/src/src/utils/popper.js +0 -1276
- package/src/src/utils/popup/index.js +0 -218
- package/src/src/utils/popup/popup-manager.js +0 -194
- package/src/src/utils/resize-event.js +0 -36
- package/src/src/utils/scroll-into-view.js +0 -27
- package/src/src/utils/scrollbar-width.js +0 -29
- package/src/src/utils/shared.js +0 -7
- package/src/src/utils/types.js +0 -40
- package/src/src/utils/util.js +0 -245
- package/src/src/utils/vdom.js +0 -5
- package/src/src/utils/vue-popper.js +0 -198
- package/src//346/226/260/345/273/272 /346/226/207/346/234/254/346/226/207/346/241/243.txt" +0 -256
|
@@ -1,174 +0,0 @@
|
|
|
1
|
-
import { App, Ellipse, Line, UI } from 'leafer-ui';
|
|
2
|
-
import Editor from './editor';
|
|
3
|
-
|
|
4
|
-
export interface IControl {
|
|
5
|
-
offsetX: number;
|
|
6
|
-
offsetY: number;
|
|
7
|
-
effect?: string;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
const circleRadius = 12;
|
|
11
|
-
|
|
12
|
-
export interface IControlConfig {
|
|
13
|
-
points?: UI[];
|
|
14
|
-
controls?: IControl[][];
|
|
15
|
-
onMove?: (e) => void;
|
|
16
|
-
onMoveEnd?: (e) => void;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export default class Control {
|
|
20
|
-
config: IControlConfig;
|
|
21
|
-
app: App;
|
|
22
|
-
editor: Editor;
|
|
23
|
-
private controlEls: UI[] = [];
|
|
24
|
-
|
|
25
|
-
point: UI;
|
|
26
|
-
control: IControl[];
|
|
27
|
-
|
|
28
|
-
private pointsIdxMap: Map<number, number> = new Map();
|
|
29
|
-
|
|
30
|
-
private controlIdxMap: Map<number, number> = new Map();
|
|
31
|
-
|
|
32
|
-
constructor(app: App, config: IControlConfig) {
|
|
33
|
-
this.config = config;
|
|
34
|
-
this.app = app;
|
|
35
|
-
|
|
36
|
-
this.config.points.forEach((point, index) => {
|
|
37
|
-
this.pointsIdxMap.set(point.innerId, index);
|
|
38
|
-
});
|
|
39
|
-
|
|
40
|
-
const { onMove = () => {}, onMoveEnd = () => {} } = this.config;
|
|
41
|
-
|
|
42
|
-
this.editor = new Editor(this.app, {
|
|
43
|
-
onMove: (e) => {
|
|
44
|
-
const controlIdx = this.controlIdxMap.get(e.target.innerId);
|
|
45
|
-
const pointIdx = this.pointsIdxMap.get(e.target.innerId);
|
|
46
|
-
|
|
47
|
-
if (controlIdx !== undefined) {
|
|
48
|
-
const offsetX = e.x - this.point.x;
|
|
49
|
-
const offsetY = e.y - this.point.y;
|
|
50
|
-
|
|
51
|
-
this.control[controlIdx].offsetX = offsetX;
|
|
52
|
-
this.control[controlIdx].offsetY = offsetY;
|
|
53
|
-
this.draw();
|
|
54
|
-
onMove({ offsetX, offsetY });
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
if (pointIdx !== undefined) {
|
|
58
|
-
this.point = this.config.points[pointIdx];
|
|
59
|
-
this.control = this.config.controls[pointIdx];
|
|
60
|
-
this.draw();
|
|
61
|
-
}
|
|
62
|
-
},
|
|
63
|
-
|
|
64
|
-
onTap: (e) => {
|
|
65
|
-
const idx = this.pointsIdxMap.get(e.target.innerId);
|
|
66
|
-
|
|
67
|
-
if (idx !== undefined) {
|
|
68
|
-
if (this.point && this.point.innerId !== e.target.innerId) {
|
|
69
|
-
this.reset();
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
this.point = this.config.points[idx];
|
|
73
|
-
this.control = this.config.controls[idx];
|
|
74
|
-
this.draw();
|
|
75
|
-
} else {
|
|
76
|
-
this.reset();
|
|
77
|
-
}
|
|
78
|
-
},
|
|
79
|
-
onMoveEnd: (e) => {
|
|
80
|
-
onMoveEnd(e);
|
|
81
|
-
},
|
|
82
|
-
});
|
|
83
|
-
this.draw();
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
private draw() {
|
|
87
|
-
if (!this.point || !this.control?.length) return;
|
|
88
|
-
|
|
89
|
-
this.clear();
|
|
90
|
-
|
|
91
|
-
const [leftControl, rightControl] = this.control || [];
|
|
92
|
-
if (leftControl) {
|
|
93
|
-
const x = leftControl.offsetX + this.point.x;
|
|
94
|
-
const y = leftControl.offsetY + this.point.y;
|
|
95
|
-
|
|
96
|
-
const leftPoint = new Ellipse({
|
|
97
|
-
x,
|
|
98
|
-
y,
|
|
99
|
-
width: circleRadius,
|
|
100
|
-
height: circleRadius,
|
|
101
|
-
fill: 'rgb(50,205,121)',
|
|
102
|
-
cursor: 'move',
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
this.controlIdxMap.set(leftPoint.innerId, 0);
|
|
106
|
-
|
|
107
|
-
this.controlEls.push(leftPoint);
|
|
108
|
-
this.app.tree.add(leftPoint);
|
|
109
|
-
|
|
110
|
-
const leftLine = new Line({
|
|
111
|
-
points: [
|
|
112
|
-
x + circleRadius / 2,
|
|
113
|
-
y + circleRadius / 2,
|
|
114
|
-
this.point.x + this.point.width / 2,
|
|
115
|
-
this.point.y + this.point.height / 2,
|
|
116
|
-
],
|
|
117
|
-
width: 1,
|
|
118
|
-
stroke: 'rgb(50,205,121)',
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
this.controlEls.push(leftLine);
|
|
122
|
-
|
|
123
|
-
this.app.tree.add(leftLine);
|
|
124
|
-
}
|
|
125
|
-
if (rightControl) {
|
|
126
|
-
const x = rightControl.offsetX + this.point.x;
|
|
127
|
-
const y = rightControl.offsetY + this.point.y;
|
|
128
|
-
|
|
129
|
-
const rightPoint = new Ellipse({
|
|
130
|
-
x: rightControl.offsetX + this.point.x,
|
|
131
|
-
y: rightControl.offsetY + this.point.y,
|
|
132
|
-
width: circleRadius,
|
|
133
|
-
height: circleRadius,
|
|
134
|
-
fill: 'rgb(50,205,121)',
|
|
135
|
-
cursor: 'move',
|
|
136
|
-
});
|
|
137
|
-
this.controlEls.push(rightPoint);
|
|
138
|
-
|
|
139
|
-
this.controlIdxMap.set(rightPoint.innerId, 1);
|
|
140
|
-
this.app.tree.add(rightPoint);
|
|
141
|
-
|
|
142
|
-
const rightLine = new Line({
|
|
143
|
-
points: [
|
|
144
|
-
this.point.x + this.point.width / 2,
|
|
145
|
-
this.point.y + this.point.height / 2,
|
|
146
|
-
x + circleRadius / 2,
|
|
147
|
-
y + circleRadius / 2,
|
|
148
|
-
],
|
|
149
|
-
width: 1,
|
|
150
|
-
stroke: 'rgb(50,205,121)',
|
|
151
|
-
});
|
|
152
|
-
|
|
153
|
-
this.controlEls.push(rightLine);
|
|
154
|
-
|
|
155
|
-
this.app.tree.add(rightLine);
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
update(config: IControlConfig) {
|
|
160
|
-
this.config = { ...this.config, ...config };
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
clear() {
|
|
164
|
-
this.controlEls.forEach((el) => {
|
|
165
|
-
this.app.tree.remove(el);
|
|
166
|
-
});
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
reset() {
|
|
170
|
-
this.clear();
|
|
171
|
-
this.point = null;
|
|
172
|
-
this.control = [];
|
|
173
|
-
}
|
|
174
|
-
}
|
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
import { App, PointerEvent, UI } from 'leafer-ui';
|
|
2
|
-
|
|
3
|
-
export interface IEditorConfig {
|
|
4
|
-
onMove?: (e) => void;
|
|
5
|
-
onMoveEnd?: (e) => void;
|
|
6
|
-
onTap?: (e) => void;
|
|
7
|
-
onDown?: (e) => void;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
interface ISelector {
|
|
11
|
-
_offsetX: number;
|
|
12
|
-
_offsetY: number;
|
|
13
|
-
target: UI;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export default class Editor {
|
|
17
|
-
app: App;
|
|
18
|
-
config: IEditorConfig;
|
|
19
|
-
isMouseDown: boolean;
|
|
20
|
-
isMoving: boolean;
|
|
21
|
-
selector: ISelector;
|
|
22
|
-
|
|
23
|
-
constructor(app: App, config: IEditorConfig) {
|
|
24
|
-
this.app = app;
|
|
25
|
-
this.config = config;
|
|
26
|
-
|
|
27
|
-
const {
|
|
28
|
-
onMove = () => {},
|
|
29
|
-
onMoveEnd = () => {},
|
|
30
|
-
onTap = () => {},
|
|
31
|
-
onDown = () => {},
|
|
32
|
-
} = this.config;
|
|
33
|
-
|
|
34
|
-
this.app.on(PointerEvent.MOVE, (e) => {
|
|
35
|
-
const { x, y } = e;
|
|
36
|
-
|
|
37
|
-
if (this.isMouseDown) {
|
|
38
|
-
if (this.selector && this.selector.target.cursor === 'move') {
|
|
39
|
-
this.isMoving = true;
|
|
40
|
-
|
|
41
|
-
const { _offsetX, _offsetY } = this.selector;
|
|
42
|
-
|
|
43
|
-
this.selector.target.x = x - _offsetX;
|
|
44
|
-
this.selector.target.y = y - _offsetY;
|
|
45
|
-
|
|
46
|
-
onMove({
|
|
47
|
-
target: this.selector.target,
|
|
48
|
-
x,
|
|
49
|
-
y,
|
|
50
|
-
offsetX: x - this.selector.target.x,
|
|
51
|
-
offsetY: y - this.selector.target.y,
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
this.app.on(PointerEvent.DOWN, (e) => {
|
|
58
|
-
this.isMouseDown = true;
|
|
59
|
-
|
|
60
|
-
if (this.app !== e.target) {
|
|
61
|
-
const { x, y } = e.target;
|
|
62
|
-
|
|
63
|
-
const _offsetX = e.x - x;
|
|
64
|
-
const _offsetY = e.y - y;
|
|
65
|
-
|
|
66
|
-
this.selector = { target: e.target, _offsetX, _offsetY };
|
|
67
|
-
onDown({ target: e.target });
|
|
68
|
-
}
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
this.app.on(PointerEvent.UP, (e) => {
|
|
72
|
-
if (this.isMoving) {
|
|
73
|
-
onMoveEnd({ target: e.target });
|
|
74
|
-
}
|
|
75
|
-
this.isMouseDown = false;
|
|
76
|
-
this.isMoving = false;
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
this.app.on(PointerEvent.TAP, (e) => {
|
|
80
|
-
const { x, y } = e;
|
|
81
|
-
|
|
82
|
-
if (this.app === e.target) {
|
|
83
|
-
this.selector = null;
|
|
84
|
-
onTap({ target: e.target, x, y });
|
|
85
|
-
} else {
|
|
86
|
-
this.selector.target = e.target;
|
|
87
|
-
onTap({ target: e.target, x, y });
|
|
88
|
-
}
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
}
|
|
@@ -1,159 +0,0 @@
|
|
|
1
|
-
// import { useEffect, useRef } from 'react';
|
|
2
|
-
|
|
3
|
-
// const canvasWidth = 800;
|
|
4
|
-
// const canvasHeight = 800;
|
|
5
|
-
|
|
6
|
-
// export default function ShapeEditor() {
|
|
7
|
-
// const canvasRef = useRef<HTMLCanvasElement>();
|
|
8
|
-
|
|
9
|
-
// useEffect(() => {
|
|
10
|
-
// const canvas = canvasRef.current;
|
|
11
|
-
// const ctx = canvasRef.current.getContext('2d');
|
|
12
|
-
|
|
13
|
-
// const points = [
|
|
14
|
-
// [300, 300],
|
|
15
|
-
// [240, 400],
|
|
16
|
-
// [300, 500],
|
|
17
|
-
// [400, 500],
|
|
18
|
-
// [460, 400],
|
|
19
|
-
// [400, 400],
|
|
20
|
-
// ];
|
|
21
|
-
|
|
22
|
-
// const radius = 8;
|
|
23
|
-
|
|
24
|
-
// const drawArc = (x, y) => {
|
|
25
|
-
// ctx.beginPath();
|
|
26
|
-
// ctx.arc(x, y, radius, 0, Math.PI * 2);
|
|
27
|
-
// ctx.strokeStyle = 'lime';
|
|
28
|
-
// ctx.lineWidth = 2;
|
|
29
|
-
// ctx.stroke();
|
|
30
|
-
// };
|
|
31
|
-
|
|
32
|
-
// const drawPol = () => {
|
|
33
|
-
// ctx.clearRect(0, 0, canvasWidth, canvasHeight);
|
|
34
|
-
// ctx.beginPath();
|
|
35
|
-
|
|
36
|
-
// ctx.moveTo(points[0][0], points[0][1]);
|
|
37
|
-
|
|
38
|
-
// const P1 = points[0];
|
|
39
|
-
// const P2 = points[1];
|
|
40
|
-
// const P3 = points[2];
|
|
41
|
-
|
|
42
|
-
// const AC = { x: P3[0] - P1[0], y: P3[1] - P1[1] };
|
|
43
|
-
|
|
44
|
-
// const ACLen = Math.sqrt(AC.x ** 2 + AC.y ** 2);
|
|
45
|
-
|
|
46
|
-
// const u = { x: AC.x / ACLen, y: AC.y / ACLen };
|
|
47
|
-
|
|
48
|
-
// const P21 = { x: P2[0] - 100 * u.x, y: P2[1] - 100 * u.y };
|
|
49
|
-
// const P22 = { x: P2[0] + 50 * u.x, y: P2[1] + 50 * u.y };
|
|
50
|
-
|
|
51
|
-
// drawArc(P21.x, P21.y);
|
|
52
|
-
// drawArc(P22.x, P22.y);
|
|
53
|
-
|
|
54
|
-
// ctx.moveTo(P1[0], P1[1]);
|
|
55
|
-
// ctx.quadraticCurveTo(P21.x, P21.y, P2[0], P2[1]);
|
|
56
|
-
// ctx.quadraticCurveTo(P22.x, P22.y, P3[0], P3[1]);
|
|
57
|
-
|
|
58
|
-
// points.slice(3).forEach((point) => {
|
|
59
|
-
// ctx.lineTo(point[0], point[1]);
|
|
60
|
-
// });
|
|
61
|
-
// ctx.strokeStyle = 'red';
|
|
62
|
-
// ctx.lineWidth = 1;
|
|
63
|
-
// ctx.closePath();
|
|
64
|
-
// ctx.stroke();
|
|
65
|
-
|
|
66
|
-
// points.forEach((point) => {
|
|
67
|
-
// drawArc(point[0], point[1]);
|
|
68
|
-
// });
|
|
69
|
-
// };
|
|
70
|
-
|
|
71
|
-
// let isEnter = false;
|
|
72
|
-
// let isDown = false;
|
|
73
|
-
|
|
74
|
-
// let moveX = null,
|
|
75
|
-
// moveY = null;
|
|
76
|
-
|
|
77
|
-
// let movePoint = null;
|
|
78
|
-
|
|
79
|
-
// const handleMousemove = (e) => {
|
|
80
|
-
// const rect = canvas.getBoundingClientRect();
|
|
81
|
-
// const x = e.clientX - rect.left;
|
|
82
|
-
// const y = e.clientY - rect.top;
|
|
83
|
-
|
|
84
|
-
// if (isDown) {
|
|
85
|
-
// canvas.style.cursor = 'pointer';
|
|
86
|
-
// if (!movePoint || moveX === null || moveY === null) return;
|
|
87
|
-
// movePoint[0] = movePoint[0] - moveX + x;
|
|
88
|
-
// movePoint[1] = movePoint[1] - moveY + y;
|
|
89
|
-
// moveX = movePoint[0];
|
|
90
|
-
// moveY = movePoint[1];
|
|
91
|
-
// drawPol();
|
|
92
|
-
// } else if (isEnter) {
|
|
93
|
-
// canvas.style.cursor = 'pointer';
|
|
94
|
-
// } else {
|
|
95
|
-
// for (const point of points) {
|
|
96
|
-
// const dx = x - point[0];
|
|
97
|
-
// const dy = y - point[1];
|
|
98
|
-
// const _isEnter = Math.sqrt(dx * dx + dy * dy) <= radius;
|
|
99
|
-
|
|
100
|
-
// if (_isEnter) {
|
|
101
|
-
// isEnter = _isEnter;
|
|
102
|
-
// canvas.style.cursor = 'pointer';
|
|
103
|
-
// return;
|
|
104
|
-
// }
|
|
105
|
-
// }
|
|
106
|
-
// }
|
|
107
|
-
// canvas.style.cursor = 'default';
|
|
108
|
-
// };
|
|
109
|
-
|
|
110
|
-
// const handleMouseDown = (e) => {
|
|
111
|
-
// if (!isEnter) return;
|
|
112
|
-
// isDown = true;
|
|
113
|
-
// const rect = canvas.getBoundingClientRect();
|
|
114
|
-
// const x = e.clientX - rect.left;
|
|
115
|
-
// const y = e.clientY - rect.top;
|
|
116
|
-
|
|
117
|
-
// for (const point of points) {
|
|
118
|
-
// const dx = x - point[0];
|
|
119
|
-
// const dy = y - point[1];
|
|
120
|
-
// const _isEnter = Math.sqrt(dx * dx + dy * dy) <= radius;
|
|
121
|
-
|
|
122
|
-
// if (_isEnter) {
|
|
123
|
-
// moveX = x;
|
|
124
|
-
// moveY = y;
|
|
125
|
-
// movePoint = point;
|
|
126
|
-
// break;
|
|
127
|
-
// }
|
|
128
|
-
// }
|
|
129
|
-
// };
|
|
130
|
-
// const handleMouseUp = (e) => {
|
|
131
|
-
// isDown = false;
|
|
132
|
-
// moveX = null;
|
|
133
|
-
// moveY = null;
|
|
134
|
-
// movePoint = null;
|
|
135
|
-
// };
|
|
136
|
-
|
|
137
|
-
// canvas.addEventListener('mousemove', handleMousemove);
|
|
138
|
-
// canvas.addEventListener('mousedown', handleMouseDown);
|
|
139
|
-
// canvas.addEventListener('mouseup', handleMouseUp);
|
|
140
|
-
|
|
141
|
-
// drawPol();
|
|
142
|
-
|
|
143
|
-
// return () => {
|
|
144
|
-
// canvas.removeEventListener('mousemove', handleMousemove);
|
|
145
|
-
// canvas.removeEventListener('mousedown', handleMouseDown);
|
|
146
|
-
// canvas.removeEventListener('mouseup', handleMouseUp);
|
|
147
|
-
// };
|
|
148
|
-
// }, []);
|
|
149
|
-
|
|
150
|
-
// return (
|
|
151
|
-
// <div className="w-[100vw] h-[100vh] flex items-center justify-center background-[#aaa] flex-col">
|
|
152
|
-
// <canvas
|
|
153
|
-
// width={canvasWidth}
|
|
154
|
-
// height={canvasHeight}
|
|
155
|
-
// ref={canvasRef}
|
|
156
|
-
// ></canvas>
|
|
157
|
-
// </div>
|
|
158
|
-
// );
|
|
159
|
-
// }
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { useEffect } from 'react';
|
|
2
|
-
import { useWindowSize } from 'react-use';
|
|
3
|
-
import ShapeEditor from './shape';
|
|
4
|
-
|
|
5
|
-
export default function Component() {
|
|
6
|
-
const { width, height } = useWindowSize();
|
|
7
|
-
const centerX = width / 2,
|
|
8
|
-
centerY = height / 2;
|
|
9
|
-
|
|
10
|
-
const initPoints = [
|
|
11
|
-
{ x: centerX - 40, y: centerY - 80 },
|
|
12
|
-
{ x: centerX + 80, y: centerY },
|
|
13
|
-
{ x: centerX + 80, y: centerY + 80 },
|
|
14
|
-
{ x: centerX - 40, y: centerY + 160 },
|
|
15
|
-
{ x: centerX + 200 - 160, y: centerY + 200 + 160 },
|
|
16
|
-
{ x: centerX + 200 - 200, y: centerY + 200 + 80 },
|
|
17
|
-
{ x: centerX + 200 - 200, y: centerY + 200 },
|
|
18
|
-
{ x: 500, y: 500 },
|
|
19
|
-
];
|
|
20
|
-
|
|
21
|
-
useEffect(() => {
|
|
22
|
-
const shapeEditor = new ShapeEditor({
|
|
23
|
-
points: initPoints.reduce((acc, point) => {
|
|
24
|
-
acc.push(point.x, point.y);
|
|
25
|
-
return acc;
|
|
26
|
-
}, []),
|
|
27
|
-
});
|
|
28
|
-
return () => {
|
|
29
|
-
shapeEditor.destroy();
|
|
30
|
-
};
|
|
31
|
-
}, []);
|
|
32
|
-
|
|
33
|
-
return (
|
|
34
|
-
<div className="w-[100vw] h-[100vh] flex items-center justify-center background-[#aaa] flex-col"></div>
|
|
35
|
-
);
|
|
36
|
-
}
|
|
@@ -1,248 +0,0 @@
|
|
|
1
|
-
import { App, Ellipse, Group, IGroupInputData, Pen, UI } from 'leafer-ui';
|
|
2
|
-
import Editor from './editor';
|
|
3
|
-
import Control, { IControl } from './control';
|
|
4
|
-
|
|
5
|
-
const circleRadius = 14;
|
|
6
|
-
|
|
7
|
-
interface IPoint {
|
|
8
|
-
x: number;
|
|
9
|
-
y: number;
|
|
10
|
-
controls: IControl[];
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export interface IConfig extends IGroupInputData {
|
|
14
|
-
points: IPoint[];
|
|
15
|
-
onMoveEnd?: (e) => void;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export default class ShapeEditor {
|
|
19
|
-
app: App;
|
|
20
|
-
editor: Editor;
|
|
21
|
-
|
|
22
|
-
selector: Ellipse;
|
|
23
|
-
private points: Ellipse[] = [];
|
|
24
|
-
|
|
25
|
-
private controls: [IControl, IControl][] = [
|
|
26
|
-
[
|
|
27
|
-
{ offsetX: -50, offsetY: 0 },
|
|
28
|
-
{ offsetX: 50, offsetY: 0 },
|
|
29
|
-
],
|
|
30
|
-
[
|
|
31
|
-
{
|
|
32
|
-
offsetX: -50,
|
|
33
|
-
offsetY: -50,
|
|
34
|
-
},
|
|
35
|
-
{
|
|
36
|
-
offsetX: 50,
|
|
37
|
-
offsetY: 50,
|
|
38
|
-
},
|
|
39
|
-
],
|
|
40
|
-
];
|
|
41
|
-
|
|
42
|
-
private pointsIdxMap: Map<number, number> = new Map();
|
|
43
|
-
|
|
44
|
-
config: IConfig = { points: [] };
|
|
45
|
-
private pen: Pen = new Pen({ fill: 'black' });
|
|
46
|
-
|
|
47
|
-
private selectBox: Ellipse = null;
|
|
48
|
-
|
|
49
|
-
private control: Control;
|
|
50
|
-
|
|
51
|
-
private container: Group;
|
|
52
|
-
|
|
53
|
-
constructor(config: IConfig) {
|
|
54
|
-
const { points, x, y } = config;
|
|
55
|
-
this.config = config;
|
|
56
|
-
this.app = new App({ view: window, tree: {} });
|
|
57
|
-
|
|
58
|
-
this.container = new Group({ x, y });
|
|
59
|
-
|
|
60
|
-
this.app.tree.add(this.container);
|
|
61
|
-
this.container.add(this.pen);
|
|
62
|
-
|
|
63
|
-
const { onMoveEnd = () => {} } = this.config;
|
|
64
|
-
|
|
65
|
-
this.editor = new Editor(this.app, {
|
|
66
|
-
onMove: (e) => {
|
|
67
|
-
const idx = this.pointsIdxMap.get(e.target.innerId);
|
|
68
|
-
if (idx !== undefined) {
|
|
69
|
-
this.selector = e.target;
|
|
70
|
-
this.drawSelectBox();
|
|
71
|
-
this.drawPolygon();
|
|
72
|
-
}
|
|
73
|
-
},
|
|
74
|
-
onTap: (e) => {
|
|
75
|
-
if (this.pointsIdxMap.get(e.target.innerId) !== undefined) {
|
|
76
|
-
this.selector = e.target;
|
|
77
|
-
this.drawSelectBox();
|
|
78
|
-
return;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
if (e.target === this.pen.pathElement) {
|
|
82
|
-
const { x, y } = e;
|
|
83
|
-
|
|
84
|
-
this.addPoint(x - circleRadius / 2, y - circleRadius / 2);
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
this.selector = null;
|
|
88
|
-
this.clearSelectBox();
|
|
89
|
-
},
|
|
90
|
-
onMoveEnd(e) {
|
|
91
|
-
onMoveEnd(e);
|
|
92
|
-
},
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
this.drawPoints(points);
|
|
96
|
-
|
|
97
|
-
this.control = new Control(this.app, {
|
|
98
|
-
points: this.points,
|
|
99
|
-
controls: this.controls,
|
|
100
|
-
onMove: () => {
|
|
101
|
-
this.drawPolygon();
|
|
102
|
-
},
|
|
103
|
-
onMoveEnd: (e) => {
|
|
104
|
-
console.log(e);
|
|
105
|
-
},
|
|
106
|
-
});
|
|
107
|
-
|
|
108
|
-
this.drawPolygon();
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
private addPoint(x, y) {
|
|
112
|
-
const arc = new Ellipse({
|
|
113
|
-
x,
|
|
114
|
-
y,
|
|
115
|
-
width: circleRadius,
|
|
116
|
-
height: circleRadius,
|
|
117
|
-
fill: 'rgb(50,205,121)',
|
|
118
|
-
cursor: 'move',
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
this.points.push(arc);
|
|
122
|
-
|
|
123
|
-
this.pointsIdxMap.set(arc.innerId, this.points.length - 1);
|
|
124
|
-
|
|
125
|
-
this.control?.update({ points: this.points });
|
|
126
|
-
|
|
127
|
-
this.addEls(arc);
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
private addEls(nodes: UI | UI[]) {
|
|
131
|
-
if (!Array.isArray(nodes)) {
|
|
132
|
-
nodes = [nodes];
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
this.container.addMany(...nodes);
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
private removeEls(nodes: UI | UI[]) {
|
|
139
|
-
if (!Array.isArray(nodes)) {
|
|
140
|
-
nodes = [nodes];
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
nodes.forEach((node) => {
|
|
144
|
-
this.container.remove(node);
|
|
145
|
-
});
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
private drawPoints(points) {
|
|
149
|
-
this.removeEls(this.points);
|
|
150
|
-
|
|
151
|
-
for (let i = 1; i < points.length; i += 2) {
|
|
152
|
-
const x = points[i - 1],
|
|
153
|
-
y = points[i];
|
|
154
|
-
this.addPoint(x, y);
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
this.drawPolygon();
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
private drawPolygon() {
|
|
161
|
-
this.pen.clear();
|
|
162
|
-
|
|
163
|
-
const points = this.points.map(({ x, y }) => {
|
|
164
|
-
return { x: x + circleRadius / 2, y: y + circleRadius / 2 };
|
|
165
|
-
});
|
|
166
|
-
|
|
167
|
-
this.pen.setStyle({ stroke: 'lime', fill: '#FF4B4B' });
|
|
168
|
-
|
|
169
|
-
this.pen.moveTo(points[0].x, points[0].y);
|
|
170
|
-
points.forEach((point, index) => {
|
|
171
|
-
const controls = this.controls[index];
|
|
172
|
-
|
|
173
|
-
let nextIdx = index + 1;
|
|
174
|
-
if (nextIdx >= points.length) nextIdx = 0;
|
|
175
|
-
|
|
176
|
-
const leftPoint = point,
|
|
177
|
-
rightPoint = points[nextIdx];
|
|
178
|
-
|
|
179
|
-
let controlLeft = null,
|
|
180
|
-
controlRight = null;
|
|
181
|
-
|
|
182
|
-
if (controls) {
|
|
183
|
-
controlLeft = controls[1];
|
|
184
|
-
}
|
|
185
|
-
const nextControls = this.controls[nextIdx];
|
|
186
|
-
|
|
187
|
-
if (nextControls) {
|
|
188
|
-
controlRight = nextControls[0];
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
if (!controlLeft && !controlRight) {
|
|
192
|
-
rightPoint.x > 500
|
|
193
|
-
? this.pen.moveTo(rightPoint.x, rightPoint.y)
|
|
194
|
-
: this.pen.lineTo(rightPoint.x, rightPoint.y);
|
|
195
|
-
} else if (controlLeft && !controlRight) {
|
|
196
|
-
this.pen.quadraticCurveTo(
|
|
197
|
-
controlLeft.offsetX + leftPoint.x,
|
|
198
|
-
controlLeft.offsetY + leftPoint.y,
|
|
199
|
-
rightPoint.x,
|
|
200
|
-
rightPoint.y
|
|
201
|
-
);
|
|
202
|
-
} else if (!controlLeft && controlRight) {
|
|
203
|
-
this.pen.quadraticCurveTo(
|
|
204
|
-
controlRight.offsetX + rightPoint.x,
|
|
205
|
-
controlRight.offsetY + rightPoint.y,
|
|
206
|
-
rightPoint.x,
|
|
207
|
-
rightPoint.y
|
|
208
|
-
);
|
|
209
|
-
} else {
|
|
210
|
-
this.pen.bezierCurveTo(
|
|
211
|
-
controlLeft.offsetX + leftPoint.x,
|
|
212
|
-
controlLeft.offsetY + leftPoint.y,
|
|
213
|
-
controlRight.offsetX + rightPoint.x,
|
|
214
|
-
controlRight.offsetY + rightPoint.y,
|
|
215
|
-
rightPoint.x,
|
|
216
|
-
rightPoint.y
|
|
217
|
-
);
|
|
218
|
-
}
|
|
219
|
-
});
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
private drawSelectBox() {
|
|
223
|
-
if (!this.selector) return;
|
|
224
|
-
|
|
225
|
-
if (this.selectBox) this.removeEls(this.selectBox);
|
|
226
|
-
|
|
227
|
-
const { x, y, width, height } = this.selector;
|
|
228
|
-
|
|
229
|
-
this.selectBox = new Ellipse({
|
|
230
|
-
x: x - 2,
|
|
231
|
-
y: y - 2,
|
|
232
|
-
width: width + 4,
|
|
233
|
-
height: height + 4,
|
|
234
|
-
stroke: '#FF4B4B',
|
|
235
|
-
strokeWidth: 1,
|
|
236
|
-
});
|
|
237
|
-
|
|
238
|
-
this.addEls(this.selectBox);
|
|
239
|
-
}
|
|
240
|
-
|
|
241
|
-
private clearSelectBox() {
|
|
242
|
-
if (this.selectBox) this.removeEls(this.selectBox);
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
destroy() {
|
|
246
|
-
this.app.destroy();
|
|
247
|
-
}
|
|
248
|
-
}
|