我最近在这里发现了这个很棒的课程,并尝试使用它。
但是,它只适用于移动、水平线和垂直线等一些基本功能。
--
我尝试通过添加额外的检查(并更改正则表达式)来扩展这个现有的类。
public static function fromPath($pathString) {
preg_match_all('/([mlvhzc][^mlvhzc]*)/i', $pathString, $commands);
$pt = array(0, 0);
$bounds = new self();
foreach ($commands[0] as $command) {
preg_match_all('/((\+|-)?\d+(\.\d+)?(e(\+|-)?\d+)?)/i', $command, $matches);
$i = 0;
while ($i < count($matches[1])) {
switch ($command[0]) {
case 'm' :
case 'l' :
$pt[0] += $matches[1][$i++];
$pt[1] += $matches[1][$i++];
break;
case 'M' :
case 'L' :
$pt[0] = $matches[1][$i++];
$pt[1] = $matches[1][$i++];
$last=$pt;
break;
case 'v' :
$pt[1] += $matches[1][$i++];
break;
case 'V' :
$pt[1] = $matches[1][$i++];
$last[1]=$pt[1];
break;
case 'h' :
$pt[0] += $matches[1][$i++];
break;
case 'H' :
$pt[0] = $matches[1][$i++];
$last[0]=$pt[0];
break;
case 'z' :
case 'Z' :
break;
case 'c':
$pt[0] = $last[0]+$matches[1][4];
$pt[1] = $last[1]+$matches[1][5];
$last=$pt;
$i=count($matches[1]);
break;
default :
throw new RuntimeException("Unhandled path command: " . $command[0]);
}
$bounds->extend($pt[0], $pt[1]);
}
}
return $bounds;
}
我查看了 SVG 手册,发现“c”只有 6 个参数,知道最后 2 个参数是曲线结束的位置,我尝试基于此扩展点...
目前,我的测试基于此:
<svg xmlns="http://www.w3.org/2000/svg" width="109" height="109" viewBox="0 0 109 109">
<g style="fill:none;stroke:#000000;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;">
<path d="M32.25,41c1.25,0.62,3.12,0.67,5.5,0.5c7.12-0.5,19.12-2.5,24-3c0.99-0.1,2.62-0.25,3.75,0" />
</g>
在浏览器中运行时,Chrome 报告它的宽高比(因为我知道 svg 并不完全有大小)大约是 5 到 6,但是,当我用我的脚本找到这个比例时,它完全关闭了。
我想知道是否有另一个支持所有功能(C、c、Q、q 等)的 svg 类。
我知道有一种方法可以通过将它转换为图像来获取盒子,但我觉得效率低下,javascript中也有getBBox,但我想在服务器上执行计算。
谢谢阅读!