vis.js is a dynamic, browser-based visualization library

86 lines
2.9 KiB

  1. <!DOCTYPE HTML>
  2. <html>
  3. <head>
  4. <title>Graph2d | Bar Graphs Side by Side Example with Groups</title>
  5. <style type="text/css">
  6. body, html {
  7. font-family: sans-serif;
  8. }
  9. </style>
  10. <script src="../../dist/vis.js"></script>
  11. <link href="../../dist/vis.css" rel="stylesheet" type="text/css" />
  12. </head>
  13. <body>
  14. <h2>Graph2d | Bar Graphs Side by Side Example with Groups</h2>
  15. <div style="width:700px; font-size:14px; text-align: justify;">
  16. When using Bar graphs, it can often be the case that there are multiple bars on the same timepoint. This may not always be the desired result. You can use the
  17. barChart.handleOverlap option to automatically plot the bars next to eachother or stacked on top of eachother if they occupy the same timeslot. By default, this option is on, the bars overlap.
  18. Use the dropdown box to experiment with the options. The stacked only really makes sense when using groups as is shown here.
  19. <br /><br />
  20. Handle overlap: <select id="dropdownID">
  21. <option value="overlap">overlap</option>
  22. <option value="sideBySide" selected="selected">sideBySide</option>
  23. <option value="stack">stack</option>
  24. </select>
  25. </div>
  26. <br />
  27. <div id="visualization"></div>
  28. <script type="text/javascript">
  29. var container = document.getElementById('visualization');
  30. var groups = new vis.DataSet();
  31. groups.add({id: 0, content: "group0"})
  32. groups.add({id: 1, content: "group1"})
  33. groups.add({id: 2, content: "group2"})
  34. var items = [
  35. {x: '2014-06-11', y: 10, group:0},
  36. {x: '2014-06-12', y: 25, group:0},
  37. {x: '2014-06-13', y: 30, group:0},
  38. {x: '2014-06-14', y: 10, group:0},
  39. {x: '2014-06-15', y: 15, group:0},
  40. {x: '2014-06-16', y: 30, group:0},
  41. {x: '2014-06-11', y: 12, group:1},
  42. {x: '2014-06-12', y: 15, group:1},
  43. {x: '2014-06-13', y: 34, group:1},
  44. {x: '2014-06-14', y: 24, group:1},
  45. {x: '2014-06-15', y: 5, group:1},
  46. {x: '2014-06-16', y: 12, group:1},
  47. {x: '2014-06-11', y: 22, group:2},
  48. {x: '2014-06-12', y: 14, group:2},
  49. {x: '2014-06-13', y: 24, group:2},
  50. {x: '2014-06-14', y: 21, group:2},
  51. {x: '2014-06-15', y: 30, group:2},
  52. {x: '2014-06-16', y: 18, group:2}
  53. ];
  54. var dataset = new vis.DataSet(items);
  55. var options = {
  56. style:'bar',
  57. barChart: {width:50, align:'center', handleOverlap:'sideBySide'}, // align: left, center, right
  58. drawPoints: false,
  59. dataAxis: {
  60. icons:true
  61. },
  62. orientation:'top',
  63. start: '2014-06-10',
  64. end: '2014-06-18'
  65. };
  66. var graph2d = new vis.Graph2d(container, items, groups, options);
  67. var dropdown = document.getElementById("dropdownID");
  68. dropdown.onchange = update;
  69. function update() {
  70. var options = {barChart:{handleOverlap:dropdown.value}};
  71. graph2d.setOptions(options);
  72. }
  73. </script>
  74. </body>
  75. </html>