我对 svg 语法非常陌生,我想知道如何将一条路径分成两条路径。实际上我有这样的东西:
M Xm Ym ... C Xc1 Yc1 Xc2 Yc2 Xc3 Yc3 (*) C Xd1 Yd1 Xd2 Yd2 Xd3 Yd3 C ...
(*) 是我要分割路径的地方
我想将其转换为两个路径,如下所示:
M Am Bm ... C Ac1 Bc1 Ac2 Bc2 Ac3 Bc3
和
M An Bn C Ad1 Bd1 Ad2 Bd2 Ad3 Bd3 ...
如何通过X和Y数字计算A和B数字?
如果您可以依赖绝对路径命令(即像“C”而不是“c”这样的大写字母),那么这很容易。
M Xm Ym ... C Xc1 Yc1 Xc2 Yc2 Xc3 Yc3 (*) C Xd1 Yd1 Xd2 Yd2 Xd3 Yd3 C ...
Run Code Online (Sandbox Code Playgroud)
会成为
M Xm Ym ... C Xc1 Yc1 Xc2 Yc2 Xc3 Yc3
Run Code Online (Sandbox Code Playgroud)
和
M Xc3 Yc3 C Xd1 Yd1 Xd2 Yd2 Xd3 Yd3 C ...
Run Code Online (Sandbox Code Playgroud)
也就是说,只需使用上一个路径命令中的最后一个坐标对。
但请注意,如果路径有填充,像这样分割它可能会弄乱填充。
如果路径具有相对路径命令(例如c) - 特别是分割之前的命令 - 那么您将需要做更多的工作。您需要先计算出最后一个坐标的绝对值,然后才能在插入的M命令中使用它们。
例子:
M Xm Ym ... C Xc1 Yc1 Xc2 Yc2 Xc3 Yc3 (*) C Xd1 Yd1 Xd2 Yd2 Xd3 Yd3 C ...
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9556 次 |
| 最近记录: |