diff options
Diffstat (limited to 'www/lib/vis/examples/network/events')
3 files changed, 275 insertions, 0 deletions
diff --git a/www/lib/vis/examples/network/events/interactionEvents.html b/www/lib/vis/examples/network/events/interactionEvents.html new file mode 100644 index 00000000..33f1ae70 --- /dev/null +++ b/www/lib/vis/examples/network/events/interactionEvents.html @@ -0,0 +1,119 @@ +<!doctype html> +<html> +<head> + <title>Network | Interaction events</title> + + <script type="text/javascript" src="../../../dist/vis.js"></script> + <link href="../../../dist/vis-network.min.css" rel="stylesheet" type="text/css"/> + + <style type="text/css"> + #mynetwork { + width: 600px; + height: 400px; + border: 1px solid lightgray; + } + </style> +</head> +<body> + +<p> + Create a simple network with some nodes and edges. Some of the events are logged in the console in improve readability. +</p> + +<div id="mynetwork"></div> +<pre id="eventSpan"></pre> + +<script type="text/javascript"> + // create an array with nodes + var nodes = new vis.DataSet([ + {id: 1, label: 'Node 1', title: 'I have a popup!'}, + {id: 2, label: 'Node 2', title: 'I have a popup!'}, + {id: 3, label: 'Node 3', title: 'I have a popup!'}, + {id: 4, label: 'Node 4', title: 'I have a popup!'}, + {id: 5, label: 'Node 5', title: 'I have a popup!'} + ]); + + // create an array with edges + var edges = new vis.DataSet([ + {from: 1, to: 3}, + {from: 1, to: 2}, + {from: 2, to: 4}, + {from: 2, to: 5} + ]); + + // create a network + var container = document.getElementById('mynetwork'); + var data = { + nodes: nodes, + edges: edges + }; + var options = {interaction:{hover:true}}; + var network = new vis.Network(container, data, options); + + network.on("click", function (params) { + params.event = "[original event]"; + document.getElementById('eventSpan').innerHTML = '<h2>Click event:</h2>' + JSON.stringify(params, null, 4); + }); + network.on("doubleClick", function (params) { + params.event = "[original event]"; + document.getElementById('eventSpan').innerHTML = '<h2>doubleClick event:</h2>' + JSON.stringify(params, null, 4); + }); + network.on("oncontext", function (params) { + params.event = "[original event]"; + document.getElementById('eventSpan').innerHTML = '<h2>oncontext (right click) event:</h2>' + JSON.stringify(params, null, 4); + }); + network.on("dragStart", function (params) { + params.event = "[original event]"; + document.getElementById('eventSpan').innerHTML = '<h2>dragStart event:</h2>' + JSON.stringify(params, null, 4); + }); + network.on("dragging", function (params) { + params.event = "[original event]"; + document.getElementById('eventSpan').innerHTML = '<h2>dragging event:</h2>' + JSON.stringify(params, null, 4); + }); + network.on("dragEnd", function (params) { + params.event = "[original event]"; + document.getElementById('eventSpan').innerHTML = '<h2>dragEnd event:</h2>' + JSON.stringify(params, null, 4); + }); + network.on("zoom", function (params) { + document.getElementById('eventSpan').innerHTML = '<h2>zoom event:</h2>' + JSON.stringify(params, null, 4); + }); + network.on("showPopup", function (params) { + document.getElementById('eventSpan').innerHTML = '<h2>showPopup event: </h2>' + JSON.stringify(params, null, 4); + }); + network.on("hidePopup", function () { + console.log('hidePopup Event'); + }); + network.on("select", function (params) { + console.log('select Event:', params); + }); + network.on("selectNode", function (params) { + console.log('selectNode Event:', params); + }); + network.on("selectEdge", function (params) { + console.log('selectEdge Event:', params); + }); + network.on("deselectNode", function (params) { + console.log('deselectNode Event:', params); + }); + network.on("deselectEdge", function (params) { + console.log('deselectEdge Event:', params); + }); + network.on("hoverNode", function (params) { + console.log('hoverNode Event:', params); + }); + network.on("hoverEdge", function (params) { + console.log('hoverEdge Event:', params); + }); + network.on("blurNode", function (params) { + console.log('blurNode Event:', params); + }); + network.on("blurEdge", function (params) { + console.log('blurEdge Event:', params); + }); + + +</script> + +<script src="../../googleAnalytics.js"></script> +</body> +</html> diff --git a/www/lib/vis/examples/network/events/physicsEvents.html b/www/lib/vis/examples/network/events/physicsEvents.html new file mode 100644 index 00000000..418f403a --- /dev/null +++ b/www/lib/vis/examples/network/events/physicsEvents.html @@ -0,0 +1,73 @@ +<!doctype html> +<html> +<head> + <title>Network | Basic usage</title> + + <script type="text/javascript" src="../../../dist/vis.js"></script> + <link href="../../../dist/vis-network.min.css" rel="stylesheet" type="text/css"/> + + <style type="text/css"> + #mynetwork { + width: 600px; + height: 400px; + border: 1px solid lightgray; + } + </style> +</head> +<body> + +<p> + Create a simple network with some nodes and edges. +</p> + +<div id="mynetwork"></div> +<pre id="eventSpan"></pre> +<script type="text/javascript"> + // create an array with nodes + var nodes = new vis.DataSet([ + {id: 1, label: 'Node 1'}, + {id: 2, label: 'Node 2'}, + {id: 3, label: 'Node 3'}, + {id: 4, label: 'Node 4'}, + {id: 5, label: 'Node 5'} + ]); + + // create an array with edges + var edges = new vis.DataSet([ + {from: 1, to: 3}, + {from: 1, to: 2}, + {from: 2, to: 4}, + {from: 2, to: 5} + ]); + + // create a network + var container = document.getElementById('mynetwork'); + var data = { + nodes: nodes, + edges: edges + }; + var options = {}; + var network = new vis.Network(container, data, options); + + network.on("startStabilizing", function (params) { + document.getElementById('eventSpan').innerHTML = '<h3>Starting Stabilization</h3>'; + console.log("started") + }); + network.on("stabilizationProgress", function (params) { + document.getElementById('eventSpan').innerHTML = '<h3>Stabilization progress</h3>' + JSON.stringify(params, null, 4); + console.log("progress:",params); + }); + network.on("stabilizationIterationsDone", function (params) { + document.getElementById('eventSpan').innerHTML = '<h3>Stabilization iterations complete</h3>'; + console.log("finished stabilization interations"); + }); + network.on("stabilized", function (params) { + document.getElementById('eventSpan').innerHTML = '<h3>Stabilized!</h3>' + JSON.stringify(params, null, 4); + console.log("stabilized!", params); + }); + +</script> + +<script src="../../googleAnalytics.js"></script> +</body> +</html> diff --git a/www/lib/vis/examples/network/events/renderEvents.html b/www/lib/vis/examples/network/events/renderEvents.html new file mode 100644 index 00000000..e28e4ea3 --- /dev/null +++ b/www/lib/vis/examples/network/events/renderEvents.html @@ -0,0 +1,83 @@ +<!doctype html> +<html> +<head> + <title>Network | Basic usage</title> + + <script type="text/javascript" src="../../../dist/vis.js"></script> + <link href="../../../dist/vis-network.min.css" rel="stylesheet" type="text/css"/> + + <style type="text/css"> + #mynetwork { + width: 600px; + height: 400px; + border: 1px solid lightgray; + } + + p { + max-width:600px; + } + </style> +</head> +<body> + +<p> + You can draw on the canvas using normal HTML5 canvas functions. The before drawing will be behind the network, the after drawing will be in front of the network. +</p> + +<div id="mynetwork"></div> +<pre id="eventSpan"></pre> +<script type="text/javascript"> + // create an array with nodes + var nodes = new vis.DataSet([ + {id: 1, label: 'Node 1'}, + {id: 2, label: 'Node 2'}, + {id: 3, label: 'Node 3'}, + {id: 4, label: 'Node 4'}, + {id: 5, label: 'Node 5'} + ]); + + // create an array with edges + var edges = new vis.DataSet([ + {from: 1, to: 3}, + {from: 1, to: 2}, + {from: 2, to: 4}, + {from: 2, to: 5} + ]); + + // create a network + var container = document.getElementById('mynetwork'); + var data = { + nodes: nodes, + edges: edges + }; + var options = {}; + var network = new vis.Network(container, data, options); + + network.on("initRedraw", function () { + // do something like move some custom elements? + }); + network.on("beforeDrawing", function (ctx) { + var nodeId = 1; + var nodePosition = network.getPositions([nodeId]); + ctx.strokeStyle = '#A6D5F7'; + ctx.fillStyle = '#294475'; + ctx.circle(nodePosition[nodeId].x, nodePosition[nodeId].y,50); + ctx.fill(); + ctx.stroke(); + }); + network.on("afterDrawing", function (ctx) { + var nodeId = 1; + var nodePosition = network.getPositions([nodeId]); + ctx.strokeStyle = '#294475'; + ctx.lineWidth = 4; + ctx.fillStyle = '#A6D5F7'; + ctx.circle(nodePosition[nodeId].x, nodePosition[nodeId].y,20); + ctx.fill(); + ctx.stroke(); + }); + +</script> + +<script src="../../googleAnalytics.js"></script> +</body> +</html> |
