我有一个带有视图框0 0 500 500
和转换matrix 0.8,0,0,0.8,54,54
现在我想将此转换添加到其他SVG。问题是所有其他SVG都有不同的视图框。所以我写了一个函数来计算基于视图框的变换......
getAdjustedTransform('0.8,0,0,0.8,54,54','0 0 500 500','0 0 100 100');
效果很好。
但现在我发现了另一个问题。一些SVG具有不同高度和宽度的视图框(不是sqaure)。
我尝试在这里解决这个问题
$viewboxWH_diff = $toThisViewBox_arr[2]/$toThisViewBox_arr[3];
$transform_arr_adjusted[5] = $transform_arr_adjusted[5]*$viewboxWH_diff;
但我的计算不正确。我的错误是什么想法?
function getAdjustedTransform($transform,$viewBox,$toThisViewBox)
{
$transform_arr = explode(",", $transform); // transform from the source SVG
$viewBox_arr = explode(" ", $viewBox); // viewbox from the source SVG
$toThisViewBox_arr = explode(" ", $toThisViewBox);
$transform_arr_adjusted = array();
$val_1 = $transform_arr[4] / $viewBox_arr[2];
$val_2 = $transform_arr[5] / $viewBox_arr[3];
$transform_arr_adjusted[0] = $transform_arr[0];
$transform_arr_adjusted[1] = $transform_arr[1];
$transform_arr_adjusted[2] = $transform_arr[2];
$transform_arr_adjusted[3] = $transform_arr[3];
$transform_arr_adjusted[4] = $val_1 * $toThisViewBox_arr[2];
$transform_arr_adjusted[5] = $val_1 * $toThisViewBox_arr[3];
// if viewbox with and height !=
if($toThisViewBox_arr[2] != $toThisViewBox_arr[3])
{
if($toThisViewBox_arr[2] > $toThisViewBox_arr[3])
{
$viewboxWH_diff = $toThisViewBox_arr[2]/$toThisViewBox_arr[3];
$transform_arr_adjusted[5] = $transform_arr_adjusted[5]*$viewboxWH_diff;
}
else
{
$viewboxWH_diff = $toThisViewBox_arr[3]/$toThisViewBox_arr[2];
$transform_arr_adjusted[5] = $transform_arr_adjusted[5]*$viewboxWH_diff;
}
}
$transform_arr_adjusted = implode(',',$transform_arr_adjusted);
return $transform_arr_adjusted;
}
修改
SVG由此功能产生
http://jsfiddle.net/nw6ykszn/
答案 0 :(得分:0)
我打算将此作为评论,但我的声誉并不允许我这样做。
我想知道这是不是一个错误,或者错误是否在您的代码中。
$transform_arr_adjusted[5] = $val_1 * $toThisViewBox_arr[3];
我想它应该是:
$transform_arr_adjusted[5] = $val_2 * $toThisViewBox_arr[3];
希望它有所帮助!