UNPKG

@leafer-in/resize

Version:
108 lines (80 loc) 4 kB
import { IBoundsType, ILeaf, IPointData } from '@leafer-ui/interface' import { Leaf, Path, Line, Text, Polygon, Group, Box, UI, MatrixHelper } from '@leafer-ui/draw' import { scaleResize, scaleResizeFontSize, scaleResizeGroup, scaleResizePath, scaleResizePoints } from './scaler' // leaf const leaf = Leaf.prototype as ILeaf, tempPoint = {} as IPointData, { scale, toOuterPoint } = MatrixHelper leaf.scaleResize = function (scaleX: number, scaleY = scaleX, noResize?: boolean, boundsType?: IBoundsType): void { const data = this as UI if (noResize || (data.editConfig && data.editConfig.editSize === 'scale')) { data.scaleX *= scaleX data.scaleY *= scaleY } else { const local = this.__localMatrix if (scaleX < 0) data.scaleX *= -1, scaleX = -scaleX, scale(local, -1, 1) if (scaleY < 0) data.scaleY *= -1, scaleY = -scaleY, scale(local, 1, -1) if (boundsType === 'stroke') { const { boxBounds, strokeBounds } = this.__layout, { x, y, width, height } = strokeBounds tempPoint.x = (x - boxBounds.x) * (scaleX - 1) tempPoint.y = (y - boxBounds.y) * (scaleY - 1) toOuterPoint(local, tempPoint, tempPoint, true) this.x += tempPoint.x this.y += tempPoint.y scaleX = (width * scaleX - (width - boxBounds.width)) / boxBounds.width scaleY = (height * scaleY - (height - boxBounds.height)) / boxBounds.height } this.__scaleResize(scaleX, scaleY) } } leaf.__scaleResize = function (scaleX: number, scaleY: number): void { scaleResize(this, scaleX, scaleY) } leaf.resizeWidth = function (width: number): void { const scale = width / this.getBounds('box', 'local').width || 1 // 不允许为0 this.scaleOf(this.__layout.boxBounds, scale, this.__.lockRatio ? scale : 1, true) } leaf.resizeHeight = function (height: number): void { const scale = height / this.getBounds('box', 'local').height || 1 // 不允许为0 this.scaleOf(this.__layout.boxBounds, this.__.lockRatio ? scale : 1, scale, true) } // UI Text.prototype.__scaleResize = function (scaleX: number, scaleY: number): void { const { app, editConfig } = this, editor = app && app.editor, dragPoint = editor && editor.dragPoint if (this.__.resizeFontSize || (editConfig && editConfig.editSize === 'font-size') || (dragPoint && editor.mergedConfig.editSize === 'font-size')) { scaleResizeFontSize(this, scaleX, scaleY, dragPoint && dragPoint.direction) } else { const { __autoWidth, __autoHeight, textAlign, verticalAlign } = this.__, { boxBounds } = this.__layout if (__autoWidth && textAlign !== 'left' && scaleX !== 1) this.x += boxBounds.x if (__autoHeight && verticalAlign !== 'top' && scaleY !== 1) this.y += boxBounds.y scaleResize(this, scaleX, scaleY) } } Path.prototype.__scaleResize = function (scaleX: number, scaleY: number): void { scaleResizePath(this, scaleX, scaleY) } Line.prototype.__scaleResize = function (scaleX: number, scaleY: number): void { if (this.pathInputed) { scaleResizePath(this, scaleX, scaleY) } else if (this.points) { scaleResizePoints(this, scaleX, scaleY) } else { this.width *= scaleX } } Polygon.prototype.__scaleResize = function (scaleX: number, scaleY: number): void { if (this.pathInputed) { scaleResizePath(this, scaleX, scaleY) } else if (this.points) { scaleResizePoints(this, scaleX, scaleY) } else { scaleResize(this, scaleX, scaleY) } } // group Group.prototype.__scaleResize = function (scaleX: number, scaleY: number): void { scaleResizeGroup(this, scaleX, scaleY) } Box.prototype.__scaleResize = function (scaleX: number, scaleY: number): void { const { resizeChildren, __autoSize } = this.__ if (!(__autoSize && resizeChildren)) scaleResize(this, scaleX, scaleY) if (resizeChildren) scaleResizeGroup(this, scaleX, scaleY) }