Skip to content

Instantly share code, notes, and snippets.

@hnakamur hnakamur/index.html
Last active May 27, 2019

Embed
What would you like to do?
cytoscape network weathermap experiment
<!DOCTYPE>
<html>
<head>
<title>network weathermap demo using cytoscape.js</title>
<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1, maximum-scale=1">
<script src="https://unpkg.com/cytoscape/dist/cytoscape.min.js"></script>
<script src="https://unpkg.com/cytoscape-automove@1.10.1/cytoscape-automove.js"></script>
<style>
#cy {
position: absolute;
left: 0;
top: 0;
bottom: 0;
right: 0;
z-index: 1;
}
</style>
</head>
<body>
<div id="cy"></div>
<script>
// document.addEventListener('DOMContentLoaded', function () {
var cy = cytoscape({
container: document.getElementById('cy'), // container to render in
elements: { // list of graph elements to start with
nodes: [
{ data: { id: 'a', label: 'コアルータ\n(core router)' }, position: { x: 50, y: 250 } },
{ data: { id: 'a2' }, classes: 'empty-joint' },
{ data: { id: 'b', label: 'ルータ\n(router)' }, position: { x: 550, y: 250 } },
{ data: { id: 'b2' }, classes: 'empty-joint' },
{ data: { id: 'c', label: 'スイッチ\n(switch)' }, position: { x: 300, y: 50 } },
{ data: { id: 'c2' }, classes: 'empty-joint' }
],
edges: [
{ data: { id: 'ab', source: 'a', target: 'a2', label: '139.14K', width: '13px', lineColor: '#B3EAD9' } },
{ data: { id: 'ab2', source: 'b', target: 'a2', label: '200.13K', width: '20px', lineColor: '#D1EAF8' } },
{ data: { id: 'bc', source: 'b', target: 'b2', label: '139.14K', width: '13px', lineColor: '#B3EAD9' } },
{ data: { id: 'bc2', source: 'c', target: 'b2', label: '200.13K', width: '20px', lineColor: '#D1EAF8' } },
{ data: { id: 'ca', source: 'c', target: 'c2', label: '139.14K', width: '13px', lineColor: '#B3EAD9' } },
{ data: { id: 'ca2', source: 'a', target: 'c2', label: '200.13K', width: '20px', lineColor: '#D1EAF8' } }
]
},
style: [ // the stylesheet for the graph
{
selector: 'node',
style: {
'background-color': '#666',
'content': 'data(id)'
}
},
{
selector: '.empty-joint',
style: {
'content': '',
'background-opacity': 0,
'width': '1px',
'height': '1px',
'border-width': 0
}
},
{
selector: 'edge',
style: {
'curve-style': 'bezier',
'width': 'data(width)',
'line-color': 'data(lineColor)',
'target-arrow-color': 'data(lineColor)',
'target-arrow-shape': 'triangle'
}
},
{
selector: 'node[label]',
style: {
'text-wrap': 'wrap',
'label': 'data(label)'
}
},
{
selector: 'edge[label]',
style: {
'label': 'data(label)',
'text-border-opacity': 1,
'text-border-color': '#000',
'text-border-width': '1px',
'text-background-padding': '4px',
'text-background-opacity': 1,
'text-background-color': '#FFF',
'text-background-shape': 'rectangle'
}
},
{
selector: '#a',
style: {
'shape': 'rectangle',
'background-opacity': 0,
'width': '72px',
'height': '69px',
'background-fit': 'cover cover',
'background-image': ''
}
},
{
selector: '#a[label]',
style: {
'text-valign': 'bottom'
}
},
{
selector: '#b',
style: {
'shape': 'rectangle',
'background-opacity': 0,
'width': '60px',
'height': '35px',
'background-fit': 'cover cover',
'background-image': ''
}
},
{
selector: '#b[label]',
style: {
'text-valign': 'bottom'
}
},
{
selector: '#c',
style: {
'shape': 'rectangle',
'background-opacity': 0,
'width': '78px',
'height': '33px',
'background-fit': 'cover cover',
'background-image': ''
}
}
],
layout: {
name: 'preset'
}
});
cy.automove({
nodesMatching: cy.$('.empty-joint'),
reposition: 'mean',
meanOnSelfPosition: function( node ){ return false; }
});
// });
</script>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
You can’t perform that action at this time.