I use Ploty js-lib to draw three-dimensional graphs. My plan is to draw 4 tracks into one 3D plot. But I come across some weird behavior on my website when I try to do this.
Sometimes, when I load my site, I donโt get an error, and all 4 tracks load perfectly in my 3D graphics. But another time, not all of my tracks are loaded into my schedule, and I get an error:
Error: gd.data must be an array.
This is my function to add traces from the csv file:
function addTraceFromCSVdarkColor(divname,link)
{
Plotly.d3.csv(link, function(err, rows)
{
function unpack1(rows, key)
{
return rows.map(function(row) { return row[key]; });
}
var trace1 = {
x: unpack1(rows, 'x'),
y: unpack1(rows, 'y'),
z: unpack1(rows, 'z'),
mode: 'lines',
type: 'scatter3d',
opacity: 0.5,
line:
{
color: 'rgb(252, 185, 0)',
size: 2,
opacity: 0.5
}
};
var data = [trace1];
Plotly.addTraces(divname,data);
});
}
And this is how I create a 3D graph:
unction print3DMultiGraphMain(divname,link)
{
Plotly.d3.csv(link, function(err, rows)
{
function unpack1(rows, key)
{
return rows.map(function(row) { return row[key]; });
}
var trace1 = {
x: unpack1(rows, 'x'),
y: unpack1(rows, 'y'),
z: unpack1(rows, 'z'),
mode: 'lines',
type: 'scatter3d',
line:
{
color: 'rgb(252, 185, 0)',
size: 2
}
};
var data = [trace1];
var layout = {
autorange: false,
width: 800,
height: 800,
scene:
{
aspectratio:
{
x: 1,
y: 1,
z: 1
},
x: 0,
y: 0,
camera:
{
center:
{
z: 0
},
eye:
{
x: 1.25,
y: 1.25,
z: 1.25
},
up:
{
x: 0,
y: 0,
z: 1
}
},
xaxis:
{
type: 'linear',
range: [0, 200],
zeroline: false
},
yaxis:
{
type: 'linear',
zeroline: false,
range: [0, 200]
},
zaxis:
{
type: 'linear',
zeroline: false,
range: [0, 200]
}
},
};
Plotly.newPlot(divname, data, layout,{displayModeBar: false});
});
}
And this is how I call the functions in my html file:
<script>
print3DMultiGraphMain('tester','out1.csv');
addTraceFromCSVlightColor('tester','out2.csv');
addTraceFromCSVdarkColor('tester','out3.csv');
addTraceFromCSVlightColor('tester','out4.csv');
</script>