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

332 lines
11 KiB

  1. <!doctype html>
  2. <html>
  3. <head>
  4. <title>Network | Animation</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. div.left {
  15. position:relative;
  16. float:left;
  17. width:300px;
  18. border: 1px #c7c7c7 solid;
  19. height:590px;
  20. padding:5px;
  21. }
  22. div.right {
  23. padding-left:10px;
  24. float:left;
  25. width:600px;
  26. }
  27. div.bottom {
  28. position:absolute;
  29. bottom:5px;
  30. }
  31. </style>
  32. <script type="text/javascript" src="../../dist/vis.js"></script>
  33. <link href="../../dist/vis.css" rel="stylesheet" type="text/css" />
  34. <script type="text/javascript">
  35. var nodes = null;
  36. var edges = null;
  37. var network = null;
  38. var doButton, focusButton, showButton;
  39. var statusUpdateSpan;
  40. var finishMessage = '';
  41. function destroy() {
  42. if (network !== null) {
  43. network.destroy();
  44. network = null;
  45. }
  46. }
  47. function draw() {
  48. destroy();
  49. statusUpdateSpan = document.getElementById('statusUpdate');
  50. doButton = document.getElementById('btnDo');
  51. focusButton = document.getElementById('btnFocus');
  52. showButton = document.getElementById('btnShow');
  53. nodes = [];
  54. edges = [];
  55. var connectionCount = [];
  56. // randomly create some nodes and edges
  57. var nodeCount = 25;
  58. for (var i = 0; i < nodeCount; i++) {
  59. nodes.push({
  60. id: i,
  61. label: String(i)
  62. });
  63. connectionCount[i] = 0;
  64. // create edges in a scale-free-network way
  65. if (i == 1) {
  66. var from = i;
  67. var to = 0;
  68. edges.push({
  69. from: from,
  70. to: to
  71. });
  72. connectionCount[from]++;
  73. connectionCount[to]++;
  74. }
  75. else if (i > 1) {
  76. var conn = edges.length * 2;
  77. var rand = Math.floor(Math.random() * conn);
  78. var cum = 0;
  79. var j = 0;
  80. while (j < connectionCount.length && cum < rand) {
  81. cum += connectionCount[j];
  82. j++;
  83. }
  84. var from = i;
  85. var to = j;
  86. edges.push({
  87. from: from,
  88. to: to
  89. });
  90. connectionCount[from]++;
  91. connectionCount[to]++;
  92. }
  93. }
  94. // create a network
  95. var container = document.getElementById('mynetwork');
  96. var data = {
  97. nodes: nodes,
  98. edges: edges
  99. };
  100. var options = {
  101. physics: {
  102. stabilization: {
  103. iterations: 1200
  104. }
  105. }
  106. };
  107. network = new vis.Network(container, data, options);
  108. // add event listeners
  109. network.on('select', function(params) {
  110. document.getElementById('selection').innerHTML = 'Selection: ' + params.nodes;
  111. });
  112. network.on('stabilized', function (params) {
  113. document.getElementById('stabilization').innerHTML = 'Stabilization took ' + params.iterations + ' iterations.';
  114. });
  115. network.on('animationFinished', function() {
  116. statusUpdateSpan.innerHTML = finishMessage;
  117. })
  118. }
  119. function zoomExtentAnimated() {
  120. var offsetx = parseInt(document.getElementById('offsetx').value);
  121. var offsety = parseInt(document.getElementById('offsety').value);
  122. var duration = parseInt(document.getElementById('duration').value);
  123. var easingFunction = document.getElementById('easingFunction').value;
  124. var options = {offset: {x:offsetx,y:offsety},
  125. duration: duration,
  126. easingFunction: easingFunction
  127. };
  128. statusUpdateSpan.innerHTML = 'Doing ZoomExtent() Animation.';
  129. finishMessage = 'Animation finished.';
  130. network.fit(options);
  131. }
  132. function doDefaultAnimation() {
  133. var offsetx = parseInt(document.getElementById('offsetx').value);
  134. var offsety = parseInt(document.getElementById('offsety').value);
  135. var scale = parseFloat(document.getElementById('scale').value);
  136. var positionx = parseInt(document.getElementById('positionx').value);
  137. var positiony = parseInt(document.getElementById('positiony').value);
  138. var easingFunction = document.getElementById('easingFunction').value;
  139. var options = {
  140. position: {x:positionx,y:positiony},
  141. scale: scale,
  142. offset: {x:offsetx,y:offsety},
  143. animation: true // default duration is 1000ms and default easingFunction is easeInOutQuad.
  144. };
  145. statusUpdateSpan.innerHTML = 'Doing Animation.';
  146. finishMessage = 'Animation finished.';
  147. network.moveTo(options);
  148. }
  149. function doAnimation() {
  150. var offsetx = parseInt(document.getElementById('offsetx').value);
  151. var offsety = parseInt(document.getElementById('offsety').value);
  152. var duration = parseInt(document.getElementById('duration').value);
  153. var scale = parseFloat(document.getElementById('scale').value);
  154. var positionx = parseInt(document.getElementById('positionx').value);
  155. var positiony = parseInt(document.getElementById('positiony').value);
  156. var easingFunction = document.getElementById('easingFunction').value;
  157. var options = {
  158. position: {x:positionx,y:positiony},
  159. scale: scale,
  160. offset: {x:offsetx,y:offsety},
  161. animation: {
  162. duration: duration,
  163. easingFunction: easingFunction
  164. }
  165. };
  166. statusUpdateSpan.innerHTML = 'Doing Animation.';
  167. finishMessage = 'Animation finished.';
  168. network.moveTo(options);
  169. }
  170. function focusRandom() {
  171. var nodeId = Math.floor(Math.random() * 25);
  172. var offsetx = parseInt(document.getElementById('offsetx').value);
  173. var offsety = parseInt(document.getElementById('offsety').value);
  174. var duration = parseInt(document.getElementById('duration').value);
  175. var scale = parseFloat(document.getElementById('scale').value);
  176. var easingFunction = document.getElementById('easingFunction').value;
  177. var options = {
  178. // position: {x:positionx,y:positiony}, // this is not relevant when focusing on nodes
  179. scale: scale,
  180. offset: {x:offsetx,y:offsety},
  181. animation: {
  182. duration: duration,
  183. easingFunction: easingFunction
  184. }
  185. };
  186. statusUpdateSpan.innerHTML = 'Focusing on node: ' + nodeId;
  187. finishMessage = 'Node: ' + nodeId + ' in focus.';
  188. network.focus(nodeId, options);
  189. }
  190. var showInterval = false;
  191. var showPhase = 1;
  192. function startShow() {
  193. if (showInterval !== false) {
  194. showInterval = false;
  195. showButton.value = 'Start a show!';
  196. network.fit();
  197. }
  198. else {
  199. showButton.value = 'Stop the show!';
  200. var duration = parseInt(document.getElementById('duration').value);
  201. focusRandom();
  202. setTimeout(doTheShow, duration);
  203. showInterval = true;
  204. }
  205. }
  206. function doTheShow() {
  207. if (showInterval == true) {
  208. var duration = parseInt(document.getElementById('duration').value);
  209. if (showPhase == 0) {
  210. focusRandom();
  211. showPhase = 1;
  212. }
  213. else {
  214. zoomExtentAnimated();
  215. showPhase = 0;
  216. }
  217. setTimeout(doTheShow, duration);
  218. }
  219. }
  220. </script>
  221. <script src="../googleAnalytics.js"></script>
  222. </head>
  223. <body onload="draw();">
  224. <h2>Camera animations</h2>
  225. <div style="width:700px; font-size:14px;">
  226. You can move the view around programmatically using the .moveTo(options) function. The options supplied to this function can
  227. also be (partially) supplied to the .zoomExtent() and .focusOnNode() methods. These are explained in the docs.
  228. <br /><br/>
  229. The buttons below take the fields from the table when they can. For instance, the "Animate with default settings." takes the position, scale and offset while using
  230. the default animation values for duration and easing function. The focusOnNode takes everything except the position and the zoomExtent takes only the duration and easing function.
  231. <br/><br/>
  232. Here you can see a full description of the options you can supply to moveTo:
  233. </div>
  234. <pre>
  235. var moveToOptions = {
  236. position: {x:x, y:x}, // position to animate to (Numbers)
  237. scale: 1.0, // scale to animate to (Number)
  238. offset: {x:x, y:y}, // offset from the center in DOM pixels (Numbers)
  239. animation: { // animation object, can also be Boolean
  240. duration: 1000, // animation duration in milliseconds (Number)
  241. easingFunction: "easeInOutQuad" // Animation easing function, available are:
  242. } // linear, easeInQuad, easeOutQuad, easeInOutQuad,
  243. } // easeInCubic, easeOutCubic, easeInOutCubic,
  244. // easeInQuart, easeOutQuart, easeInOutQuart,
  245. // easeInQuint, easeOutQuint, easeInOutQuint
  246. </pre>
  247. <div class="left">
  248. <table>
  249. <tr>
  250. <td>position x</td><td><input type="text" value="300" id="positionx" style="width:170px;"></td>
  251. </tr>
  252. <tr>
  253. <td>position y</td><td><input type="text" value="300" id="positiony" style="width:170px;"></td>
  254. </tr>
  255. <tr>
  256. <td>scale</td><td><input type="text" value="1.0" id="scale" style="width:170px;"></td>
  257. </tr>
  258. <tr>
  259. <td>offset x</td><td><input type="text" value="0" id="offsetx" style="width:170px;"> px</td>
  260. </tr>
  261. <tr>
  262. <td>offset y</td><td><input type="text" value="0" id="offsety" style="width:170px;"> px</td>
  263. </tr>
  264. <tr>
  265. <td>duration</td><td><input type="text" value="2500" id="duration" style="width:170px;"> ms</td>
  266. </tr>
  267. <tr>
  268. <td>easingFunction</td><td>
  269. <select id="easingFunction" style="width:174px;">
  270. <option value="linear">linear</option>
  271. <option value="easeInQuad">easeInQuad</option>
  272. <option value="easeOutQuad">easeOutQuad</option>
  273. <option value="easeInOutQuad" selected="selected">easeInOutQuad</option>
  274. <option value="easeInCubic">easeInCubic</option>
  275. <option value="easeOutCubic">easeOutCubic</option>
  276. <option value="easeInOutCubic">easeInOutCubic</option>
  277. <option value="easeInQuart">easeInQuart</option>
  278. <option value="easeOutQuart">easeOutQuart</option>
  279. <option value="easeInOutQuart">easeInOutQuart</option>
  280. <option value="easeInQuint">easeInQuint</option>
  281. <option value="easeOutQuint">easeOutQuint</option>
  282. <option value="easeInOutQuint">easeInOutQuint</option>
  283. </select>
  284. </td>
  285. </tr>
  286. </table>
  287. <div class="bottom">
  288. <span id="statusUpdate"></span><br />
  289. Examples:
  290. <input type="button" onclick="doAnimation();" value="Animate with above settings." style="width:300px;" id="btnDo"> <br/>
  291. <input type="button" onclick="doDefaultAnimation();" value="Animate with default settings." style="width:300px;" id="btnDoDefault"> <br/>
  292. <input type="button" onclick="zoomExtentAnimated();" value="Animated ZoomExtent()." style="width:300px;" id="btnZoom"> <br/>
  293. <input type="button" onclick="focusRandom();" value="Focus on random node." style="width:300px;" id="btnFocus"><br/>
  294. <input type="button" onclick="startShow();" value="Start a show!" style="width:300px;" id="btnShow"><br/>
  295. </div>
  296. </div>
  297. <div class="right">
  298. <div id="mynetwork"></div>
  299. <p id="selection"></p>
  300. <p id="stabilization"></p>
  301. </div>
  302. </body>
  303. </html>