@plait/draw 0.75.0-next.9 → 0.75.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/engines/basic-shapes/cloud.d.ts +2 -12
- package/engines/uml/provided-interface.d.ts +0 -5
- package/esm2022/engines/basic-shapes/cloud.mjs +10 -11
- package/esm2022/engines/flowchart/note-curly-left.mjs +48 -12
- package/esm2022/engines/flowchart/note-curly-right.mjs +49 -10
- package/esm2022/engines/uml/actor.mjs +61 -44
- package/esm2022/engines/uml/assembly.mjs +72 -23
- package/esm2022/engines/uml/component.mjs +78 -33
- package/esm2022/engines/uml/deletion.mjs +28 -6
- package/esm2022/engines/uml/package.mjs +51 -21
- package/esm2022/engines/uml/provided-interface.mjs +53 -26
- package/esm2022/engines/uml/required-interface.mjs +51 -7
- package/esm2022/plugins/with-arrow-line-text-move.mjs +2 -2
- package/esm2022/plugins/with-table.mjs +3 -2
- package/esm2022/utils/hit.mjs +5 -5
- package/fesm2022/plait-draw.mjs +489 -178
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1,24 +1,70 @@
|
|
|
1
|
-
import { PlaitBoard, RectangleClient, getEllipseTangentSlope,
|
|
2
|
-
import { RectangleEngine } from '../basic-shapes/rectangle';
|
|
1
|
+
import { PlaitBoard, RectangleClient, distanceBetweenPointAndPoint, getEllipseTangentSlope, getNearestPointBetweenPointAndDiscreteSegments, getNearestPointBetweenPointAndEllipse, getVectorFromPointAndSlope, setStrokeLinecap } from '@plait/core';
|
|
3
2
|
import { getUnitVectorByPointAndPoint, rotateVector } from '@plait/common';
|
|
3
|
+
function generateActorPath(rectangle) {
|
|
4
|
+
const centerX = rectangle.x + rectangle.width / 2;
|
|
5
|
+
const headRadius = { width: rectangle.width / 3 / 2, height: rectangle.height / 4 / 2 };
|
|
6
|
+
const centerY = rectangle.y + rectangle.height / 4 / 2;
|
|
7
|
+
return {
|
|
8
|
+
headArcCommand: {
|
|
9
|
+
rx: headRadius.width,
|
|
10
|
+
ry: headRadius.height,
|
|
11
|
+
xAxisRotation: 0,
|
|
12
|
+
largeArcFlag: 0,
|
|
13
|
+
sweepFlag: 1,
|
|
14
|
+
endX: centerX,
|
|
15
|
+
endY: rectangle.y
|
|
16
|
+
},
|
|
17
|
+
bodyLine: [
|
|
18
|
+
[centerX, rectangle.y + rectangle.height / 4],
|
|
19
|
+
[centerX, rectangle.y + (rectangle.height / 4) * 3]
|
|
20
|
+
],
|
|
21
|
+
armsLine: [
|
|
22
|
+
[rectangle.x, rectangle.y + rectangle.height / 2],
|
|
23
|
+
[rectangle.x + rectangle.width, rectangle.y + rectangle.height / 2]
|
|
24
|
+
],
|
|
25
|
+
leftLegLine: [
|
|
26
|
+
[centerX, rectangle.y + (rectangle.height / 4) * 3],
|
|
27
|
+
[rectangle.x + rectangle.width / 12, rectangle.y + rectangle.height]
|
|
28
|
+
],
|
|
29
|
+
rightLegLine: [
|
|
30
|
+
[centerX, rectangle.y + (rectangle.height / 4) * 3],
|
|
31
|
+
[rectangle.x + (rectangle.width / 12) * 11, rectangle.y + rectangle.height]
|
|
32
|
+
]
|
|
33
|
+
};
|
|
34
|
+
}
|
|
4
35
|
export const ActorEngine = {
|
|
5
36
|
draw(board, rectangle, options) {
|
|
6
37
|
const rs = PlaitBoard.getRoughSVG(board);
|
|
7
|
-
const
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
M${
|
|
17
|
-
|
|
18
|
-
|
|
38
|
+
const { headArcCommand, bodyLine, armsLine, leftLegLine, rightLegLine } = generateActorPath(rectangle);
|
|
39
|
+
const pathData = [
|
|
40
|
+
// 头部(从中间开始画)
|
|
41
|
+
`M${bodyLine[0][0]} ${bodyLine[0][1]}`,
|
|
42
|
+
`A${headArcCommand.rx} ${headArcCommand.ry} ${headArcCommand.xAxisRotation} ${headArcCommand.largeArcFlag} ${headArcCommand.sweepFlag} ${headArcCommand.endX} ${headArcCommand.endY}`,
|
|
43
|
+
`A${headArcCommand.rx} ${headArcCommand.ry} ${headArcCommand.xAxisRotation} ${headArcCommand.largeArcFlag} ${headArcCommand.sweepFlag} ${bodyLine[0][0]} ${bodyLine[0][1]}`,
|
|
44
|
+
// 身体
|
|
45
|
+
`V${bodyLine[1][1]}`,
|
|
46
|
+
// 手臂
|
|
47
|
+
`M${armsLine[0][0]} ${armsLine[0][1]} H${armsLine[1][0]}`,
|
|
48
|
+
// 腿
|
|
49
|
+
`M${leftLegLine[0][0]} ${leftLegLine[0][1]} L${leftLegLine[1][0]} ${leftLegLine[1][1]}`,
|
|
50
|
+
`M${rightLegLine[0][0]} ${rightLegLine[0][1]} L${rightLegLine[1][0]} ${rightLegLine[1][1]}`
|
|
51
|
+
].join(' ');
|
|
52
|
+
const shape = rs.path(pathData, { ...options, fillStyle: 'solid' });
|
|
19
53
|
setStrokeLinecap(shape, 'round');
|
|
20
54
|
return shape;
|
|
21
55
|
},
|
|
56
|
+
getNearestPoint(rectangle, point) {
|
|
57
|
+
const { headArcCommand, bodyLine, armsLine, leftLegLine, rightLegLine } = generateActorPath(rectangle);
|
|
58
|
+
// 检查头部椭圆
|
|
59
|
+
const headCenter = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 4 / 2];
|
|
60
|
+
const nearestPointForHead = getNearestPointBetweenPointAndEllipse(point, headCenter, headArcCommand.rx, headArcCommand.ry);
|
|
61
|
+
const distanceForHead = distanceBetweenPointAndPoint(...point, ...nearestPointForHead);
|
|
62
|
+
// 检查所有线段
|
|
63
|
+
const allSegments = [bodyLine, armsLine, leftLegLine, rightLegLine];
|
|
64
|
+
const nearestPointForLines = getNearestPointBetweenPointAndDiscreteSegments(point, allSegments);
|
|
65
|
+
const distanceForLines = distanceBetweenPointAndPoint(...point, ...nearestPointForLines);
|
|
66
|
+
return distanceForHead < distanceForLines ? nearestPointForHead : nearestPointForLines;
|
|
67
|
+
},
|
|
22
68
|
isInsidePoint(rectangle, point) {
|
|
23
69
|
const rangeRectangle = RectangleClient.getRectangleByPoints([point, point]);
|
|
24
70
|
return RectangleClient.isHit(rectangle, rangeRectangle);
|
|
@@ -26,35 +72,6 @@ export const ActorEngine = {
|
|
|
26
72
|
getCornerPoints(rectangle) {
|
|
27
73
|
return RectangleClient.getCornerPoints(rectangle);
|
|
28
74
|
},
|
|
29
|
-
getNearestPoint(rectangle, point) {
|
|
30
|
-
let nearestPoint = getNearestPointBetweenPointAndSegments(point, RectangleEngine.getCornerPoints(rectangle));
|
|
31
|
-
if (nearestPoint[1] >= rectangle.y && nearestPoint[1] <= rectangle.y + rectangle.height / 4) {
|
|
32
|
-
const centerPoint = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 4 / 2];
|
|
33
|
-
nearestPoint = getNearestPointBetweenPointAndEllipse(point, centerPoint, rectangle.width / 3 / 2, rectangle.height / 4 / 2);
|
|
34
|
-
return nearestPoint;
|
|
35
|
-
}
|
|
36
|
-
if (nearestPoint[1] >= rectangle.y + rectangle.height / 4 && nearestPoint[1] < rectangle.y + (rectangle.height / 4) * 3) {
|
|
37
|
-
if (nearestPoint[1] === rectangle.x + rectangle.width / 2) {
|
|
38
|
-
nearestPoint = getNearestPointBetweenPointAndSegments(point, [
|
|
39
|
-
[rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 4],
|
|
40
|
-
[rectangle.x + rectangle.width / 2, rectangle.y + (rectangle.height / 4) * 3]
|
|
41
|
-
]);
|
|
42
|
-
}
|
|
43
|
-
else {
|
|
44
|
-
nearestPoint = getNearestPointBetweenPointAndSegments(point, [
|
|
45
|
-
[rectangle.x, rectangle.y + rectangle.height / 2],
|
|
46
|
-
[rectangle.x + rectangle.width, rectangle.y + rectangle.height / 2]
|
|
47
|
-
]);
|
|
48
|
-
}
|
|
49
|
-
return nearestPoint;
|
|
50
|
-
}
|
|
51
|
-
nearestPoint = getNearestPointBetweenPointAndSegments(point, [
|
|
52
|
-
[rectangle.x + rectangle.width / 12, rectangle.y + rectangle.height],
|
|
53
|
-
[rectangle.x + rectangle.width / 2, rectangle.y + (rectangle.height / 4) * 3],
|
|
54
|
-
[rectangle.x + (rectangle.width / 12) * 11, rectangle.y + rectangle.height]
|
|
55
|
-
]);
|
|
56
|
-
return nearestPoint;
|
|
57
|
-
},
|
|
58
75
|
getConnectorPoints(rectangle) {
|
|
59
76
|
return RectangleClient.getEdgeCenterPoints(rectangle);
|
|
60
77
|
},
|
|
@@ -99,4 +116,4 @@ export const ActorEngine = {
|
|
|
99
116
|
};
|
|
100
117
|
}
|
|
101
118
|
};
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actor.js","sourceRoot":"","sources":["../../../../../packages/draw/src/engines/uml/actor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    Point,\n    PointOfRectangle,\n    RectangleClient,\n    W,\n    getEllipseTangentSlope,\n    getNearestPointBetweenPointAndEllipse,\n    getNearestPointBetweenPointAndSegments,\n    getVectorFromPointAndSlope,\n    setStrokeLinecap\n} from '@plait/core';\nimport { PlaitGeometry, ShapeEngine } from '../../interfaces';\nimport { Options } from 'roughjs/bin/core';\nimport { getPolygonEdgeByConnectionPoint } from '../../utils/polygon';\nimport { RectangleEngine } from '../basic-shapes/rectangle';\nimport { getUnitVectorByPointAndPoint, rotateVector } from '@plait/common';\n\nexport const ActorEngine: ShapeEngine = {\n    draw(board: PlaitBoard, rectangle: RectangleClient, options: Options) {\n        const rs = PlaitBoard.getRoughSVG(board);\n        const shape = rs.path(\n            `M${rectangle.x + rectangle.width / 2} ${rectangle.y + rectangle.height / 4}  \n            A${rectangle.width / 3 / 2} ${rectangle.height / 4 / 2}, 0, 0, 1, ${rectangle.x + rectangle.width / 2} ${rectangle.y} \n            A${rectangle.width / 3 / 2} ${rectangle.height / 4 / 2}, 0, 0, 1, ${rectangle.x + rectangle.width / 2} ${rectangle.y +\n                rectangle.height / 4}\n            V${rectangle.y + (rectangle.height / 4) * 3}\n            M${rectangle.x + rectangle.width / 2} ${rectangle.y + rectangle.height / 2} H${rectangle.x}\n            M${rectangle.x + rectangle.width / 2} ${rectangle.y + rectangle.height / 2} H${rectangle.x + rectangle.width}\n            M${rectangle.x + rectangle.width / 2} ${rectangle.y + (rectangle.height / 4) * 3}\n            L${rectangle.x + rectangle.width / 12} ${rectangle.y + rectangle.height}\n            M${rectangle.x + rectangle.width / 2} ${rectangle.y + (rectangle.height / 4) * 3}\n            L${rectangle.x + (rectangle.width / 12) * 11} ${rectangle.y + rectangle.height}\n            `,\n            { ...options, fillStyle: 'solid' }\n        );\n        setStrokeLinecap(shape, 'round');\n        return shape;\n    },\n    isInsidePoint(rectangle: RectangleClient, point: Point) {\n        const rangeRectangle = RectangleClient.getRectangleByPoints([point, point]);\n        return RectangleClient.isHit(rectangle, rangeRectangle);\n    },\n    getCornerPoints(rectangle: RectangleClient) {\n        return RectangleClient.getCornerPoints(rectangle);\n    },\n    getNearestPoint(rectangle: RectangleClient, point: Point) {\n        let nearestPoint = getNearestPointBetweenPointAndSegments(point, RectangleEngine.getCornerPoints(rectangle));\n\n        if (nearestPoint[1] >= rectangle.y && nearestPoint[1] <= rectangle.y + rectangle.height / 4) {\n            const centerPoint: Point = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 4 / 2];\n            nearestPoint = getNearestPointBetweenPointAndEllipse(point, centerPoint, rectangle.width / 3 / 2, rectangle.height / 4 / 2);\n            return nearestPoint;\n        }\n        if (nearestPoint[1] >= rectangle.y + rectangle.height / 4 && nearestPoint[1] < rectangle.y + (rectangle.height / 4) * 3) {\n            if (nearestPoint[1] === rectangle.x + rectangle.width / 2) {\n                nearestPoint = getNearestPointBetweenPointAndSegments(point, [\n                    [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 4],\n                    [rectangle.x + rectangle.width / 2, rectangle.y + (rectangle.height / 4) * 3]\n                ]);\n            } else {\n                nearestPoint = getNearestPointBetweenPointAndSegments(point, [\n                    [rectangle.x, rectangle.y + rectangle.height / 2],\n                    [rectangle.x + rectangle.width, rectangle.y + rectangle.height / 2]\n                ]);\n            }\n            return nearestPoint;\n        }\n        nearestPoint = getNearestPointBetweenPointAndSegments(point, [\n            [rectangle.x + rectangle.width / 12, rectangle.y + rectangle.height],\n            [rectangle.x + rectangle.width / 2, rectangle.y + (rectangle.height / 4) * 3],\n            [rectangle.x + (rectangle.width / 12) * 11, rectangle.y + rectangle.height]\n        ]);\n        return nearestPoint;\n    },\n    getConnectorPoints(rectangle: RectangleClient) {\n        return RectangleClient.getEdgeCenterPoints(rectangle);\n    },\n\n    getTangentVectorByConnectionPoint(rectangle: RectangleClient, pointOfRectangle: PointOfRectangle) {\n        const connectionPoint = RectangleClient.getConnectionPoint(rectangle, pointOfRectangle);\n        if (connectionPoint[1] >= rectangle.y && connectionPoint[1] <= rectangle.y + rectangle.height / 4) {\n            const centerPoint: Point = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 4 / 2];\n            const point = [connectionPoint[0] - centerPoint[0], -(connectionPoint[1] - centerPoint[1])];\n            const a = rectangle.width / 2;\n            const b = rectangle.height / 2;\n            const slope = getEllipseTangentSlope(point[0], point[1], a, b) as any;\n            const vector = getVectorFromPointAndSlope(point[0], point[1], slope);\n            return vector;\n        }\n\n        if (connectionPoint[1] >= rectangle.y + rectangle.height / 4 && connectionPoint[1] < rectangle.y + (rectangle.height / 4) * 3) {\n            if (connectionPoint[0] < rectangle.x + rectangle.width / 2) {\n                return rotateVector(\n                    getUnitVectorByPointAndPoint([rectangle.x, rectangle.y + rectangle.height / 2], connectionPoint),\n                    -(Math.PI / 2)\n                );\n            } else {\n                return rotateVector(\n                    getUnitVectorByPointAndPoint([rectangle.x + rectangle.width, rectangle.y + rectangle.height / 2], connectionPoint),\n                    -(Math.PI / 2)\n                );\n            }\n        }\n\n        if (connectionPoint[1] >= rectangle.y + (rectangle.height / 4) * 3) {\n            if (connectionPoint[0] < rectangle.x + rectangle.width / 2) {\n                return getUnitVectorByPointAndPoint(connectionPoint, [rectangle.x + rectangle.width / 12, rectangle.y + rectangle.height]);\n            } else {\n                return getUnitVectorByPointAndPoint(\n                    [rectangle.x + (rectangle.width / 12) * 11, rectangle.y + rectangle.height],\n                    connectionPoint\n                );\n            }\n        }\n\n        return getUnitVectorByPointAndPoint(connectionPoint, [rectangle.x + rectangle.width / 4, rectangle.y + rectangle.height]);\n    },\n    getTextRectangle: (element: PlaitGeometry) => {\n        const elementRectangle = RectangleClient.getRectangleByPoints(element.points!);\n        const height = element.textHeight!;\n        const width = elementRectangle.width + 40;\n        return {\n            height,\n            width: width > 0 ? width : 0,\n            x: elementRectangle.x - 20,\n            y: elementRectangle.y + elementRectangle.height + 4\n        };\n    }\n};\n"]}
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actor.js","sourceRoot":"","sources":["../../../../../packages/draw/src/engines/uml/actor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    Point,\n    PointOfRectangle,\n    RectangleClient,\n    SVGArcCommand,\n    W,\n    distanceBetweenPointAndPoint,\n    getEllipseTangentSlope,\n    getNearestPointBetweenPointAndDiscreteSegments,\n    getNearestPointBetweenPointAndEllipse,\n    getNearestPointBetweenPointAndSegment,\n    getNearestPointBetweenPointAndSegments,\n    getVectorFromPointAndSlope,\n    setStrokeLinecap\n} from '@plait/core';\nimport { PlaitGeometry, ShapeEngine } from '../../interfaces';\nimport { Options } from 'roughjs/bin/core';\nimport { getPolygonEdgeByConnectionPoint } from '../../utils/polygon';\nimport { RectangleEngine } from '../basic-shapes/rectangle';\nimport { getUnitVectorByPointAndPoint, rotateVector } from '@plait/common';\n\ninterface ActorPathData {\n    headArcCommand: SVGArcCommand;\n    bodyLine: [Point, Point];\n    armsLine: [Point, Point];\n    leftLegLine: [Point, Point];\n    rightLegLine: [Point, Point];\n}\n\nfunction generateActorPath(rectangle: RectangleClient): ActorPathData {\n    const centerX = rectangle.x + rectangle.width / 2;\n    const headRadius = { width: rectangle.width / 3 / 2, height: rectangle.height / 4 / 2 };\n    const centerY = rectangle.y + rectangle.height / 4 / 2;\n\n    return {\n        headArcCommand: {\n            rx: headRadius.width,\n            ry: headRadius.height,\n            xAxisRotation: 0,\n            largeArcFlag: 0,\n            sweepFlag: 1,\n            endX: centerX,\n            endY: rectangle.y\n        },\n        bodyLine: [\n            [centerX, rectangle.y + rectangle.height / 4],\n            [centerX, rectangle.y + (rectangle.height / 4) * 3]\n        ],\n        armsLine: [\n            [rectangle.x, rectangle.y + rectangle.height / 2],\n            [rectangle.x + rectangle.width, rectangle.y + rectangle.height / 2]\n        ],\n        leftLegLine: [\n            [centerX, rectangle.y + (rectangle.height / 4) * 3],\n            [rectangle.x + rectangle.width / 12, rectangle.y + rectangle.height]\n        ],\n        rightLegLine: [\n            [centerX, rectangle.y + (rectangle.height / 4) * 3],\n            [rectangle.x + (rectangle.width / 12) * 11, rectangle.y + rectangle.height]\n        ]\n    };\n}\n\nexport const ActorEngine: ShapeEngine = {\n    draw(board: PlaitBoard, rectangle: RectangleClient, options: Options) {\n        const rs = PlaitBoard.getRoughSVG(board);\n        const { headArcCommand, bodyLine, armsLine, leftLegLine, rightLegLine } = generateActorPath(rectangle);\n\n        const pathData = [\n            // 头部（从中间开始画）\n            `M${bodyLine[0][0]} ${bodyLine[0][1]}`,\n            `A${headArcCommand.rx} ${headArcCommand.ry} ${headArcCommand.xAxisRotation} ${headArcCommand.largeArcFlag} ${headArcCommand.sweepFlag} ${headArcCommand.endX} ${headArcCommand.endY}`,\n            `A${headArcCommand.rx} ${headArcCommand.ry} ${headArcCommand.xAxisRotation} ${headArcCommand.largeArcFlag} ${headArcCommand.sweepFlag} ${bodyLine[0][0]} ${bodyLine[0][1]}`,\n            // 身体\n            `V${bodyLine[1][1]}`,\n            // 手臂\n            `M${armsLine[0][0]} ${armsLine[0][1]} H${armsLine[1][0]}`,\n            // 腿\n            `M${leftLegLine[0][0]} ${leftLegLine[0][1]} L${leftLegLine[1][0]} ${leftLegLine[1][1]}`,\n            `M${rightLegLine[0][0]} ${rightLegLine[0][1]} L${rightLegLine[1][0]} ${rightLegLine[1][1]}`\n        ].join(' ');\n\n        const shape = rs.path(pathData, { ...options, fillStyle: 'solid' });\n        setStrokeLinecap(shape, 'round');\n        return shape;\n    },\n\n    getNearestPoint(rectangle: RectangleClient, point: Point) {\n        const { headArcCommand, bodyLine, armsLine, leftLegLine, rightLegLine } = generateActorPath(rectangle);\n\n        // 检查头部椭圆\n        const headCenter: Point = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 4 / 2];\n        const nearestPointForHead = getNearestPointBetweenPointAndEllipse(point, headCenter, headArcCommand.rx, headArcCommand.ry);\n        const distanceForHead = distanceBetweenPointAndPoint(...point, ...nearestPointForHead);\n\n        // 检查所有线段\n        const allSegments = [bodyLine, armsLine, leftLegLine, rightLegLine];\n        const nearestPointForLines = getNearestPointBetweenPointAndDiscreteSegments(point, allSegments);\n        const distanceForLines = distanceBetweenPointAndPoint(...point, ...nearestPointForLines);\n\n        return distanceForHead < distanceForLines ? nearestPointForHead : nearestPointForLines;\n    },\n    isInsidePoint(rectangle: RectangleClient, point: Point) {\n        const rangeRectangle = RectangleClient.getRectangleByPoints([point, point]);\n        return RectangleClient.isHit(rectangle, rangeRectangle);\n    },\n    getCornerPoints(rectangle: RectangleClient) {\n        return RectangleClient.getCornerPoints(rectangle);\n    },\n    getConnectorPoints(rectangle: RectangleClient) {\n        return RectangleClient.getEdgeCenterPoints(rectangle);\n    },\n    getTangentVectorByConnectionPoint(rectangle: RectangleClient, pointOfRectangle: PointOfRectangle) {\n        const connectionPoint = RectangleClient.getConnectionPoint(rectangle, pointOfRectangle);\n        if (connectionPoint[1] >= rectangle.y && connectionPoint[1] <= rectangle.y + rectangle.height / 4) {\n            const centerPoint: Point = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 4 / 2];\n            const point = [connectionPoint[0] - centerPoint[0], -(connectionPoint[1] - centerPoint[1])];\n            const a = rectangle.width / 2;\n            const b = rectangle.height / 2;\n            const slope = getEllipseTangentSlope(point[0], point[1], a, b) as any;\n            const vector = getVectorFromPointAndSlope(point[0], point[1], slope);\n            return vector;\n        }\n\n        if (connectionPoint[1] >= rectangle.y + rectangle.height / 4 && connectionPoint[1] < rectangle.y + (rectangle.height / 4) * 3) {\n            if (connectionPoint[0] < rectangle.x + rectangle.width / 2) {\n                return rotateVector(\n                    getUnitVectorByPointAndPoint([rectangle.x, rectangle.y + rectangle.height / 2], connectionPoint),\n                    -(Math.PI / 2)\n                );\n            } else {\n                return rotateVector(\n                    getUnitVectorByPointAndPoint([rectangle.x + rectangle.width, rectangle.y + rectangle.height / 2], connectionPoint),\n                    -(Math.PI / 2)\n                );\n            }\n        }\n\n        if (connectionPoint[1] >= rectangle.y + (rectangle.height / 4) * 3) {\n            if (connectionPoint[0] < rectangle.x + rectangle.width / 2) {\n                return getUnitVectorByPointAndPoint(connectionPoint, [rectangle.x + rectangle.width / 12, rectangle.y + rectangle.height]);\n            } else {\n                return getUnitVectorByPointAndPoint(\n                    [rectangle.x + (rectangle.width / 12) * 11, rectangle.y + rectangle.height],\n                    connectionPoint\n                );\n            }\n        }\n\n        return getUnitVectorByPointAndPoint(connectionPoint, [rectangle.x + rectangle.width / 4, rectangle.y + rectangle.height]);\n    },\n    getTextRectangle: (element: PlaitGeometry) => {\n        const elementRectangle = RectangleClient.getRectangleByPoints(element.points!);\n        const height = element.textHeight!;\n        const width = elementRectangle.width + 40;\n        return {\n            height,\n            width: width > 0 ? width : 0,\n            x: elementRectangle.x - 20,\n            y: elementRectangle.y + elementRectangle.height + 4\n        };\n    }\n};\n"]}
|
|
@@ -1,24 +1,59 @@
|
|
|
1
|
-
import { PlaitBoard, RectangleClient, getNearestPointBetweenPointAndEllipse, getNearestPointBetweenPointAndSegments, setStrokeLinecap } from '@plait/core';
|
|
2
|
-
import { RectangleEngine } from '../basic-shapes/rectangle';
|
|
1
|
+
import { PlaitBoard, RectangleClient, distanceBetweenPointAndPoint, getNearestPointBetweenPointAndArc, getNearestPointBetweenPointAndEllipse, getNearestPointBetweenPointAndSegments, setStrokeLinecap } from '@plait/core';
|
|
3
2
|
import { getUnitVectorByPointAndPoint, rotateVector } from '@plait/common';
|
|
3
|
+
function generateAssemblyPath(rectangle) {
|
|
4
|
+
const centerY = rectangle.y + rectangle.height / 2;
|
|
5
|
+
const firstLineEndX = rectangle.x + rectangle.width * 0.3;
|
|
6
|
+
const circleWidth = rectangle.width * 0.13;
|
|
7
|
+
const circleHeight = rectangle.height * 0.285;
|
|
8
|
+
const verticalX = firstLineEndX + circleWidth;
|
|
9
|
+
const verticalRadius = rectangle.width * 0.233;
|
|
10
|
+
return {
|
|
11
|
+
startPoint: [rectangle.x, centerY],
|
|
12
|
+
line1: [
|
|
13
|
+
[rectangle.x, centerY],
|
|
14
|
+
[firstLineEndX, centerY]
|
|
15
|
+
],
|
|
16
|
+
circleArcCommand: {
|
|
17
|
+
rx: circleWidth,
|
|
18
|
+
ry: circleHeight,
|
|
19
|
+
xAxisRotation: 0,
|
|
20
|
+
largeArcFlag: 1,
|
|
21
|
+
sweepFlag: 1,
|
|
22
|
+
endX: firstLineEndX,
|
|
23
|
+
endY: centerY
|
|
24
|
+
},
|
|
25
|
+
verticalArcCommand: {
|
|
26
|
+
rx: verticalRadius,
|
|
27
|
+
ry: rectangle.height / 2,
|
|
28
|
+
xAxisRotation: 0,
|
|
29
|
+
largeArcFlag: 0,
|
|
30
|
+
sweepFlag: 1,
|
|
31
|
+
endX: verticalX,
|
|
32
|
+
endY: rectangle.y + rectangle.height
|
|
33
|
+
},
|
|
34
|
+
line2: [
|
|
35
|
+
[verticalX + verticalRadius, centerY],
|
|
36
|
+
[rectangle.x + rectangle.width, centerY]
|
|
37
|
+
]
|
|
38
|
+
};
|
|
39
|
+
}
|
|
4
40
|
export const AssemblyEngine = {
|
|
5
41
|
draw(board, rectangle, options) {
|
|
6
42
|
const rs = PlaitBoard.getRoughSVG(board);
|
|
7
|
-
const
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
`, {
|
|
43
|
+
const { startPoint, line1, circleArcCommand, verticalArcCommand, line2 } = generateAssemblyPath(rectangle);
|
|
44
|
+
const pathData = [
|
|
45
|
+
`M${startPoint[0]} ${startPoint[1]}`,
|
|
46
|
+
`H${line1[1][0]}`,
|
|
47
|
+
// 画完整的圆形:先画一个半圆,再画另一个半圆
|
|
48
|
+
`A${circleArcCommand.rx} ${circleArcCommand.ry} ${circleArcCommand.xAxisRotation} ${circleArcCommand.largeArcFlag} ${circleArcCommand.sweepFlag} ${line1[1][0] + circleArcCommand.rx * 2} ${circleArcCommand.endY}`,
|
|
49
|
+
`A${circleArcCommand.rx} ${circleArcCommand.ry} ${circleArcCommand.xAxisRotation} ${circleArcCommand.largeArcFlag} ${circleArcCommand.sweepFlag} ${circleArcCommand.endX} ${circleArcCommand.endY}`,
|
|
50
|
+
// 垂直椭圆
|
|
51
|
+
`M${verticalArcCommand.endX} ${rectangle.y}`,
|
|
52
|
+
`A${verticalArcCommand.rx} ${verticalArcCommand.ry} ${verticalArcCommand.xAxisRotation} ${verticalArcCommand.largeArcFlag} ${verticalArcCommand.sweepFlag} ${verticalArcCommand.endX} ${verticalArcCommand.endY}`,
|
|
53
|
+
// 最后一条线
|
|
54
|
+
`M${line2[0][0]} ${line2[0][1]} H${line2[1][0]}`
|
|
55
|
+
].join(' ');
|
|
56
|
+
const shape = rs.path(pathData, {
|
|
22
57
|
...options,
|
|
23
58
|
fillStyle: 'solid'
|
|
24
59
|
});
|
|
@@ -36,11 +71,25 @@ export const AssemblyEngine = {
|
|
|
36
71
|
return RectangleClient.getEdgeCenterPoints(rectangle);
|
|
37
72
|
},
|
|
38
73
|
getNearestPoint(rectangle, point) {
|
|
39
|
-
const
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
74
|
+
const { line1, line2, circleArcCommand, verticalArcCommand } = generateAssemblyPath(rectangle);
|
|
75
|
+
// 检查直线段
|
|
76
|
+
const nearestPointForLines = getNearestPointBetweenPointAndSegments(point, [...line1, ...line2]);
|
|
77
|
+
const distanceForLines = distanceBetweenPointAndPoint(...point, ...nearestPointForLines);
|
|
78
|
+
// 检查中间圆形
|
|
79
|
+
const circleCenter = [line1[1][0] + circleArcCommand.rx, line1[1][1]];
|
|
80
|
+
const nearestPointForCircle = getNearestPointBetweenPointAndEllipse(point, circleCenter, circleArcCommand.rx, circleArcCommand.ry);
|
|
81
|
+
const distanceForCircle = distanceBetweenPointAndPoint(...point, ...nearestPointForCircle);
|
|
82
|
+
// 检查垂直椭圆(使用 getNearestPointBetweenPointAndArc 处理半圆弧)
|
|
83
|
+
const arcStartPoint = [verticalArcCommand.endX, rectangle.y];
|
|
84
|
+
const nearestPointForEllipse = getNearestPointBetweenPointAndArc(point, arcStartPoint, verticalArcCommand);
|
|
85
|
+
const distanceForEllipse = distanceBetweenPointAndPoint(...point, ...nearestPointForEllipse);
|
|
86
|
+
// 返回最近的点
|
|
87
|
+
const minDistance = Math.min(distanceForLines, distanceForCircle, distanceForEllipse);
|
|
88
|
+
if (minDistance === distanceForLines)
|
|
89
|
+
return nearestPointForLines;
|
|
90
|
+
if (minDistance === distanceForCircle)
|
|
91
|
+
return nearestPointForCircle;
|
|
92
|
+
return nearestPointForEllipse;
|
|
44
93
|
},
|
|
45
94
|
getTangentVectorByConnectionPoint(rectangle, pointOfRectangle) {
|
|
46
95
|
const connectionPoint = RectangleClient.getConnectionPoint(rectangle, pointOfRectangle);
|
|
@@ -53,4 +102,4 @@ export const AssemblyEngine = {
|
|
|
53
102
|
return getUnitVectorByPointAndPoint(connectionPoint, [rectangle.x, rectangle.y + rectangle.height / 2]);
|
|
54
103
|
}
|
|
55
104
|
};
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assembly.js","sourceRoot":"","sources":["../../../../../packages/draw/src/engines/uml/assembly.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    Point,\n    PointOfRectangle,\n    RectangleClient,\n    getNearestPointBetweenPointAndEllipse,\n    getNearestPointBetweenPointAndSegments,\n    setStrokeLinecap\n} from '@plait/core';\nimport { ShapeEngine } from '../../interfaces';\nimport { Options } from 'roughjs/bin/core';\nimport { RectangleEngine } from '../basic-shapes/rectangle';\nimport { getUnitVectorByPointAndPoint, rotateVector } from '@plait/common';\n\nexport const AssemblyEngine: ShapeEngine = {\n    draw(board: PlaitBoard, rectangle: RectangleClient, options: Options) {\n        const rs = PlaitBoard.getRoughSVG(board);\n        const shape = rs.path(\n            `\n        M${rectangle.x} ${rectangle.y + rectangle.height / 2} \n        H${rectangle.x + rectangle.width * 0.3}\n        A${rectangle.width * 0.13} ${rectangle.height * 0.285}, 0, 1, 1 ${rectangle.x +\n                rectangle.width * 0.3 +\n                rectangle.width * 0.26} ${rectangle.y + rectangle.height / 2}\n        A${rectangle.width * 0.13} ${rectangle.height * 0.285}, 0, 1, 1 ${rectangle.x + rectangle.width * 0.3} ${rectangle.y +\n                rectangle.height / 2}\n        M${rectangle.x + rectangle.width * 0.3 + rectangle.width * 0.13} ${rectangle.y}\n        A${rectangle.width * 0.233} ${rectangle.height / 2}, 0, 0, 1 ${rectangle.x +\n                rectangle.width * 0.3 +\n                rectangle.width * 0.13} ${rectangle.y + rectangle.height}\n        M${rectangle.x + rectangle.width * 0.3 + rectangle.width * 0.13 + rectangle.width * 0.233} ${rectangle.y +\n                rectangle.height / 2} H${rectangle.x + rectangle.width}\n        `,\n            {\n                ...options,\n                fillStyle: 'solid'\n            }\n        );\n        setStrokeLinecap(shape, 'round');\n\n        return shape;\n    },\n    isInsidePoint(rectangle: RectangleClient, point: Point) {\n        const rangeRectangle = RectangleClient.getRectangleByPoints([point, point]);\n        return RectangleClient.isHit(rectangle, rangeRectangle);\n    },\n    getCornerPoints(rectangle: RectangleClient) {\n        return RectangleClient.getCornerPoints(rectangle);\n    },\n    getConnectorPoints(rectangle: RectangleClient) {\n        return RectangleClient.getEdgeCenterPoints(rectangle);\n    },\n    getNearestPoint(rectangle: RectangleClient, point: Point) {\n        const nearestPoint = getNearestPointBetweenPointAndSegments(point, RectangleEngine.getCornerPoints(rectangle));\n        if (nearestPoint[0] === rectangle.x + rectangle.width / 2) {\n            return getNearestPointBetweenPointAndEllipse(\n                point,\n                [rectangle.x + rectangle.width * 0.43, rectangle.y + rectangle.height / 2],\n                rectangle.width * 0.223,\n                rectangle.height / 2\n            );\n        }\n        return nearestPoint;\n    },\n    getTangentVectorByConnectionPoint(rectangle: RectangleClient, pointOfRectangle: PointOfRectangle) {\n        const connectionPoint = RectangleClient.getConnectionPoint(rectangle, pointOfRectangle);\n        if (connectionPoint[0] > rectangle.x + rectangle.width * 0.43 && connectionPoint[1] < rectangle.y + rectangle.height / 2) {\n            return rotateVector(getUnitVectorByPointAndPoint(connectionPoint, [rectangle.x, rectangle.y + rectangle.height / 2]), -Math.PI);\n        }\n        if (connectionPoint[0] > rectangle.x + rectangle.width * 0.43 && connectionPoint[1] > rectangle.y + rectangle.height / 2) {\n            return getUnitVectorByPointAndPoint(connectionPoint, [rectangle.x, rectangle.y + rectangle.height / 2]);\n        }\n        return getUnitVectorByPointAndPoint(connectionPoint, [rectangle.x, rectangle.y + rectangle.height / 2]);\n    }\n};\n"]}
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assembly.js","sourceRoot":"","sources":["../../../../../packages/draw/src/engines/uml/assembly.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    Point,\n    PointOfRectangle,\n    RectangleClient,\n    SVGArcCommand,\n    distanceBetweenPointAndPoint,\n    getNearestPointBetweenPointAndArc,\n    getNearestPointBetweenPointAndEllipse,\n    getNearestPointBetweenPointAndSegments,\n    setStrokeLinecap\n} from '@plait/core';\nimport { ShapeEngine } from '../../interfaces';\nimport { Options } from 'roughjs/bin/core';\nimport { RectangleEngine } from '../basic-shapes/rectangle';\nimport { getUnitVectorByPointAndPoint, rotateVector } from '@plait/common';\n\ninterface AssemblyPathData {\n    startPoint: Point;\n    line1: [Point, Point];\n    circleArcCommand: SVGArcCommand;\n    verticalArcCommand: SVGArcCommand;\n    line2: [Point, Point];\n}\n\nfunction generateAssemblyPath(rectangle: RectangleClient): AssemblyPathData {\n    const centerY = rectangle.y + rectangle.height / 2;\n    const firstLineEndX = rectangle.x + rectangle.width * 0.3;\n    const circleWidth = rectangle.width * 0.13;\n    const circleHeight = rectangle.height * 0.285;\n    const verticalX = firstLineEndX + circleWidth;\n    const verticalRadius = rectangle.width * 0.233;\n\n    return {\n        startPoint: [rectangle.x, centerY],\n        line1: [\n            [rectangle.x, centerY],\n            [firstLineEndX, centerY]\n        ],\n        circleArcCommand: {\n            rx: circleWidth,\n            ry: circleHeight,\n            xAxisRotation: 0,\n            largeArcFlag: 1,\n            sweepFlag: 1,\n            endX: firstLineEndX,\n            endY: centerY\n        },\n        verticalArcCommand: {\n            rx: verticalRadius,\n            ry: rectangle.height / 2,\n            xAxisRotation: 0,\n            largeArcFlag: 0,\n            sweepFlag: 1,\n            endX: verticalX,\n            endY: rectangle.y + rectangle.height\n        },\n        line2: [\n            [verticalX + verticalRadius, centerY],\n            [rectangle.x + rectangle.width, centerY]\n        ]\n    };\n}\n\nexport const AssemblyEngine: ShapeEngine = {\n    draw(board: PlaitBoard, rectangle: RectangleClient, options: Options) {\n        const rs = PlaitBoard.getRoughSVG(board);\n        const { startPoint, line1, circleArcCommand, verticalArcCommand, line2 } = generateAssemblyPath(rectangle);\n\n        const pathData = [\n            `M${startPoint[0]} ${startPoint[1]}`,\n            `H${line1[1][0]}`,\n            // 画完整的圆形：先画一个半圆，再画另一个半圆\n            `A${circleArcCommand.rx} ${circleArcCommand.ry} ${circleArcCommand.xAxisRotation} ${circleArcCommand.largeArcFlag} ${circleArcCommand.sweepFlag} ${line1[1][0] + circleArcCommand.rx * 2} ${circleArcCommand.endY}`,\n            `A${circleArcCommand.rx} ${circleArcCommand.ry} ${circleArcCommand.xAxisRotation} ${circleArcCommand.largeArcFlag} ${circleArcCommand.sweepFlag} ${circleArcCommand.endX} ${circleArcCommand.endY}`,\n            // 垂直椭圆\n            `M${verticalArcCommand.endX} ${rectangle.y}`,\n            `A${verticalArcCommand.rx} ${verticalArcCommand.ry} ${verticalArcCommand.xAxisRotation} ${verticalArcCommand.largeArcFlag} ${verticalArcCommand.sweepFlag} ${verticalArcCommand.endX} ${verticalArcCommand.endY}`,\n            // 最后一条线\n            `M${line2[0][0]} ${line2[0][1]} H${line2[1][0]}`\n        ].join(' ');\n\n        const shape = rs.path(pathData, {\n            ...options,\n            fillStyle: 'solid'\n        });\n        setStrokeLinecap(shape, 'round');\n        return shape;\n    },\n    isInsidePoint(rectangle: RectangleClient, point: Point) {\n        const rangeRectangle = RectangleClient.getRectangleByPoints([point, point]);\n        return RectangleClient.isHit(rectangle, rangeRectangle);\n    },\n    getCornerPoints(rectangle: RectangleClient) {\n        return RectangleClient.getCornerPoints(rectangle);\n    },\n    getConnectorPoints(rectangle: RectangleClient) {\n        return RectangleClient.getEdgeCenterPoints(rectangle);\n    },\n    getNearestPoint(rectangle: RectangleClient, point: Point) {\n        const { line1, line2, circleArcCommand, verticalArcCommand } = generateAssemblyPath(rectangle);\n\n        // 检查直线段\n        const nearestPointForLines = getNearestPointBetweenPointAndSegments(point, [...line1, ...line2]);\n        const distanceForLines = distanceBetweenPointAndPoint(...point, ...nearestPointForLines);\n\n        // 检查中间圆形\n        const circleCenter = [line1[1][0] + circleArcCommand.rx, line1[1][1]] as Point;\n        const nearestPointForCircle = getNearestPointBetweenPointAndEllipse(\n            point,\n            circleCenter,\n            circleArcCommand.rx,\n            circleArcCommand.ry\n        );\n        const distanceForCircle = distanceBetweenPointAndPoint(...point, ...nearestPointForCircle);\n\n        // 检查垂直椭圆（使用 getNearestPointBetweenPointAndArc 处理半圆弧）\n        const arcStartPoint: Point = [verticalArcCommand.endX, rectangle.y];\n        const nearestPointForEllipse = getNearestPointBetweenPointAndArc(\n            point,\n            arcStartPoint,\n            verticalArcCommand\n        );\n        const distanceForEllipse = distanceBetweenPointAndPoint(...point, ...nearestPointForEllipse);\n\n        // 返回最近的点\n        const minDistance = Math.min(distanceForLines, distanceForCircle, distanceForEllipse);\n        if (minDistance === distanceForLines) return nearestPointForLines;\n        if (minDistance === distanceForCircle) return nearestPointForCircle;\n        return nearestPointForEllipse;\n    },\n    getTangentVectorByConnectionPoint(rectangle: RectangleClient, pointOfRectangle: PointOfRectangle) {\n        const connectionPoint = RectangleClient.getConnectionPoint(rectangle, pointOfRectangle);\n        if (connectionPoint[0] > rectangle.x + rectangle.width * 0.43 && connectionPoint[1] < rectangle.y + rectangle.height / 2) {\n            return rotateVector(getUnitVectorByPointAndPoint(connectionPoint, [rectangle.x, rectangle.y + rectangle.height / 2]), -Math.PI);\n        }\n        if (connectionPoint[0] > rectangle.x + rectangle.width * 0.43 && connectionPoint[1] > rectangle.y + rectangle.height / 2) {\n            return getUnitVectorByPointAndPoint(connectionPoint, [rectangle.x, rectangle.y + rectangle.height / 2]);\n        }\n        return getUnitVectorByPointAndPoint(connectionPoint, [rectangle.x, rectangle.y + rectangle.height / 2]);\n    }\n};\n"]}
|
|
@@ -1,32 +1,85 @@
|
|
|
1
|
-
import { PlaitBoard, RectangleClient,
|
|
2
|
-
import { RectangleEngine } from '../basic-shapes/rectangle';
|
|
1
|
+
import { PlaitBoard, RectangleClient, getNearestPointBetweenPointAndDiscreteSegments, setStrokeLinecap } from '@plait/core';
|
|
3
2
|
import { getStrokeWidthByElement } from '../../utils';
|
|
4
3
|
import { ShapeDefaultSpace } from '../../constants';
|
|
5
4
|
import { getUnitVectorByPointAndPoint } from '@plait/common';
|
|
5
|
+
function generateComponentPath(rectangle) {
|
|
6
|
+
const mainLineX = rectangle.x + 12;
|
|
7
|
+
const boxWidth = rectangle.width > 70 ? 24 : rectangle.width * 0.2;
|
|
8
|
+
const boxHeight = rectangle.height - 28 - rectangle.height * 0.35 > 1 ? 14 : rectangle.height * 0.175;
|
|
9
|
+
const topBoxY = rectangle.y + rectangle.height * 0.175;
|
|
10
|
+
const bottomBoxY = rectangle.y + rectangle.height - rectangle.height * 0.175 - boxHeight;
|
|
11
|
+
return {
|
|
12
|
+
boxSize: {
|
|
13
|
+
width: boxWidth,
|
|
14
|
+
height: boxHeight
|
|
15
|
+
},
|
|
16
|
+
points: {
|
|
17
|
+
mainStart: [mainLineX, rectangle.y],
|
|
18
|
+
topBoxStart: [mainLineX, topBoxY],
|
|
19
|
+
topBoxEnd: [mainLineX, topBoxY + boxHeight],
|
|
20
|
+
bottomBoxStart: [mainLineX, bottomBoxY],
|
|
21
|
+
bottomBoxEnd: [mainLineX, bottomBoxY + boxHeight],
|
|
22
|
+
mainEnd: [mainLineX, rectangle.y + rectangle.height],
|
|
23
|
+
rightTop: [rectangle.x + rectangle.width, rectangle.y],
|
|
24
|
+
rightBottom: [rectangle.x + rectangle.width, rectangle.y + rectangle.height]
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
}
|
|
6
28
|
export const ComponentEngine = {
|
|
7
29
|
draw(board, rectangle, options) {
|
|
8
30
|
const rs = PlaitBoard.getRoughSVG(board);
|
|
9
|
-
const boxSize =
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
M${
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
31
|
+
const { boxSize, points } = generateComponentPath(rectangle);
|
|
32
|
+
const pathData = [
|
|
33
|
+
// 主矩形轮廓
|
|
34
|
+
`M${points.mainStart[0]} ${points.mainStart[1]}`,
|
|
35
|
+
`H${points.rightTop[0]}`,
|
|
36
|
+
`V${points.rightBottom[1]}`,
|
|
37
|
+
`H${points.mainEnd[0]}`,
|
|
38
|
+
// 上方小矩形
|
|
39
|
+
`M${points.topBoxStart[0]} ${points.topBoxStart[1]}`,
|
|
40
|
+
`h${boxSize.width / 2} v${boxSize.height} h${-boxSize.width} v${-boxSize.height} h${boxSize.width / 2}`,
|
|
41
|
+
// 下方小矩形
|
|
42
|
+
`M${points.bottomBoxStart[0]} ${points.bottomBoxStart[1]}`,
|
|
43
|
+
`h${boxSize.width / 2} v${boxSize.height} h${-boxSize.width} v${-boxSize.height} h${boxSize.width / 2}`,
|
|
44
|
+
// 连接线
|
|
45
|
+
`M${points.mainStart[0]} ${points.mainStart[1]}`,
|
|
46
|
+
`V${points.topBoxStart[1]}`,
|
|
47
|
+
`M${points.topBoxEnd[0]} ${points.topBoxEnd[1]}`,
|
|
48
|
+
`V${points.bottomBoxStart[1]}`,
|
|
49
|
+
`M${points.bottomBoxEnd[0]} ${points.bottomBoxEnd[1]}`,
|
|
50
|
+
`V${points.mainEnd[1]}`
|
|
51
|
+
].join(' ');
|
|
52
|
+
const shape = rs.path(pathData, { ...options, fillStyle: 'solid' });
|
|
27
53
|
setStrokeLinecap(shape, 'round');
|
|
28
54
|
return shape;
|
|
29
55
|
},
|
|
56
|
+
getNearestPoint(rectangle, point) {
|
|
57
|
+
const { boxSize, points } = generateComponentPath(rectangle);
|
|
58
|
+
const segments = [
|
|
59
|
+
// 主矩形轮廓
|
|
60
|
+
[points.mainStart, [points.rightTop[0], points.mainStart[1]]],
|
|
61
|
+
[[points.rightTop[0], points.mainStart[1]], points.rightBottom],
|
|
62
|
+
[points.rightBottom, [points.mainEnd[0], points.rightBottom[1]]],
|
|
63
|
+
[[points.mainEnd[0], points.rightBottom[1]], points.mainStart],
|
|
64
|
+
// 上方小矩形
|
|
65
|
+
[points.topBoxStart, [points.topBoxStart[0] + boxSize.width / 2, points.topBoxStart[1]]],
|
|
66
|
+
[[points.topBoxStart[0] + boxSize.width / 2, points.topBoxStart[1]], [points.topBoxStart[0] + boxSize.width / 2, points.topBoxEnd[1]]],
|
|
67
|
+
[[points.topBoxStart[0] + boxSize.width / 2, points.topBoxEnd[1]], [points.topBoxStart[0] - boxSize.width / 2, points.topBoxEnd[1]]],
|
|
68
|
+
[[points.topBoxStart[0] - boxSize.width / 2, points.topBoxEnd[1]], [points.topBoxStart[0] - boxSize.width / 2, points.topBoxStart[1]]],
|
|
69
|
+
[[points.topBoxStart[0] - boxSize.width / 2, points.topBoxStart[1]], points.topBoxStart],
|
|
70
|
+
// 下方小矩形
|
|
71
|
+
[points.bottomBoxStart, [points.bottomBoxStart[0] + boxSize.width / 2, points.bottomBoxStart[1]]],
|
|
72
|
+
[[points.bottomBoxStart[0] + boxSize.width / 2, points.bottomBoxStart[1]], [points.bottomBoxStart[0] + boxSize.width / 2, points.bottomBoxEnd[1]]],
|
|
73
|
+
[[points.bottomBoxStart[0] + boxSize.width / 2, points.bottomBoxEnd[1]], [points.bottomBoxStart[0] - boxSize.width / 2, points.bottomBoxEnd[1]]],
|
|
74
|
+
[[points.bottomBoxStart[0] - boxSize.width / 2, points.bottomBoxEnd[1]], [points.bottomBoxStart[0] - boxSize.width / 2, points.bottomBoxStart[1]]],
|
|
75
|
+
[[points.bottomBoxStart[0] - boxSize.width / 2, points.bottomBoxStart[1]], points.bottomBoxStart],
|
|
76
|
+
// 连接线
|
|
77
|
+
[points.mainStart, points.topBoxStart],
|
|
78
|
+
[points.topBoxEnd, points.bottomBoxStart],
|
|
79
|
+
[points.bottomBoxEnd, points.mainEnd]
|
|
80
|
+
];
|
|
81
|
+
return getNearestPointBetweenPointAndDiscreteSegments(point, segments);
|
|
82
|
+
},
|
|
30
83
|
isInsidePoint(rectangle, point) {
|
|
31
84
|
const rangeRectangle = RectangleClient.getRectangleByPoints([point, point]);
|
|
32
85
|
return RectangleClient.isHit(rectangle, rangeRectangle);
|
|
@@ -34,26 +87,18 @@ export const ComponentEngine = {
|
|
|
34
87
|
getCornerPoints(rectangle) {
|
|
35
88
|
return RectangleClient.getCornerPoints(rectangle);
|
|
36
89
|
},
|
|
37
|
-
getNearestPoint(rectangle, point) {
|
|
38
|
-
let nearestPoint = getNearestPointBetweenPointAndSegments(point, RectangleEngine.getCornerPoints(rectangle));
|
|
39
|
-
if (nearestPoint[1] === rectangle.y + rectangle.height / 2) {
|
|
40
|
-
nearestPoint = getNearestPointBetweenPointAndSegments(point, [
|
|
41
|
-
[rectangle.x + 12, rectangle.y + rectangle.height * 0.175 + 14],
|
|
42
|
-
[rectangle.x + 12, rectangle.y + rectangle.height - rectangle.height * 0.175 - 14]
|
|
43
|
-
], false);
|
|
44
|
-
}
|
|
45
|
-
return nearestPoint;
|
|
46
|
-
},
|
|
47
90
|
getTangentVectorByConnectionPoint(rectangle, pointOfRectangle) {
|
|
91
|
+
const { points } = generateComponentPath(rectangle);
|
|
48
92
|
const connectionPoint = RectangleClient.getConnectionPoint(rectangle, pointOfRectangle);
|
|
49
|
-
return getUnitVectorByPointAndPoint(
|
|
93
|
+
return getUnitVectorByPointAndPoint(points.mainStart, connectionPoint);
|
|
50
94
|
},
|
|
51
95
|
getConnectorPoints(rectangle) {
|
|
96
|
+
const { points } = generateComponentPath(rectangle);
|
|
52
97
|
return [
|
|
53
98
|
[rectangle.x + rectangle.width / 2, rectangle.y],
|
|
54
99
|
[rectangle.x + rectangle.width, rectangle.y + rectangle.height / 2],
|
|
55
100
|
[rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height],
|
|
56
|
-
[
|
|
101
|
+
[points.mainStart[0], rectangle.y + rectangle.height / 2]
|
|
57
102
|
];
|
|
58
103
|
},
|
|
59
104
|
getTextRectangle(element) {
|
|
@@ -69,4 +114,4 @@ export const ComponentEngine = {
|
|
|
69
114
|
};
|
|
70
115
|
}
|
|
71
116
|
};
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../packages/draw/src/engines/uml/component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    Point,\n    PointOfRectangle,\n    RectangleClient,\n    getNearestPointBetweenPointAndSegments,\n    setStrokeLinecap\n} from '@plait/core';\nimport { PlaitGeometry, ShapeEngine } from '../../interfaces';\nimport { Options } from 'roughjs/bin/core';\nimport { RectangleEngine } from '../basic-shapes/rectangle';\nimport { getStrokeWidthByElement } from '../../utils';\nimport { ShapeDefaultSpace } from '../../constants';\nimport { getUnitVectorByPointAndPoint } from '@plait/common';\n\nexport const ComponentEngine: ShapeEngine = {\n    draw(board: PlaitBoard, rectangle: RectangleClient, options: Options) {\n        const rs = PlaitBoard.getRoughSVG(board);\n        const boxSize = {\n            with: rectangle.width > 70 ? 24 : rectangle.width * 0.2,\n            height: rectangle.height - 28 - rectangle.height * 0.35 > 1 ? 14 : rectangle.height * 0.175\n        };\n        const shape = rs.path(\n            `M${rectangle.x + 12} ${rectangle.y} \n            v${rectangle.height * 0.175} \n            h${boxSize.with / 2} v${boxSize.height} h${-boxSize.with} v${-boxSize.height} h${boxSize.with / 2}\n\n            M${rectangle.x + 12} ${rectangle.y + rectangle.height * 0.175 + boxSize.height} \n\n            v${rectangle.height - rectangle.height * 0.35 - boxSize.height * 2}\n            h${boxSize.with / 2} v${boxSize.height} h${-boxSize.with} v${-boxSize.height} h${boxSize.with / 2}\n            M${rectangle.x + 12} ${rectangle.y + rectangle.height - rectangle.height * 0.175} \n            V${rectangle.y + rectangle.height}\n            H${rectangle.x + rectangle.width}\n            v${-rectangle.height}\n            h${-(rectangle.width - 12)}\n             `,\n            { ...options, fillStyle: 'solid' }\n        );\n        setStrokeLinecap(shape, 'round');\n\n        return shape;\n    },\n    isInsidePoint(rectangle: RectangleClient, point: Point) {\n        const rangeRectangle = RectangleClient.getRectangleByPoints([point, point]);\n        return RectangleClient.isHit(rectangle, rangeRectangle);\n    },\n    getCornerPoints(rectangle: RectangleClient) {\n        return RectangleClient.getCornerPoints(rectangle);\n    },\n    getNearestPoint(rectangle: RectangleClient, point: Point) {\n        let nearestPoint = getNearestPointBetweenPointAndSegments(point, RectangleEngine.getCornerPoints(rectangle));\n        if (nearestPoint[1] === rectangle.y + rectangle.height / 2) {\n            nearestPoint = getNearestPointBetweenPointAndSegments(\n                point,\n                [\n                    [rectangle.x + 12, rectangle.y + rectangle.height * 0.175 + 14],\n                    [rectangle.x + 12, rectangle.y + rectangle.height - rectangle.height * 0.175 - 14]\n                ],\n                false\n            );\n        }\n        return nearestPoint;\n    },\n\n    getTangentVectorByConnectionPoint(rectangle: RectangleClient, pointOfRectangle: PointOfRectangle) {\n        const connectionPoint = RectangleClient.getConnectionPoint(rectangle, pointOfRectangle);\n        return getUnitVectorByPointAndPoint(\n            [rectangle.x + 12, rectangle.y + rectangle.height - rectangle.height * 0.175 - 14],\n            connectionPoint\n        );\n    },\n    getConnectorPoints(rectangle: RectangleClient) {\n        return [\n            [rectangle.x + rectangle.width / 2, rectangle.y],\n            [rectangle.x + rectangle.width, rectangle.y + rectangle.height / 2],\n            [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height],\n            [rectangle.x + 12, rectangle.y + rectangle.height / 2]\n        ] as [Point, Point, Point, Point];\n    },\n    getTextRectangle(element: PlaitGeometry) {\n        const elementRectangle = RectangleClient.getRectangleByPoints(element.points!);\n        const strokeWidth = getStrokeWidthByElement(element);\n        const height = element.textHeight!;\n        const width = elementRectangle.width - 24 - ShapeDefaultSpace.rectangleAndText * 2 - strokeWidth * 2;\n        return {\n            height,\n            width: width > 0 ? width : 0,\n            x: elementRectangle.x + 24 + ShapeDefaultSpace.rectangleAndText + strokeWidth,\n            y: elementRectangle.y + (elementRectangle.height - height) / 2\n        };\n    }\n};\n"]}
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../packages/draw/src/engines/uml/component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    Point,\n    PointOfRectangle,\n    RectangleClient,\n    getNearestPointBetweenPointAndDiscreteSegments,\n    setStrokeLinecap\n} from '@plait/core';\nimport { PlaitGeometry, ShapeEngine } from '../../interfaces';\nimport { Options } from 'roughjs/bin/core';\nimport { RectangleEngine } from '../basic-shapes/rectangle';\nimport { getStrokeWidthByElement } from '../../utils';\nimport { ShapeDefaultSpace } from '../../constants';\nimport { getUnitVectorByPointAndPoint } from '@plait/common';\n\ninterface ComponentPathData {\n    boxSize: {\n        width: number;\n        height: number;\n    };\n    points: {\n        mainStart: Point;\n        topBoxStart: Point;\n        topBoxEnd: Point;\n        bottomBoxStart: Point;\n        bottomBoxEnd: Point;\n        mainEnd: Point;\n        rightTop: Point;\n        rightBottom: Point;\n    };\n}\n\nfunction generateComponentPath(rectangle: RectangleClient): ComponentPathData {\n    const mainLineX = rectangle.x + 12;\n    const boxWidth = rectangle.width > 70 ? 24 : rectangle.width * 0.2;\n    const boxHeight = rectangle.height - 28 - rectangle.height * 0.35 > 1 ? 14 : rectangle.height * 0.175;\n    const topBoxY = rectangle.y + rectangle.height * 0.175;\n    const bottomBoxY = rectangle.y + rectangle.height - rectangle.height * 0.175 - boxHeight;\n    \n    return {\n        boxSize: {\n            width: boxWidth,\n            height: boxHeight\n        },\n        points: {\n            mainStart: [mainLineX, rectangle.y],\n            topBoxStart: [mainLineX, topBoxY],\n            topBoxEnd: [mainLineX, topBoxY + boxHeight],\n            bottomBoxStart: [mainLineX, bottomBoxY],\n            bottomBoxEnd: [mainLineX, bottomBoxY + boxHeight],\n            mainEnd: [mainLineX, rectangle.y + rectangle.height],\n            rightTop: [rectangle.x + rectangle.width, rectangle.y],\n            rightBottom: [rectangle.x + rectangle.width, rectangle.y + rectangle.height]\n        }\n    };\n}\n\nexport const ComponentEngine: ShapeEngine = {\n    draw(board: PlaitBoard, rectangle: RectangleClient, options: Options) {\n        const rs = PlaitBoard.getRoughSVG(board);\n        const { boxSize, points } = generateComponentPath(rectangle);\n        \n        const pathData = [\n            // 主矩形轮廓\n            `M${points.mainStart[0]} ${points.mainStart[1]}`,\n            `H${points.rightTop[0]}`,\n            `V${points.rightBottom[1]}`,\n            `H${points.mainEnd[0]}`,\n\n            // 上方小矩形\n            `M${points.topBoxStart[0]} ${points.topBoxStart[1]}`,\n            `h${boxSize.width / 2} v${boxSize.height} h${-boxSize.width} v${-boxSize.height} h${boxSize.width / 2}`,\n\n            // 下方小矩形\n            `M${points.bottomBoxStart[0]} ${points.bottomBoxStart[1]}`,\n            `h${boxSize.width / 2} v${boxSize.height} h${-boxSize.width} v${-boxSize.height} h${boxSize.width / 2}`,\n\n            // 连接线\n            `M${points.mainStart[0]} ${points.mainStart[1]}`,\n            `V${points.topBoxStart[1]}`,\n            `M${points.topBoxEnd[0]} ${points.topBoxEnd[1]}`,\n            `V${points.bottomBoxStart[1]}`,\n            `M${points.bottomBoxEnd[0]} ${points.bottomBoxEnd[1]}`,\n            `V${points.mainEnd[1]}`\n        ].join(' ');\n\n        const shape = rs.path(pathData, { ...options, fillStyle: 'solid' });\n        setStrokeLinecap(shape, 'round');\n        return shape;\n    },\n\n    getNearestPoint(rectangle: RectangleClient, point: Point) {\n        const { boxSize, points } = generateComponentPath(rectangle);\n        \n        const segments: [Point, Point][] = [\n            // 主矩形轮廓\n            [points.mainStart, [points.rightTop[0], points.mainStart[1]]],\n            [[points.rightTop[0], points.mainStart[1]], points.rightBottom],\n            [points.rightBottom, [points.mainEnd[0], points.rightBottom[1]]],\n            [[points.mainEnd[0], points.rightBottom[1]], points.mainStart],\n\n            // 上方小矩形\n            [points.topBoxStart, [points.topBoxStart[0] + boxSize.width/2, points.topBoxStart[1]]],\n            [[points.topBoxStart[0] + boxSize.width/2, points.topBoxStart[1]], [points.topBoxStart[0] + boxSize.width/2, points.topBoxEnd[1]]],\n            [[points.topBoxStart[0] + boxSize.width/2, points.topBoxEnd[1]], [points.topBoxStart[0] - boxSize.width/2, points.topBoxEnd[1]]],\n            [[points.topBoxStart[0] - boxSize.width/2, points.topBoxEnd[1]], [points.topBoxStart[0] - boxSize.width/2, points.topBoxStart[1]]],\n            [[points.topBoxStart[0] - boxSize.width/2, points.topBoxStart[1]], points.topBoxStart],\n\n            // 下方小矩形\n            [points.bottomBoxStart, [points.bottomBoxStart[0] + boxSize.width/2, points.bottomBoxStart[1]]],\n            [[points.bottomBoxStart[0] + boxSize.width/2, points.bottomBoxStart[1]], [points.bottomBoxStart[0] + boxSize.width/2, points.bottomBoxEnd[1]]],\n            [[points.bottomBoxStart[0] + boxSize.width/2, points.bottomBoxEnd[1]], [points.bottomBoxStart[0] - boxSize.width/2, points.bottomBoxEnd[1]]],\n            [[points.bottomBoxStart[0] - boxSize.width/2, points.bottomBoxEnd[1]], [points.bottomBoxStart[0] - boxSize.width/2, points.bottomBoxStart[1]]],\n            [[points.bottomBoxStart[0] - boxSize.width/2, points.bottomBoxStart[1]], points.bottomBoxStart],\n\n            // 连接线\n            [points.mainStart, points.topBoxStart],\n            [points.topBoxEnd, points.bottomBoxStart],\n            [points.bottomBoxEnd, points.mainEnd]\n        ];\n\n        return getNearestPointBetweenPointAndDiscreteSegments(point, segments);\n    },\n\n    isInsidePoint(rectangle: RectangleClient, point: Point) {\n        const rangeRectangle = RectangleClient.getRectangleByPoints([point, point]);\n        return RectangleClient.isHit(rectangle, rangeRectangle);\n    },\n\n    getCornerPoints(rectangle: RectangleClient) {\n        return RectangleClient.getCornerPoints(rectangle);\n    },\n\n    getTangentVectorByConnectionPoint(rectangle: RectangleClient, pointOfRectangle: PointOfRectangle) {\n        const { points } = generateComponentPath(rectangle);\n        const connectionPoint = RectangleClient.getConnectionPoint(rectangle, pointOfRectangle);\n        return getUnitVectorByPointAndPoint(points.mainStart, connectionPoint);\n    },\n\n    getConnectorPoints(rectangle: RectangleClient) {\n        const { points } = generateComponentPath(rectangle);\n        return [\n            [rectangle.x + rectangle.width / 2, rectangle.y],\n            [rectangle.x + rectangle.width, rectangle.y + rectangle.height / 2],\n            [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height],\n            [points.mainStart[0], rectangle.y + rectangle.height / 2]\n        ] as [Point, Point, Point, Point];\n    },\n\n    getTextRectangle(element: PlaitGeometry) {\n        const elementRectangle = RectangleClient.getRectangleByPoints(element.points!);\n        const strokeWidth = getStrokeWidthByElement(element);\n        const height = element.textHeight!;\n        const width = elementRectangle.width - 24 - ShapeDefaultSpace.rectangleAndText * 2 - strokeWidth * 2;\n        return {\n            height,\n            width: width > 0 ? width : 0,\n            x: elementRectangle.x + 24 + ShapeDefaultSpace.rectangleAndText + strokeWidth,\n            y: elementRectangle.y + (elementRectangle.height - height) / 2\n        };\n    }\n};\n"]}
|