我使用brush.extent([val1,val2])
进行刷牙时遇到问题关于文档:https://github.com/mbostock/d3/wiki/SVG-Controls当我像这样设置brush.extent([val1,val2])时:
var xScale = d3.scale.linear()
.domain(data)
.range([0, 500]);
var brush = d3.svg.brush()
.x(xScale)
.on('brushstart', function() {
this.brushStart();
})
.on('brushend', function() {
this.brushEnd();
})
.extent([100, 300]);
它将在xAxis上显示从100到200的刷区域(刷子可见且在右侧位置)。
不幸的是,当我使用d3.time.scale()时,它根本不起作用:
var xScale = d3.time.scale()
.domain(data)
.range([0, 500]);
var brush = d3.svg.brush()
.x(xScale)
.on('brushstart', function() {
this.brushStart();
})
.on('brushend', function() {
this.brushEnd();
})
.extent([100, 300]);
// or
// .extent(['2013-08-01T00:00:00Z', '2013-08-10T23:59:59Z']);
// or
// .extent(['2013-08-01 00:00:00', '2013-08-10 23:59:59']);
// or even
// .extent([new Date(2013, 8, 1, 00, 00, 00), new Date(2013, 8, 10, 23, 59, 59)]);
它不显示拉丝区域。
当我使用d3.time.scale()时如何设置拉丝区域?
当然,数据包含的日期范围可以适用于刷毛甚至是边距。
马里乌什
答案 0 :(得分:11)
我发现了问题和解决方案。
我正在使用功能:
var parseDate = d3.time.format('%Y-%m-%d %H:%M:%S').parse;
处理所有数据值,原始格式为yyyy-mm-dd hh:mm:ss
设置brush.extent([val1,val2])时我需要使用相同的parseDate()函数:
brush.extent([parseDate(val1), parseDate[val2]]);
马里乌什