1
我有一个简单的路径元素,圆圈必须遵循使用D3.js.我发现了一个办法做到这一点,通过使用如本例中所述的SVG getTotalLength和getPointAtLength方法:沿着路径动画改变起点
http://bl.ocks.org/mbostock/1705868
它工作正常,但问题是,我的圈子里开始底部向上如下行,我如何在动画中更改圆圈的起点,以便它从上到下?这里是我的代码:
我的路径元素:
<path id="testpath" style="fill:none;stroke:#FFFFFF;stroke-width:0.75;" d="M1312.193,1035.872l80.324-174.458l13.909-264.839l507.09-211.095
l8.667-248.405" />
的D3代码:
function followPath()
{
var circle = d3.select("svg").append("circle")
.attr("r", 6.5)
.attr("transform", "translate(0,0)")
.attr("class","circle");
var path = d3.select("#testpath");
function transition()
{
circle.transition()
.duration(10000)
.attrTween("transform", translateAlong(path.node()))
.each("end", transition);
}
function translateAlong(path)
{
var l = path.getTotalLength();
return function (d, i, a) {
return function (t) {
var p = path.getPointAtLength(t * l);
return "translate(" + p.x + "," + p.y + ")";
};
};
}
transition();
}
我做了一个小提琴其中u可以看到它从底部到顶部(我知道视框大,这是一个更大的SVG图像的一部分)
我知道这只是颠倒了一些东西,只是无法弄清楚每个函数的参数是什么。非常感谢! – 2014-11-05 00:07:49