vis.js is a dynamic, browser-based visualization library
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.

114 lines
3.3 KiB

  1. <!doctype html>
  2. <html>
  3. <head>
  4. <title>Network | Hierarchical layout</title>
  5. <style type="text/css">
  6. body {
  7. font: 10pt sans;
  8. }
  9. #mynetwork {
  10. width: 600px;
  11. height: 600px;
  12. border: 1px solid lightgray;
  13. }
  14. </style>
  15. <script type="text/javascript" src="../exampleUtil.js"></script>
  16. <script type="text/javascript" src="../../../dist/vis.js"></script>
  17. <link href="../../../dist/vis.css" rel="stylesheet" type="text/css"/>
  18. <script type="text/javascript">
  19. var nodes = null;
  20. var edges = null;
  21. var network = null;
  22. function destroy() {
  23. if (network !== null) {
  24. network.destroy();
  25. network = null;
  26. }
  27. }
  28. function draw() {
  29. destroy();
  30. // randomly create some nodes and edges
  31. var nodeCount = document.getElementById('nodeCount').value;
  32. var data = getScaleFreeNetwork(nodeCount)
  33. // create a network
  34. var container = document.getElementById('mynetwork');
  35. var directionInput = document.getElementById("direction").value;
  36. var options = {
  37. layout: {
  38. hierarchical: {
  39. direction: directionInput
  40. }
  41. }
  42. };
  43. network = new vis.Network(container, data, options);
  44. // add event listeners
  45. network.on('select', function (params) {
  46. document.getElementById('selection').innerHTML = 'Selection: ' + params.nodes;
  47. });
  48. }
  49. </script>
  50. <script src="../googleAnalytics.js"></script>
  51. </head>
  52. <body onload="draw();">
  53. <h2>Hierarchical Layout - Scale-Free-Network</h2>
  54. <div style="width:700px; font-size:14px; text-align: justify;">
  55. This example shows the randomly generated <b>scale-free-network</b> set of nodes and connected edges from example 2.
  56. In this example, hierarchical layout has been enabled and the vertical levels are determined automatically.
  57. </div>
  58. <br/>
  59. <form onsubmit="draw(); return false;">
  60. <label for="nodeCount">Number of nodes:</label>
  61. <input id="nodeCount" type="text" value="25" style="width: 50px;">
  62. <input type="submit" value="Go">
  63. </form>
  64. <p>
  65. <input type="button" id="btn-UD" value="Up-Down">
  66. <input type="button" id="btn-DU" value="Down-Up">
  67. <input type="button" id="btn-LR" value="Left-Right">
  68. <input type="button" id="btn-RL" value="Right-Left">
  69. <input type="hidden" id='direction' value="UD">
  70. </p>
  71. <script language="javascript">
  72. var directionInput = document.getElementById("direction");
  73. var btnUD = document.getElementById("btn-UD");
  74. btnUD.onclick = function () {
  75. directionInput.value = "UD";
  76. draw();
  77. }
  78. var btnDU = document.getElementById("btn-DU");
  79. btnDU.onclick = function () {
  80. directionInput.value = "DU";
  81. draw();
  82. };
  83. var btnLR = document.getElementById("btn-LR");
  84. btnLR.onclick = function () {
  85. directionInput.value = "LR";
  86. draw();
  87. };
  88. var btnRL = document.getElementById("btn-RL");
  89. btnRL.onclick = function () {
  90. directionInput.value = "RL";
  91. draw();
  92. };
  93. </script>
  94. <br>
  95. <div id="mynetwork"></div>
  96. <p id="selection"></p>
  97. </body>
  98. </html>