jquery - D3.js 缩放初始缩放级别

标签 jquery d3.js force-layout

我创建了 d3.js 强制布局,并希望根据屏幕分辨率设置初始缩放级别。 我已经使用带有静态 scale 值的 jQuery 在页面加载上实现了它,它工作正常,但是当我放大时,它会直接缩放到默认比例。

代码如下:

var svg = d3.select("#grapharea")
.append("svg:svg")
.attr("width", width)
.attr("height", height)
.call(d3.behavior.zoom().scaleExtent([0.2, 3]).on("zoom", redraw)).on("dblclick.zoom", null)
.append('svg:g');

$( document ).ready(function() {
  scale = (0.24758571798325626);
  translate = [width*40/100,height*37/100];      
  svg.transition()
    .duration(750)
    .attr("transform", "translate(" + translate + ")scale(" + scale +    ")");
});

有没有办法在页面加载时设置默认比例值,这样当我放大时它会正常缩放。

最佳答案

我尚未测试此解决方案,但我认为您需要在过渡结束时更新缩放行为的缩放/平移属性:

var zoomBehavior = d3.behavior.zoom()
  .scaleExtent([0.2, 3])
  .on("zoom", redraw);

var svg = d3.select("#grapharea")
.append("svg:svg")
.attr("width", width)
.attr("height", height)
.call(zoomBehavior)
.append('svg:g');

$( document ).ready(function() {
  scale = (0.24758571798325626);
  translate = [width*40/100,height*37/100];      
  svg.transition()
    .duration(750)
    .attr("transform", "translate(" + translate + ")scale(" + scale +    ")")
    .each("end", function () {
      zoomBehavior
        .scale(scale)
        .translate(translate);
    });
});

关于jquery - D3.js 缩放初始缩放级别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29643228/

相关文章:

jquery - spring mvc中使用@PathVariable时ajax不起作用

javascript - D3 强制布局 : Fit everything on a page?

javascript - JQueryUI 可拖动和可调整大小的框问题

javascript - 在数字和字符之间插入一个空格

javascript - 在 D3.js (V4) 中创建分类折线图

javascript - D3 x 轴删除垂直条

javascript - 如何缩放 D3 气泡图中的文本

D3.js 强制有向图,每组不同颜色?

javascript - d3js 在力有向图中的线元素上附加圆形形状?

javascript - 带有 ng-change 的 Angularjs slider