D3时间刻度轴刻度在年边界上是不规则的

时间:2014-01-23 00:24:15

标签: d3.js

更新bl.ocks.org example已使用解决方案进行了更新。

在计算刻度位置时,是否可以使时间刻度轴的默认刻度生成器忽略月份和年份边界?

this bl.ocks.org example所示,当一个带有日期标记的D3时标轴跨越一年结束时,默认的标记生成器有时会绘制不规则间距的标记。此代码(也在上面的要点中)导致一个轴,每两天除了12月31日和1月1日之间的间隔,这两个都被绘制,导致不规则的外观。我用红色突出显示了不合需要的刻度标签。

<!DOCTYPE html>
<meta charset="utf-8">
<style>
  p { width: 600px; margin-bottom: 30px; }
  .chart { shape-rendering: crispEdges; }
  .axis text { font: 10px sans-serif; }
  .axis line, .axis path { fill: none; stroke: black; }
</style>
<body>
<script src="http://d3js.org/d3.v3.min.js"></script>
<script>

var start_date = "2013-12-21T00:00:00Z",
    end_date   = "2014-01-07T00:00:00Z",
    iso        = d3.time.format.iso,
    t1         = iso.parse(start_date),
    t2         = iso.parse(end_date),

var margin = {top: 0, right: 10, bottom: 20, left: 10},
    width  = 600 - margin.left - margin.right,
    height = 100 - margin.top - margin.bottom;

var x = d3.time.scale()
    .domain([t1, t2])
    .range([0, width])

var xAxis = d3.svg.axis()
    .scale(x)

var svg = d3.select("body").append("svg")
    .attr("class", "chart")
    .attr("width", width + margin.left + margin.right)
    .attr("height", height + margin.top + margin.bottom)
  .append("g")
    .attr("transform", "translate(" + margin.left + "," + margin.top + ")");

svg.append('g')
    .attr('class', 'x axis')
    .call(xAxis)
  .selectAll('text')
    .attr('fill', function(d) { if(is_problematic(d)) { return "red"; } })

function is_problematic(d) {
  return ((d.getDate() == 31) || (d.getDate() == 1));
}

1 个答案:

答案 0 :(得分:2)

如果您明确设置了刻度值,您将避免在年度舍入问题中出现奇怪的结局:

var xAxis = d3.svg.axis()
    .scale(x)
    .tickValues(d3.time.days(t1, t2).filter(function(d, i){ return !(i % 2); }))

fixed