gpt4 book ai didi

javascript - D3JS折线图倒置问题

转载 作者:行者123 更新时间:2023-12-02 17:37:11 25 4
gpt4 key购买 nike

我正在尝试根据输入的 JSON 数据动态生成折线图:

这是我的 JS 代码:

d3.json("../js/sample2.json", function(data) {
var dataArray = new Array(), k = 0, j = 0, dataArraySize = 0, line, positionNumber,
canvas = d3.select("body").append("svg")
.attr("width", 1000)
.attr("height", 1000)
.attr("border", "black")

heightScale = d3.scale.linear()
.domain([0, 250])
.range([300, 0]);

widthScale = d3.scale.linear()
.domain([0, 200])
.range([0, 700]);

Yaxis = d3.svg.axis()
.ticks(5)
.scale(heightScale)
.orient("left");

Xaxis = d3.svg.axis()
.ticks(10)
.scale(widthScale)
.orient("bottom");

jsonLength = Object.keys(data).length;

group = canvas.append("g")
.attr("class", "grp")
.attr("transform", "translate(100,10)");

// Conversion of JSON data to appropriate data format
for (j = 0; j < jsonLength; j += 2) {
var innerObjArray = new Array();
positionNumber = Object.keys(data[j].position).length;
for (k = 0; k < positionNumber; k++) {
var obj = {};
obj.x = data[j].position[k];
obj.y = data[j + 1].position[k];
innerObjArray.push(obj);
}
dataArray.push(innerObjArray);
}
console.log(dataArray);
dataArraySize = dataArray.length;

//Graphical representation of the dataArray
line = d3.svg.line()
.x(function(d) {
return d.x;
})
.y(function(d) {
return d.y;
});
for (k = 0; k < dataArraySize; k++) {
d3.select(".grp")
.append("path")
.attr("d", line(dataArray[k]))
// .attr("transform", "translate(100,10)")
.attr("fill", "none")
.attr("stroke", "hsl(" + Math.random() * 360 + ",50%,50%)")
.attr("stroke-width", 3);
console.log(dataArray[k]);
}

group.append("g")
.attr("transform", "translate(0, 300 )")
.call(Xaxis)


group.append("g")
.call(Yaxis)
.attr("transform", "translate(0,0)");
});

我已经给了

 heightScale = d3.scale.linear()
.domain([0, 250])
.range([300, 0]);

我认为这会起作用,但没有。

这是我的JSON 数据:

     [{"name": "x1", 
"position":[0,60,80,100,200]
},

{"name": "y1",
"position":[0,190,220,160,240]
},

{"name": "x2",
"position":[0,60,80,100,200]
},

{"name": "y2",
"position":[10,90,20,60,40]},

{"name": "x3",
"position":[30,50,70,90,150]
},

{"name": "y3",
"position":[20,160,170,160,150]}]

这是我目前的输出 This is currently my output

现在图表从 (200,240) 位置开始..

图表目前是倒置的,因为我在第一行的 (0,0) 处开始,在 (200,240) 处结束,依此类推。(通过 JSON 数据输入)

最佳答案

您忘记使用已定义的比例,因此使用 svg 坐标系(从左上角开始(0,0)开始绘制项目。

因此,在定义线条时,请使用return widthScale(d.x),而不仅仅是return d.x等等

line = d3.svg.line()
.x(function(d) {
return widthScale(d.x);
})
.y(function(d) {
return heightScale(d.y);
});

查看此JSFiddle我认为您所期待的。

Fixed chart

关于javascript - D3JS折线图倒置问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22530182/

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