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

168 lines
5.2 KiB

  1. <!doctype html>
  2. <html>
  3. <head>
  4. <title>Network | Navigation</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. table.legend_table {
  15. font-size: 11px;
  16. border-width:1px;
  17. border-color:#d3d3d3;
  18. border-style:solid;
  19. }
  20. table.legend_table,td {
  21. border-width:1px;
  22. border-color:#d3d3d3;
  23. border-style:solid;
  24. padding: 2px;
  25. }
  26. div.table_content {
  27. width:80px;
  28. text-align:center;
  29. }
  30. div.table_description {
  31. width:100px;
  32. }
  33. </style>
  34. <script type="text/javascript" src="../../dist/vis.js"></script>
  35. <link type="text/css" rel="stylesheet" href="../../dist/vis.css">
  36. <script type="text/javascript">
  37. var nodes = null;
  38. var edges = null;
  39. var network = null;
  40. function draw() {
  41. nodes = [];
  42. edges = [];
  43. var connectionCount = [];
  44. // randomly create some nodes and edges
  45. var nodeCount = document.getElementById('nodeCount').value;
  46. for (var i = 0; i < nodeCount; i++) {
  47. nodes.push({
  48. id: i,
  49. label: String(i)
  50. });
  51. connectionCount[i] = 0;
  52. // create edges in a scale-free-network way
  53. if (i == 1) {
  54. var from = i;
  55. var to = 0;
  56. edges.push({
  57. from: from,
  58. to: to
  59. });
  60. connectionCount[from]++;
  61. connectionCount[to]++;
  62. }
  63. else if (i > 1) {
  64. var conn = edges.length * 2;
  65. var rand = Math.floor(Math.random() * conn);
  66. var cum = 0;
  67. var j = 0;
  68. while (j < connectionCount.length && cum < rand) {
  69. cum += connectionCount[j];
  70. j++;
  71. }
  72. var from = i;
  73. var to = j;
  74. edges.push({
  75. from: from,
  76. to: to
  77. });
  78. connectionCount[from]++;
  79. connectionCount[to]++;
  80. }
  81. }
  82. // create a network
  83. var container = document.getElementById('mynetwork');
  84. var data = {
  85. nodes: nodes,
  86. edges: edges
  87. };
  88. var options = {
  89. stabilize: false,
  90. navigation: true,
  91. keyboard: true
  92. };
  93. network = new vis.Network(container, data, options);
  94. // add event listeners
  95. network.on('select', function(params) {
  96. document.getElementById('selection').innerHTML = 'Selection: ' + params.nodes;
  97. });
  98. }
  99. </script>
  100. </head>
  101. <body onload="draw();">
  102. <h2>Navigation controls and keyboad navigation</h2>
  103. <div style="width: 800px; font-size:14px; text-align: justify;">
  104. This example is the same as example 2, except for the navigation controls that have been activated. The navigation controls are described below. <br /><br />
  105. <table class="legend_table">
  106. <tr>
  107. <td>Icons: </td>
  108. <td><div class="table_content"><img src="../../dist/img/network/upArrow.png" /> </div></td>
  109. <td><div class="table_content"><img src="../../dist/img/network/downArrow.png" /> </div></td>
  110. <td><div class="table_content"><img src="../../dist/img/network/leftArrow.png" /> </div></td>
  111. <td><div class="table_content"><img src="../../dist/img/network/rightArrow.png" /> </div></td>
  112. <td><div class="table_content"><img src="../../dist/img/network/plus.png" /> </div></td>
  113. <td><div class="table_content"><img src="../../dist/img/network/minus.png" /> </div></td>
  114. <td><div class="table_content"><img src="../../dist/img/network/zoomExtends.png" /> </div></td>
  115. </tr>
  116. <tr>
  117. <td><div class="table_description">Keyboard shortcuts:</div></td>
  118. <td><div class="table_content">Up arrow</div></td>
  119. <td><div class="table_content">Down arrow</div></td>
  120. <td><div class="table_content">Left arrow</div></td>
  121. <td><div class="table_content">Right arrow</div></td>
  122. <td><div class="table_content">=<br />[<br />Page up</div></td>
  123. <td><div class="table_content">-<br />]<br />Page down</div></td>
  124. <td><div class="table_content">None</div></td>
  125. </tr>
  126. <tr>
  127. <td><div class="table_description">Description:</div></td>
  128. <td><div class="table_content">Move up</div></td>
  129. <td><div class="table_content">Move down</div></td>
  130. <td><div class="table_content">Move left</div></td>
  131. <td><div class="table_content">Move right</div></td>
  132. <td><div class="table_content">Zoom in</div></td>
  133. <td><div class="table_content">Zoom out</div></td>
  134. <td><div class="table_content">Zoom extent</div></td>
  135. </tr>
  136. </table>
  137. <br />
  138. Apart from clicking the icons, you can also navigate using the keyboard. The buttons are in table above.
  139. Zoom Extends changes the zoom and position of the camera to encompass all visible nodes. <u>To correctly display the navigation icons, the <b>vis.css</b> file must be included.</u>
  140. The user is free to alter or overload the CSS classes but without them the navigation icons are not visible.
  141. </div>
  142. <br />
  143. <form onsubmit="draw(); return false;">
  144. <label for="nodeCount">Number of nodes:</label>
  145. <input id="nodeCount" type="text" value="25" style="width: 50px;">
  146. <input type="submit" value="Go">
  147. </form>
  148. <br>
  149. <div id="mynetwork"></div>
  150. <p id="selection"></p>
  151. </body>
  152. </html>