我正在尝试用相同数量的段补间2条路径。我使用的迈克·博斯托克这里介绍的方法:https://gist.github.com/mbostock/3916621:d3js - 2条路径之间的转换
svg.append("path")
.attr("transform", "translate(180,150)scale(2,2)")
.attr("d", d0)
.call(transition, d0, d1);
function transition(path, d0, d1) {
path.transition()
.duration(2000)
.attrTween("d", pathTween(d1, 4))
.each("end", function() { d3.select(this).call(transition, d1, d0); });
}
function pathTween(d1, precision) {
return function() {
var path0 = this,
path1 = path0.cloneNode(),
n0 = path0.getTotalLength(),
n1 = (path1.setAttribute("d", d1), path1).getTotalLength();
// Uniform sampling of distance based on specified precision.
var distances = [0], i = 0, dt = precision/Math.max(n0, n1);
while ((i += dt) < 1) distances.push(i);
distances.push(1);
// Compute point-interpolators at each distance.
var points = distances.map(function(t) {
var p0 = path0.getPointAtLength(t * n0),
p1 = path1.getPointAtLength(t * n1);
return d3.interpolate([p0.x, p0.y], [p1.x, p1.y]);
});
return function(t) {
return t < 1 ? "M" + points.map(function(p) { return p(t); }).join("L") : d1;
};
};
}
它提供了很好的效果,但是我现在面临一个愚蠢的问题。 我想找到一种方法将第一条路径中的细分与第二条路径中的细分相关联,以获得更好的补间效果。
例如,这里:http://jsfiddle.net/2brqoo5p/1/ 2路径具有相似的形状,但补间比它可能要复杂得多。有没有办法来解决这个问题?
非常感谢
也许你可以弄清楚如何绘制第一条路径'd0',其条款与'd1'相同。即按照与d1中出现的顺序相同的顺序,使用一系列曲线和直线指定'd0',但点的数值不同。由于'd0'是一个圆,所以每条线将结束于其结束之前的曲线的同一点(即线的长度为0)。这样d3可能“知道”如何正确插入它。 – meetamit 2014-08-28 04:27:23