我正在使用这个多线图,但到目前为止未能在每个刻度(每天)上生成数据值标签。
<script>
var margin = {top: 30, right: 40, bottom: 30, left: 50},
width = 600 - margin.left - margin.right,
height = 270 - margin.top - margin.bottom;
var parseDate = d3.time.format("%d-%m-%y").parse;
var x = d3.time.scale().range([0, width]);
var y = d3.scale.linear().range([height, 0]);
var xAxis = d3.svg.axis().scale(x)
.orient("bottom").ticks(7);
var yAxis = d3.svg.axis().scale(y)
.orient("left").ticks(7);
var valueline = d3.svg.line()
.x(function(d) { return x(d.date); })
.y(function(d) { return y(d.sev3); });
var valueline2 = d3.svg.line()
.x(function(d) { return x(d.date); })
.y(function(d) { return y(d.sev4); });
var svg = d3.select("body")
.append("svg")
.attr("width", width + margin.left + margin.right)
.attr("height", height + margin.top + margin.bottom)
.append("g")
.attr("transform", "translate(" + margin.left + "," + margin.top + ")");
// Get the data
d3.csv("data.tsv", function(error, data) {
data.forEach(function(d) {
d.date = parseDate(d.date);
d.sev3 = +d.sev3;
d.sev4 = +d.sev4;
});
// Scale the range of the data
x.domain(d3.extent(data, function(d) { return d.date; }));
y.domain([0, d3.max(data, function(d) { return Math.max(d.sev3, d.sev4); })]);
svg.append("path") // Add the valueline path.
.attr("class", "line")
.attr("d", valueline(data));
svg.append("path") // Add the valueline2 path.
.attr("class", "line")
.style("stroke", "red")
.attr("d", valueline2(data));
svg.append("g") // Add the X Axis
.attr("class", "x axis")
.attr("transform", "translate(0," + height + ")")
.call(xAxis);
svg.append("g") // Add the Y Axis
.attr("class", "y axis")
.call(yAxis);
svg.append("text")
.attr("transform", "translate(" + (width+3) + "," + y(data[0].sev4) + ")")
.attr("dy", ".35em")
.attr("text-anchor", "start")
.style("fill", "red")
.text("Sev4");
svg.append("text")
.attr("transform", "translate(" + (width+3) + "," + y(data[0].sev3) + ")")
.attr("dy", ".35em")
.attr("text-anchor", "start")
.style("fill", "steelblue")
.text("Sev3");
});
</script>
Run Code Online (Sandbox Code Playgroud)
数据.tsv
date,sev3,sev4
20-02-15,0,0
19-02-15,0,0
18-02-15,0,0
17-02-15,481,200
16-02-15,691,200
15-02-15,296,200
14-02-15,307,200
Run Code Online (Sandbox Code Playgroud)
上面的代码给出了这个:

这就是我想要完成的
我知道我必须使用 .append("text") 并将文本定位在与数据点大致相同的 x,y 坐标处,并从数据中提取值以输入“文本”,但我在整合方面遇到困难那个概念。
我怀疑选择会发生在 valueline.append 吗?我查看了一堆示例,我不认为存在带有数据值标签的折线图,如果确实存在,请指点我:)
有什么想法吗 ?
您的文本将不可见,因为它位于 svg 的边界之外:您添加了一个由 margin.left 翻译的组,并将您的 x 放在宽度 + 3 处,这意味着位于宽度 + 3 + 边距处。 svg 左边框的左侧。
尝试用以下内容替换您的附加文本:
svg.append("text")
.attr("transform", "translate(" + (width/2) + "," + y(data[0].sev4) + ")")
.attr("dy", ".35em")
.attr("text-anchor", "start")
.style("fill", "red")
.text("Sev4");
svg.append("text")
.attr("transform", "translate(" + (width/2) + "," + y(data[0].sev3) + ")")
.attr("dy", ".35em")
.attr("text-anchor", "start")
.style("fill", "steelblue")
.text("Sev3");
Run Code Online (Sandbox Code Playgroud)
我没有测试它,所以我不能保证,但你的代码看起来很好,这是我唯一看到的。
添加的结果: 
编辑
在您澄清之后,这里有一个 plunk:http ://plnkr.co/edit/lDlseqUQQXgoFwTK5Aop? p= preview
你会感兴趣的部分是:
svg.append('g')
.classed('labels-group', true)
.selectAll('text')
.data(data)
.enter()
.append('text')
.classed('label', true)
.attr({
'x': function(d, i) {
return x(d.date);
},
'y': function(d, i) {
return y(d.sev3);
}
})
.text(function(d, i) {
return d.sev3;
});
Run Code Online (Sandbox Code Playgroud)
这将绘制您的标签。这是你试图达到的结果吗?
| 归档时间: |
|
| 查看次数: |
5858 次 |
| 最近记录: |