gpt4 book ai didi

javascript - D3 中带有日期的简单折线图

转载 作者:行者123 更新时间:2023-11-29 09:53:16 24 4
gpt4 key购买 nike

我正在尝试掌握 D3,并想绘制一个简单的折线图演示,其中沿 x 轴为 7 天。到目前为止我有 http://jsfiddle.net/wRDXt/1/

// Define the resolution
var width = 500;
var height = 250;

// Create the SVG 'canvas'
var svg = d3.select("body")
.append("svg")
.attr("viewBox", "0 0 " + width + " " + height)

// get the data
var dataset = [
{ date: new Date(2013, 17, 1), value: 1 },
{ date: new Date(2013, 17, 2), value: 2 },
{ date: new Date(2013, 17, 3), value: 3 },
{ date: new Date(2013, 17, 4), value: 4 },
{ date: new Date(2013, 17, 5), value: 5 },
{ date: new Date(2013, 17, 6), value: 6 },
{ date: new Date(2013, 17, 7), value: 7 }
];

// Define the padding around the graph
var padding = 50;

// Set the scales

var minDate = d3.min(dataset, function(d) { return d.date; });
minDate.setDate(minDate.getDate() - 1);
var maxDate = d3.max(dataset, function(d) { return d.date; });

var xScale = d3.scale.linear()
.domain([minDate, maxDate])
.range([padding, width - padding]);

var yScale = d3.scale.linear()
.domain([0, d3.max(dataset, function(d) { return d.value; })])
.range([height - padding, padding]);

// x-axis
var xAxis = d3.svg.axis()
.scale(xScale)
.orient("bottom")
.tickFormat("todo")
.tickSize(5, 5, 0)

svg.append("g")
.attr("class", "axis x-axis")
.attr("transform", "translate(0," + (height - padding) + ")")
.call(xAxis);

// y-axis
var yAxis = d3.svg.axis()
.scale(yScale)
.orient("left")
.tickFormat(function (d) { return d; })
.tickSize(5, 5, 0)
.ticks(5); // set rough # of ticks

svg.append("g")
.attr("class", "axis y-axis")
.attr("transform", "translate(" + padding + ",0)")
.call(yAxis);

// Scatter plot
svg.selectAll("circle")
.data(dataset)
.enter()
.append("circle")
.attr("class", "data-point")
.attr("cx", function(d) {
return xScale(d.date);
})
.attr("cy", function(d) {
return yScale(d.value);
})
.attr("r", 5);

// line graph
var line = d3.svg.line()
.x(function(d) {
return xScale(d.date);
})
.y(function(d) {
return yScale(d.value);
});

svg.append("svg:path").attr("d", line(dataset));

我遇到了一些问题:

  • 如何让 x 轴每天显示一个刻度(我希望每个刻度与数据点匹配并与其对齐)
  • 线图位由于某种原因像多边形一样填充?
  • 如何很好地格式化轴上的刻度文本,使其像“1 JUL”、“2 JUL”等
  • 我如何让第一个日期值出现在第一个刻度而不是 y 轴上 - 我尝试在 minDate 上休息一天,但是如您所见,它影响了绘图

最佳答案

我已经更新了你的 jsfiddle 来做你想做的事 here .简而言之,我做了以下事情:

  • 使用时间尺度而不是线性尺度。然后您可以将 d3.time.days, 1 指定为 ticks
  • 默认情况下,路径被填充,没有描边。查看我添加的 CSS。
  • 使用具有适当格式的 .tickFormat 函数。
  • 应使用时间尺度和适当的刻度规范来修复。

关于javascript - D3 中带有日期的简单折线图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17710371/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com