<script src="src/sigma.core.js"></script>
|
|
<script src="src/conrad.js"></script>
|
|
<script src="src/utils/sigma.utils.js"></script>
|
|
<script src="src/utils/sigma.polyfills.js"></script>
|
|
<script src="src/sigma.settings.js"></script>
|
|
<script src="src/classes/sigma.classes.dispatcher.js"></script>
|
|
<script src="src/classes/sigma.classes.configurable.js"></script>
|
|
<script src="src/classes/sigma.classes.graph.js"></script>
|
|
<script src="src/classes/sigma.classes.camera.js"></script>
|
|
<script src="src/classes/sigma.classes.quad.js"></script>
|
|
<script src="src/classes/sigma.classes.edgequad.js"></script>
|
|
<script src="src/captors/sigma.captors.mouse.js"></script>
|
|
<script src="src/captors/sigma.captors.touch.js"></script>
|
|
<script src="src/renderers/sigma.renderers.canvas.js"></script>
|
|
<script src="src/renderers/sigma.renderers.webgl.js"></script>
|
|
<script src="src/renderers/sigma.renderers.svg.js"></script>
|
|
<script src="src/renderers/sigma.renderers.def.js"></script>
|
|
<script src="src/renderers/webgl/sigma.webgl.nodes.def.js"></script>
|
|
<script src="src/renderers/webgl/sigma.webgl.nodes.fast.js"></script>
|
|
<script src="src/renderers/webgl/sigma.webgl.edges.def.js"></script>
|
|
<script src="src/renderers/webgl/sigma.webgl.edges.fast.js"></script>
|
|
<script src="src/renderers/webgl/sigma.webgl.edges.arrow.js"></script>
|
|
<script src="src/renderers/canvas/sigma.canvas.labels.def.js"></script>
|
|
<script src="src/renderers/canvas/sigma.canvas.hovers.def.js"></script>
|
|
<script src="src/renderers/canvas/sigma.canvas.nodes.def.js"></script>
|
|
<script src="src/renderers/canvas/sigma.canvas.edges.def.js"></script>
|
|
<script src="src/renderers/canvas/sigma.canvas.edges.curve.js"></script>
|
|
<script src="src/renderers/canvas/sigma.canvas.edges.arrow.js"></script>
|
|
<script src="src/renderers/canvas/sigma.canvas.edges.curvedArrow.js"></script>
|
|
<script src="src/renderers/canvas/sigma.canvas.edgehovers.def.js"></script>
|
|
<script src="src/renderers/canvas/sigma.canvas.edgehovers.curve.js"></script>
|
|
<script src="src/renderers/canvas/sigma.canvas.edgehovers.arrow.js"></script>
|
|
<script src="src/renderers/canvas/sigma.canvas.edgehovers.curvedArrow.js"></script>
|
|
<script src="src/renderers/canvas/sigma.canvas.extremities.def.js"></script>
|
|
<script src="src/renderers/svg/sigma.svg.utils.js"></script>
|
|
<script src="src/renderers/svg/sigma.svg.nodes.def.js"></script>
|
|
<script src="src/renderers/svg/sigma.svg.edges.def.js"></script>
|
|
<script src="src/renderers/svg/sigma.svg.edges.curve.js"></script>
|
|
<script src="src/renderers/svg/sigma.svg.labels.def.js"></script>
|
|
<script src="src/renderers/svg/sigma.svg.hovers.def.js"></script>
|
|
<script src="src/middlewares/sigma.middlewares.rescale.js"></script>
|
|
<script src="src/middlewares/sigma.middlewares.copy.js"></script>
|
|
<script src="src/misc/sigma.misc.animation.js"></script>
|
|
<script src="src/misc/sigma.misc.bindEvents.js"></script>
|
|
<script src="src/misc/sigma.misc.bindDOMEvents.js"></script>
|
|
<script src="src/misc/sigma.misc.drawHovers.js"></script>
|
|
|
|
<script src="src/plugins/sigma.plugins.neighborhoods/sigma.plugins.neighborhoods.js"></script>
|
|
<script src="src/plugins/sigma.layout.forceAtlas2/supervisor.js"></script>
|
|
<script src="src/plugins/sigma.layout.forceAtlas2/worker.js"></script>
|
|
<script src="src/jquery-2.1.1.min.js"></script>
|
|
|
|
|
|
<!-- END SIGMA IMPORTS -->
|
|
<div id="container">
|
|
<style>
|
|
#graph-container {
|
|
top: 0;
|
|
bottom: 0;
|
|
left: 0;
|
|
right: 0;
|
|
position: absolute;
|
|
background-color: #455660;
|
|
}
|
|
.sigma-edge {
|
|
stroke: #14191C;
|
|
}
|
|
.sigma-node {
|
|
fill: green;
|
|
stroke: #14191C;
|
|
stroke-width: 2px;
|
|
}
|
|
.sigma-node:hover {
|
|
fill: blue;
|
|
}
|
|
.muted {
|
|
fill-opacity: 0.1;
|
|
stroke-opacity: 0.1;
|
|
}
|
|
</style>
|
|
<div id="graph-container"></div>
|
|
</div>
|
|
|
|
<script src="src/worker.js"></script>
|
|
<script src="src/supervisor.js"></script>
|
|
|
|
<script>
|
|
|
|
/**
|
|
* This is a basic example on how to instantiate sigma. A random graph is
|
|
* generated and stored in the "graph" variable, and then sigma is instantiated
|
|
* directly with the graph.
|
|
*
|
|
* The simple instance of sigma is enough to make it render the graph on the on
|
|
* the screen, since the graph is given directly to the constructor.
|
|
*
|
|
* var sigInstance = new sigma();
|
|
|
|
// Adding node
|
|
sigInstance.graph.addNode(params);
|
|
|
|
// Adding edge
|
|
sigInstance.graph.addEdge(params);
|
|
|
|
// You can also use the read method if you already have a object of nodes and edges
|
|
sigInst.graph.read({nodes: [...], edges: [...]});
|
|
|
|
// Updating nodes
|
|
sigInstance.graph.nodes().forEach(function(n) {
|
|
n.size = 34;
|
|
n.color = '#000';
|
|
});
|
|
|
|
// Replace 'nodes' by 'edges' for the edges
|
|
|
|
// Don't forget to refresh your instance when done so the new graph is correctly displayed
|
|
sigInst.refresh();
|
|
|
|
// If you want to clear the graph, use the clear method
|
|
sigInst.graph.clear(); // graph now empty
|
|
*
|
|
*/
|
|
var s,
|
|
g = {
|
|
nodes: [],
|
|
edges: []
|
|
};
|
|
|
|
// Instantiate sigma:
|
|
s = new sigma({
|
|
graph: g,
|
|
container: 'graph-container'
|
|
});
|
|
|
|
|
|
s.addRenderer({
|
|
id: 'main',
|
|
type: 'svg',
|
|
container: document.getElementById('graph-container'),
|
|
freeStyle: true
|
|
});
|
|
|
|
s.refresh();
|
|
|
|
// Binding silly interactions
|
|
function mute(node) {
|
|
if (!~node.getAttribute('class').search(/muted/))
|
|
node.setAttributeNS(null, 'class', node.getAttribute('class') + ' muted');
|
|
}
|
|
|
|
function unmute(node) {
|
|
node.setAttributeNS(null, 'class', node.getAttribute('class').replace(/(\s|^)muted(\s|$)/g, '$2'));
|
|
}
|
|
|
|
$('.sigma-node').click(function() {
|
|
|
|
// Muting
|
|
$('.sigma-node, .sigma-edge').each(function() {
|
|
mute(this);
|
|
});
|
|
|
|
// Unmuting neighbors
|
|
var neighbors = s.graph.neighborhood($(this).attr('data-node-id'));
|
|
neighbors.nodes.forEach(function(node) {
|
|
unmute($('[data-node-id="' + node.id + '"]')[0]);
|
|
});
|
|
|
|
neighbors.edges.forEach(function(edge) {
|
|
unmute($('[data-edge-id="' + edge.id + '"]')[0]);
|
|
});
|
|
});
|
|
|
|
s.bind('clickStage', function() {
|
|
$('.sigma-node, .sigma-edge').each(function() {
|
|
unmute(this);
|
|
});
|
|
});
|
|
|
|
|
|
|
|
|
|
var connection = new WebSocket('ws://127.0.0.1:4444');
|
|
|
|
connection.onopen = function ()
|
|
{
|
|
console.log('Connected!');
|
|
connection.send('Ping'); // Send the message 'Ping' to the server
|
|
};
|
|
|
|
// Log errors
|
|
connection.onerror = function (error)
|
|
{
|
|
console.log('WebSocket Error ' + error);
|
|
};
|
|
|
|
function addNodeToGraph(request)
|
|
{
|
|
s.graph.addNode({
|
|
id: request.id,
|
|
label: request.name,
|
|
x: Math.random(),
|
|
y: Math.random(),
|
|
size: Math.random(),
|
|
color: '#666'
|
|
});
|
|
s.refresh();
|
|
}
|
|
|
|
|
|
function addEdgeToGraph(request)
|
|
{
|
|
s.graph.addEdge({
|
|
id: request.id,
|
|
source: request.p1,
|
|
target: request.p2,
|
|
size: Math.random(),
|
|
color: '#000'
|
|
});
|
|
s.refresh();
|
|
}
|
|
|
|
|
|
// Log messages from the server
|
|
connection.onmessage = function (e)
|
|
{
|
|
var request = JSON.parse(e.data);
|
|
|
|
if(request.action == 1)
|
|
{
|
|
addNodeToGraph(request);
|
|
}
|
|
else if(request.action == 2)
|
|
{
|
|
addEdgeToGraph(request);
|
|
}
|
|
console.log('Server: ' + e.data);
|
|
};
|
|
|
|
|
|
//s.startForceAtlas2({worker: true, barnesHutOptimize: false});
|
|
</script>
|