You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
70 lines
2.2 KiB
70 lines
2.2 KiB
### html ### |
|
|
|
<h4>CurvedLines: customizing and mixing</h4> |
|
|
|
<div class="text-block"> <span id="hoverText">point at: - / -</span> |
|
|
|
</div> |
|
<div id="flotContainer" class="chart-style"></div> |
|
<div class="text-block">The example shows two datasets (d1, d2) plotted using different styles (curved line, points, bigger points). The points are hoverable, the curved line is not.</div> |
|
<div class="text-block">To achieve such mixed plots you have to define some settings on a per series level. In the example the curved line plugin is generally set to active (as default in the options object) but will be applied only to the first series. Similarly hovering is deactivated for the first series. The combination of "replotting" (series 1 and 2 both origin form dataset d1) and per series settings allows you to mix different plotting styles and settings in one canvas.</div> |
|
|
|
### css ### |
|
|
|
.chart-style { |
|
width: 600px; |
|
height: 340px; |
|
margin-bottom: 15px; |
|
} |
|
.text-block { |
|
margin-bottom: 15px; |
|
} |
|
|
|
### javascript ### |
|
|
|
//some random data |
|
var d1 = []; var last = 0; |
|
for (var i = 0; i <= 40; i += (2 + parseInt(Math.random() * 5))) { |
|
last = last + ((Math.random() * 3) - 1.5) |
|
d1.push([i, parseInt(last)]); |
|
} |
|
|
|
var d2 = []; |
|
for (var i = 2; i <= $(d1).get(-1)[0]; i += (2 + parseInt(Math.random() * 5))) { |
|
d2.push([i, parseInt(Math.random() * 8)]); |
|
} |
|
|
|
|
|
//default flot options |
|
var options = { |
|
series: { curvedLines: { active: true } }, |
|
grid: { hoverable: true } // <- generally activate hover |
|
}; |
|
|
|
|
|
//plotting with per series adjustments |
|
$.plot($("#flotContainer"), [ |
|
{ //series 1 |
|
data: d1, |
|
lines: { show: true, lineWidth: 3 }, |
|
hoverable: false, // <- overwrite hoverable with false |
|
curvedLines: { |
|
apply: true // <- set apply <- curve only this data series |
|
} |
|
}, { //series 2 |
|
data: d1, |
|
points: { show: true } |
|
}, { //series 3 |
|
data: d2, |
|
points: { show: true, radius: 5 } |
|
}], options); |
|
|
|
|
|
//adding hover text |
|
$("#flotContainer").bind("plothover", function (event, pos, item) { |
|
if (item) { |
|
$("#hoverText").text("point at: " + pos.x.toFixed(2) + " / " + pos.y.toFixed(2)) |
|
} else { |
|
$("#hoverText").text("point at: - / -") |
|
} |
|
}); |