2

我有一个问题好几个星期都无法解决。我正在研究这个例子的修改版本:http: //bl.ocks.org/mbostock/1667367我最初定义了画笔,所以它的画笔范围在 0.5 和 0.8 之间。

var brush = d3.svg.brush()
    .x(x2)
    .extent([0.5, 0.8])
    .on("brush", brushed);

画笔选择显示在正确的位置(在上下文图上),但焦点区域的初始视图仍设置为整个数据集的范围(而不是画笔的剪切区域)。我读过定义画笔不会自动强制重绘该区域,但我似乎无法弄清楚如何使焦点区域的视图自动缩放到画笔范围。有人可以提供一些意见吗?

更新 1 我目前有一个名为 Brushed 的函数,它执行以下操作:

function brushed() {
  x.domain(brush.empty() ? x2.domain() : brush.extent());
  focus.select("path").attr("d", Light_area);
  focus.select(".x.axis").call(xAxis);
  Light_line_overlay.select("path").attr("d", Light_area);

  rules.select(".y.grid").call(make_x_axis_light()
          .tickSize(-height, 0, 0)
          .tickFormat("")
      );

  var xx0=brush.x()(brush.extent()[0]);
  var xx1=brush.x()(brush.extent()[1]);

  brushfill.attr("x", xx0);
  brushfill.attr("width", xx1-xx0);
}

它与示例略有不同......因为我一直在对其进行修改以执行与基本示例不同的操作。然而,第一条评论建议我应该在声明画笔后调用这个画笔函数(见第一篇文章)。然而,调用这个函数并没有做任何事情(或者至少,它不会将焦点区域更新到画笔的范围)。你有什么建议吗?

4

2 回答 2

1

我很抱歉迟了两年才回答这个问题,但我遇到了同样的情况,这是我在这个话题上找到的唯一资源。我能够弄清楚,所以希望这会帮助其他任何偶然发现它的人。

原始问题中的代码几乎一直存在,只是在范围初始化上没有正确的缩放比例。

我正在使用的数据是一个对象数组,其中包含一个用于我的值的ts键(即纪元毫秒) 。x

// These are needed for the brush construction to know how to scale
x2.domain(x.domain());
y2.domain(y.domain());

// Pick out the ~50% and ~80% marks from the data
var N = data.length;
var cx0 = new Date(data[Math.floor(N*0.50)].ts);
var cx1 = new Date(data[Math.floor(N*0.80)].ts);

// Construct with that extent, which will leave the
// context box started in the correct position.
var brush = d3.svg.brush()
                  .x(x2)
                  .extent([cx0, cx1])
                  .on("brush", brushed)
;

// This is just the original brushed example 
function brushed() {
    x.domain(brush.empty() ? x2.domain() : brush.extent());
    focus.select(".area").attr("d", line);
    focus.select(".x.axis").call(xAxis);
}

...

var focus = svg.append("g")
               .attr("class", "focus")
               .attr("transform",
                     "translate(" + margin.left + "," + margin.top + ")")
;

// Now that focus is defined we can manually update it
brushed();

实际上,我brushed在设置的最后保留了对的调用,只是为了保持美观,但这里的目的只是为了说明一旦focus定义,您就可以调用brushed来执行您想要的任何更新。

最终,您的主要问题似乎是在一定程度上获得正确的类型。使用[0.5, 0.8]用于初始化,但如果您检查brushed是否从实际使用鼠标滑动焦点时调用,brush.extent()将是[Date(), Date()]. 这是有道理的,因为我们正在将这个范围传递给x.domain. 所以这在初始化画笔之前设置了所有缩放,因此初始化范围可以是 a Date,然后其他一切都是肉汁。

于 2015-06-04T13:36:40.923 回答
0

每当以编程方式更改画笔范围时,您都需要执行类似于画笔功能的操作。调整 x.domain 的大小,刷新视图。

function brushed() {
  x.domain(brush.empty() ? x2.domain() : brush.extent());
  focus.select("path").attr("d", area);
  focus.select(".x.axis").call(xAxis);
}

如果这不能解决您的问题,请考虑提供一些代码示例。

于 2013-04-25T03:38:06.097 回答