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.

268 lines
8.1 KiB

11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
  1. <!doctype html>
  2. <html>
  3. <head>
  4. <title>Graph | Random nodes</title>
  5. <style type="text/css">
  6. body {
  7. font: 10pt sans;
  8. }
  9. #mygraph {
  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. div.graph-manipulationDiv {
  34. border-width:0px;
  35. border-bottom: 1px;
  36. border-style:solid;
  37. border-color: #d6d9d8;
  38. background: #ffffff; /* Old browsers */
  39. background: -moz-linear-gradient(top, #ffffff 0%, #f3f3f3 50%, #ededed 51%, #ffffff 100%); /* FF3.6+ */
  40. background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffffff), color-stop(50%,#f3f3f3), color-stop(51%,#ededed), color-stop(100%,#ffffff)); /* Chrome,Safari4+ */
  41. background: -webkit-linear-gradient(top, #ffffff 0%,#f3f3f3 50%,#ededed 51%,#ffffff 100%); /* Chrome10+,Safari5.1+ */
  42. background: -o-linear-gradient(top, #ffffff 0%,#f3f3f3 50%,#ededed 51%,#ffffff 100%); /* Opera 11.10+ */
  43. background: -ms-linear-gradient(top, #ffffff 0%,#f3f3f3 50%,#ededed 51%,#ffffff 100%); /* IE10+ */
  44. background: linear-gradient(to bottom, #ffffff 0%,#f3f3f3 50%,#ededed 51%,#ffffff 100%); /* W3C */
  45. filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#ffffff',GradientType=0 ); /* IE6-9 */
  46. width: 600px;
  47. height:30px;
  48. z-index:10;
  49. position:absolute;
  50. }
  51. span.manipulationUI {
  52. -moz-border-radius: 15px;
  53. border-radius: 15px;
  54. display:inline-block;
  55. background-position: 4px 0px;
  56. background-repeat:no-repeat;
  57. height:24px;
  58. margin: -14px 0px 0px 10px;
  59. vertical-align:middle;
  60. cursor: pointer;
  61. padding: 0px 8px 0px 8px;
  62. -webkit-touch-callout: none;
  63. -webkit-user-select: none;
  64. -khtml-user-select: none;
  65. -moz-user-select: none;
  66. -ms-user-select: none;
  67. user-select: none;
  68. }
  69. span.manipulationUI:hover {
  70. box-shadow: 1px 1px 8px rgba(0, 0, 0, 0.20);
  71. }
  72. span.manipulationUI:active {
  73. box-shadow: 1px 1px 8px rgba(0, 0, 0, 0.50);
  74. }
  75. span.manipulationUI.back {
  76. background-image: url("../../dist/img/backIcon.png");
  77. }
  78. span.manipulationUI.none:hover {
  79. box-shadow: 1px 1px 8px rgba(0, 0, 0, 0.0);
  80. cursor: default;
  81. }
  82. span.manipulationUI.none:active {
  83. box-shadow: 1px 1px 8px rgba(0, 0, 0, 0.0);
  84. }
  85. span.manipulationUI.add {
  86. background-image: url("../../dist/img/addNodeIcon.png");
  87. }
  88. span.manipulationUI.connect {
  89. background-image: url("../../dist/img/connectIcon.png");
  90. }
  91. span.manipulationUI.delete {
  92. background-image: url("../../dist/img/deleteIcon.png");
  93. }
  94. /* top right bottom left */
  95. span.manipulationLabel {
  96. margin: 0px 0px 0px 25px;
  97. line-height: 25px;
  98. }
  99. div.seperatorLine {
  100. display:inline-block;
  101. width:1px;
  102. height:20px;
  103. background-color: #bdbdbd;
  104. margin: 5px 7px 0px 15px;
  105. }
  106. </style>
  107. <script type="text/javascript" src="../../dist/vis.js"></script>
  108. <script type="text/javascript">
  109. var nodes = null;
  110. var edges = null;
  111. var graph = null;
  112. function draw() {
  113. nodes = [];
  114. edges = [];
  115. var connectionCount = [];
  116. // randomly create some nodes and edges
  117. var nodeCount = document.getElementById('nodeCount').value;
  118. for (var i = 0; i < nodeCount; i++) {
  119. nodes.push({
  120. id: i,
  121. label: String(i)
  122. });
  123. connectionCount[i] = 0;
  124. // create edges in a scale-free-graph way
  125. if (i == 1) {
  126. var from = i;
  127. var to = 0;
  128. edges.push({
  129. from: from,
  130. to: to
  131. });
  132. connectionCount[from]++;
  133. connectionCount[to]++;
  134. }
  135. else if (i > 1) {
  136. var conn = edges.length * 2;
  137. var rand = Math.floor(Math.random() * conn);
  138. var cum = 0;
  139. var j = 0;
  140. while (j < connectionCount.length && cum < rand) {
  141. cum += connectionCount[j];
  142. j++;
  143. }
  144. var from = i;
  145. var to = j;
  146. edges.push({
  147. from: from,
  148. to: to
  149. });
  150. connectionCount[from]++;
  151. connectionCount[to]++;
  152. }
  153. }
  154. // create a graph
  155. var container = document.getElementById('mygraph');
  156. var data = {
  157. nodes: nodes,
  158. edges: edges
  159. };
  160. /*
  161. var options = {
  162. nodes: {
  163. shape: 'circle'
  164. },
  165. edges: {
  166. length: 50
  167. },
  168. stabilize: false
  169. };
  170. */
  171. var options = {
  172. edges: {
  173. length: 50
  174. },
  175. stabilize: false,
  176. navigationUI: {
  177. enabled: true
  178. },
  179. keyboardNavigation: {
  180. enabled: true
  181. }
  182. };
  183. graph = new vis.Graph(container, data, options);
  184. // add event listeners
  185. vis.events.addListener(graph, 'select', function(params) {
  186. document.getElementById('selection').innerHTML =
  187. 'Selection: ' + JSON.stringify(graph.getSelection());
  188. });
  189. }
  190. </script>
  191. </head>
  192. <body onload="draw();">
  193. <h2>UI - User Interface and Keyboad Navigation</h2>
  194. <div style="width: 700px; font-size:14px;">
  195. This example is the same as example 2, except for the UI that has been activated. The UI icons are described below. <br /><br />
  196. <table class="legend_table">
  197. <tr>
  198. <td>Icons: </td>
  199. <td><div class="table_content"><img src="../../dist/img/uparrow.png" /> </div></td>
  200. <td><div class="table_content"><img src="../../dist/img/downarrow.png" /> </div></td>
  201. <td><div class="table_content"><img src="../../dist/img/leftarrow.png" /> </div></td>
  202. <td><div class="table_content"><img src="../../dist/img/rightarrow.png" /> </div></td>
  203. <td><div class="table_content"><img src="../../dist/img/plus.png" /> </div></td>
  204. <td><div class="table_content"><img src="../../dist/img/minus.png" /> </div></td>
  205. <td><div class="table_content"><img src="../../dist/img/zoomExtends.png" /> </div></td>
  206. </tr>
  207. <tr>
  208. <td><div class="table_description">Keyboard shortcuts:</div></td>
  209. <td><div class="table_content">Up arrow</div></td>
  210. <td><div class="table_content">Down arrow</div></td>
  211. <td><div class="table_content">Left arrow</div></td>
  212. <td><div class="table_content">Right arrow</div></td>
  213. <td><div class="table_content">=<br />[<br />Page up</div></td>
  214. <td><div class="table_content">-<br />]<br />Page down</div></td>
  215. <td><div class="table_content">None</div></td>
  216. </tr>
  217. <td><div class="table_description">Description:</div></td>
  218. <td><div class="table_content">Move up</div></td>
  219. <td><div class="table_content">Move down</div></td>
  220. <td><div class="table_content">Move left</div></td>
  221. <td><div class="table_content">Move right</div></td>
  222. <td><div class="table_content">Zoom in</div></td>
  223. <td><div class="table_content">Zoom out</div></td>
  224. <td><div class="table_content">Zoom extends</div></td>
  225. </tr>
  226. </table>
  227. <br />
  228. Apart from clicking the icons, you can also navigate using the keyboard. The buttons are in table above.
  229. Zoom Extends changes the zoom and position of the camera to encompass all visible nodes.
  230. </div>
  231. <br />
  232. <form onsubmit="draw(); return false;">
  233. <label for="nodeCount">Number of nodes:</label>
  234. <input id="nodeCount" type="text" value="25" style="width: 50px;">
  235. <input type="submit" value="Go">
  236. </form>
  237. <br>
  238. <div id="mygraph"></div>
  239. <p id="selection"></p>
  240. </body>
  241. </html>