d3js - SVG圆在光滑的永动机
d3js - SVG circle in smooth perpetual motion
我正在尝试用d3js动画一个圆圈云。我想要得到的是一个随机的光滑的永久运动,所有的圆都围绕它们的初始位置"引力"。
到目前为止,我得到了这个:http://jsfiddle.net/vnr1f9f8/6/
这里的问题是运动一点也不平滑。圆圈移动,然后停止,然后重新开始。
我该如何解决这个问题?
以下是我使用的d3代码: var svg = d3.select('body').append('svg')
.attr("width", 960)
.attr("height", 480);
var circleContainer = [];
for (var i = 0; i < 10; i++) {
var originX = 100 * (1 + 2.5 * Math.random()),
originY = 80 * (1 + 2.5 * Math.random());
circleContainer[i] = svg.append('circle')
.attr('class', 'circle-' + i)
.attr('cx', originX)
.attr('cy', originY)
.attr('originX', originX)
.attr('originY', originY)
.attr('r', 20)
.attr('fill','red');
}
transition();
function transition() {
for (var i = 0; i < 10; i++) {
circleContainer[i].transition()
.duration(1000)
.attr('cx', circleContainer[i].attr('originX') * (1 + Math.random()/10))
.attr('cy', circleContainer[i].attr('originY') * (1 + Math.random()/10))
.each("end", transition)
.ease("linear");
}
}
您可以添加.ease("linear")
以使其平滑。这里是jsfiddle - http://jsfiddle.net/cuckovic/vnr1f9f8/3/
相关文章:
- D3在一个调用中绘制不同的SVG形状,没有可见性
- 如何使用javascript从主svg对象动态创建svg视图框
- 如何更改<svg>标记为<img>用js标记
- 锚点元素不't使用svg时,请打开EDGE上的href
- 带有填充属性的SVG矩形显示在包含元素的上方插入框阴影
- 使用onclick绘制SVG路径
- SVG/JavaScript:尝试选择和更改多边形点
- 顺时针旋转Svg元件
- 禁用SVG拖动
- 在select元素中显示highchart dashstyle(svg)
- 在D3.js中,有没有任何方法可以将x和y方向上的滚动事件绑定到平移svg
- 缩放Raphael/SVG容器以适应所有内容
- JavaScript-动态SVG-onload属性-未触发事件
- 设置动画时,SVG/Raphael大圆圈会变形
- 使用SVG和JavaScript创建波浪动画
- Canvas+svg路径动画,在路径中的特定点暂停一段时间,然后继续
- D3.js生成有效的SVG,但不显示任何内容
- SVG xml to image
- 如何自动保存动态生成的HTML SVG元素
- d3js - SVG圆在光滑的永动机