| @ -1,241 +0,0 @@ | |||||
| <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> | |||||
| @ -0,0 +1,136 @@ | |||||
| <!DOCTYPE html> | |||||
| <html lang="en"> | |||||
| <head> | |||||
| <meta charset="utf-8"> | |||||
| <title>Jrtechs Steam Friend Graph Project</title> | |||||
| <meta name="viewport" content="width=device-width, initial-scale=1"> | |||||
| <meta http-equiv="X-UA-Compatible" content="IE=edge" /> | |||||
| <link rel="stylesheet" href="css/bootstrap.css" media="screen"> | |||||
| <link rel="stylesheet" href="css/custom.min.css"> | |||||
| </head> | |||||
| <body> | |||||
| <div class="navbar navbar-expand-lg fixed-top navbar-dark bg-primary"> | |||||
| <div class="container"> | |||||
| <a href="#" class="navbar-brand">Jrtechs Steam Graph Project</a> | |||||
| <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarResponsive" aria-controls="navbarResponsive" aria-expanded="false" aria-label="Toggle navigation"> | |||||
| <span class="navbar-toggler-icon"></span> | |||||
| </button> | |||||
| <div class="collapse navbar-collapse" id="navbarResponsive"> | |||||
| <ul class="navbar-nav"> | |||||
| <li class="nav-item dropdown"> | |||||
| <a class="nav-link dropdown-toggle" data-toggle="dropdown" href="#" id="themes">Graphs <span class="caret"></span></a> | |||||
| <div class="dropdown-menu" aria-labelledby="themes"> | |||||
| <a class="dropdown-item" href="friendsOfFriends.html">Friends of Friends</a> | |||||
| <a class="dropdown-item" href="commonFriends.html">Common Friends</a> | |||||
| <a class="dropdown-item" href="closestPath.html">Closest Path</a> | |||||
| <a class="dropdown-item" href="commonGames.html">Common Games</a> | |||||
| <a class="dropdown-item" href="bestFriends.html">Best Friends</a> | |||||
| </div> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://jrtechs.net">Blog</a> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://jrtechs.me">Resume</a> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://github.com/jrtechs">Github</a> | |||||
| </li> | |||||
| </ul> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| <div class="container"> | |||||
| <br><br><br> | |||||
| <h1>TDLTR</h1> | |||||
| </div> | |||||
| <!- | |||||
| ┈┈╱▔▔▔▔▔╲┈┈┈HM┈HM | |||||
| ┈╱┈┈╱▔╲╲╲▏┈┈┈HMMM | |||||
| ╱┈┈╱━╱▔▔▔▔▔╲━╮┈┈ | |||||
| ▏┈▕┃▕╱▔╲╱▔╲▕╮┃┈┈ | |||||
| ▏┈▕╰━▏▊▕▕▋▕▕━╯┈┈ | |||||
| ╲┈┈╲╱▔╭╮▔▔┳╲╲┈┈┈ | |||||
| ┈╲┈┈▏╭━━━━╯▕▕┈┈┈ | |||||
| ┈┈╲┈╲▂▂▂▂▂▂╱╱┈┈┈ | |||||
| ┈┈┈┈▏┊┈┈┈┈┊┈┈┈╲┈ | |||||
| ┈┈┈┈▏┊┈┈┈┈┊▕╲┈┈╲ | |||||
| ┈╱▔╲▏┊┈┈┈┈┊▕╱▔╲▕ | |||||
| ┈▏ ┈┈┈╰┈┈┈┈╯┈┈┈▕▕ | |||||
| ┈╲┈┈┈╲┈┈┈┈╱┈┈┈╱┈╲ | |||||
| ┈┈╲┈┈▕▔▔▔▔▏┈┈╱╲╲╲▏ | |||||
| ┈╱▔┈┈▕┈┈┈┈▏┈┈▔╲▔▔ | |||||
| ┈╲▂▂▂╱┈┈┈┈╲▂▂▂╱┈ | |||||
| If you are seeing this money that means that you are interested in my | |||||
| code. Yay!! If you are not here to hack me ... you should really consider | |||||
| contributing to some of my public projects on github. | |||||
| https://github.com/jrtechs | |||||
| --> | |||||
| <!-- Footer --> | |||||
| <footer class="text-center"> | |||||
| <div class="footer-above"> | |||||
| <div class="container"> | |||||
| <div class="row"> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>Location</h3> | |||||
| <p>Rochester Institute of Technology | |||||
| <br>1 Lomb Memorial Dr, Rochester, NY 14623</p> | |||||
| </div> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>Around the Web</h3> | |||||
| <ul class="list-inline"> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="https://www.youtube.com/c/JrtechsNet"> | |||||
| <i class="fa fa-fw fa-youtube"></i> | |||||
| </a> | |||||
| </li> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="https://github.com/jrtechs"> | |||||
| <i class="fa fa-fw fa-github"></i> | |||||
| </a> | |||||
| </li> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="http://jrtechs.net"> | |||||
| <i class="fa fa-fw fa-wordpress"></i> | |||||
| </a> | |||||
| </li> | |||||
| </ul> | |||||
| </div> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>About This Website</h3> | |||||
| <p>Check out the source code for this website on my | |||||
| <a href="https://github.com/jrtechs">github</a>.</p> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| <div class="footer-below"> | |||||
| <div class="container"> | |||||
| <div class="row"> | |||||
| <div class="col-lg-12"> | |||||
| <p class="m-0 text-center text-white"><a href="https://creativecommons.org/licenses/by-sa/4.0/" target="_blank">CC-BY-SA 4.0</a> <script type="text/javascript"> | |||||
| document.write(new Date().getFullYear()); | |||||
| </script> Jrtechs</p> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </footer> | |||||
| <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script> | |||||
| <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script> | |||||
| <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/js/bootstrap.min.js" integrity="sha384-smHYKdLADwkXOn1EmN1qk/HfnUcbVRZyYmZ4qpPea6sjB/pTJ0euyQp0Mk8ck+5T" crossorigin="anonymous"></script> | |||||
| </body> | |||||
| </html> | |||||
| @ -0,0 +1,136 @@ | |||||
| <!DOCTYPE html> | |||||
| <html lang="en"> | |||||
| <head> | |||||
| <meta charset="utf-8"> | |||||
| <title>Jrtechs Steam Friend Graph Project</title> | |||||
| <meta name="viewport" content="width=device-width, initial-scale=1"> | |||||
| <meta http-equiv="X-UA-Compatible" content="IE=edge" /> | |||||
| <link rel="stylesheet" href="css/bootstrap.css" media="screen"> | |||||
| <link rel="stylesheet" href="css/custom.min.css"> | |||||
| </head> | |||||
| <body> | |||||
| <div class="navbar navbar-expand-lg fixed-top navbar-dark bg-primary"> | |||||
| <div class="container"> | |||||
| <a href="#" class="navbar-brand">Jrtechs Steam Graph Project</a> | |||||
| <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarResponsive" aria-controls="navbarResponsive" aria-expanded="false" aria-label="Toggle navigation"> | |||||
| <span class="navbar-toggler-icon"></span> | |||||
| </button> | |||||
| <div class="collapse navbar-collapse" id="navbarResponsive"> | |||||
| <ul class="navbar-nav"> | |||||
| <li class="nav-item dropdown"> | |||||
| <a class="nav-link dropdown-toggle" data-toggle="dropdown" href="#" id="themes">Graphs <span class="caret"></span></a> | |||||
| <div class="dropdown-menu" aria-labelledby="themes"> | |||||
| <a class="dropdown-item" href="friendsOfFriends.html">Friends of Friends</a> | |||||
| <a class="dropdown-item" href="commonFriends.html">Common Friends</a> | |||||
| <a class="dropdown-item" href="closestPath.html">Closest Path</a> | |||||
| <a class="dropdown-item" href="commonGames.html">Common Games</a> | |||||
| <a class="dropdown-item" href="bestFriends.html">Best Friends</a> | |||||
| </div> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://jrtechs.net">Blog</a> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://jrtechs.me">Resume</a> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://github.com/jrtechs">Github</a> | |||||
| </li> | |||||
| </ul> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| <div class="container"> | |||||
| <br><br><br> | |||||
| <h1>TDLTR</h1> | |||||
| </div> | |||||
| <!- | |||||
| ┈┈╱▔▔▔▔▔╲┈┈┈HM┈HM | |||||
| ┈╱┈┈╱▔╲╲╲▏┈┈┈HMMM | |||||
| ╱┈┈╱━╱▔▔▔▔▔╲━╮┈┈ | |||||
| ▏┈▕┃▕╱▔╲╱▔╲▕╮┃┈┈ | |||||
| ▏┈▕╰━▏▊▕▕▋▕▕━╯┈┈ | |||||
| ╲┈┈╲╱▔╭╮▔▔┳╲╲┈┈┈ | |||||
| ┈╲┈┈▏╭━━━━╯▕▕┈┈┈ | |||||
| ┈┈╲┈╲▂▂▂▂▂▂╱╱┈┈┈ | |||||
| ┈┈┈┈▏┊┈┈┈┈┊┈┈┈╲┈ | |||||
| ┈┈┈┈▏┊┈┈┈┈┊▕╲┈┈╲ | |||||
| ┈╱▔╲▏┊┈┈┈┈┊▕╱▔╲▕ | |||||
| ┈▏ ┈┈┈╰┈┈┈┈╯┈┈┈▕▕ | |||||
| ┈╲┈┈┈╲┈┈┈┈╱┈┈┈╱┈╲ | |||||
| ┈┈╲┈┈▕▔▔▔▔▏┈┈╱╲╲╲▏ | |||||
| ┈╱▔┈┈▕┈┈┈┈▏┈┈▔╲▔▔ | |||||
| ┈╲▂▂▂╱┈┈┈┈╲▂▂▂╱┈ | |||||
| If you are seeing this money that means that you are interested in my | |||||
| code. Yay!! If you are not here to hack me ... you should really consider | |||||
| contributing to some of my public projects on github. | |||||
| https://github.com/jrtechs | |||||
| --> | |||||
| <!-- Footer --> | |||||
| <footer class="text-center"> | |||||
| <div class="footer-above"> | |||||
| <div class="container"> | |||||
| <div class="row"> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>Location</h3> | |||||
| <p>Rochester Institute of Technology | |||||
| <br>1 Lomb Memorial Dr, Rochester, NY 14623</p> | |||||
| </div> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>Around the Web</h3> | |||||
| <ul class="list-inline"> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="https://www.youtube.com/c/JrtechsNet"> | |||||
| <i class="fa fa-fw fa-youtube"></i> | |||||
| </a> | |||||
| </li> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="https://github.com/jrtechs"> | |||||
| <i class="fa fa-fw fa-github"></i> | |||||
| </a> | |||||
| </li> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="http://jrtechs.net"> | |||||
| <i class="fa fa-fw fa-wordpress"></i> | |||||
| </a> | |||||
| </li> | |||||
| </ul> | |||||
| </div> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>About This Website</h3> | |||||
| <p>Check out the source code for this website on my | |||||
| <a href="https://github.com/jrtechs">github</a>.</p> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| <div class="footer-below"> | |||||
| <div class="container"> | |||||
| <div class="row"> | |||||
| <div class="col-lg-12"> | |||||
| <p class="m-0 text-center text-white"><a href="https://creativecommons.org/licenses/by-sa/4.0/" target="_blank">CC-BY-SA 4.0</a> <script type="text/javascript"> | |||||
| document.write(new Date().getFullYear()); | |||||
| </script> Jrtechs</p> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </footer> | |||||
| <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script> | |||||
| <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script> | |||||
| <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/js/bootstrap.min.js" integrity="sha384-smHYKdLADwkXOn1EmN1qk/HfnUcbVRZyYmZ4qpPea6sjB/pTJ0euyQp0Mk8ck+5T" crossorigin="anonymous"></script> | |||||
| </body> | |||||
| </html> | |||||
| @ -0,0 +1,136 @@ | |||||
| <!DOCTYPE html> | |||||
| <html lang="en"> | |||||
| <head> | |||||
| <meta charset="utf-8"> | |||||
| <title>Jrtechs Steam Friend Graph Project</title> | |||||
| <meta name="viewport" content="width=device-width, initial-scale=1"> | |||||
| <meta http-equiv="X-UA-Compatible" content="IE=edge" /> | |||||
| <link rel="stylesheet" href="css/bootstrap.css" media="screen"> | |||||
| <link rel="stylesheet" href="css/custom.min.css"> | |||||
| </head> | |||||
| <body> | |||||
| <div class="navbar navbar-expand-lg fixed-top navbar-dark bg-primary"> | |||||
| <div class="container"> | |||||
| <a href="#" class="navbar-brand">Jrtechs Steam Graph Project</a> | |||||
| <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarResponsive" aria-controls="navbarResponsive" aria-expanded="false" aria-label="Toggle navigation"> | |||||
| <span class="navbar-toggler-icon"></span> | |||||
| </button> | |||||
| <div class="collapse navbar-collapse" id="navbarResponsive"> | |||||
| <ul class="navbar-nav"> | |||||
| <li class="nav-item dropdown"> | |||||
| <a class="nav-link dropdown-toggle" data-toggle="dropdown" href="#" id="themes">Graphs <span class="caret"></span></a> | |||||
| <div class="dropdown-menu" aria-labelledby="themes"> | |||||
| <a class="dropdown-item" href="friendsOfFriends.html">Friends of Friends</a> | |||||
| <a class="dropdown-item" href="commonFriends.html">Common Friends</a> | |||||
| <a class="dropdown-item" href="closestPath.html">Closest Path</a> | |||||
| <a class="dropdown-item" href="commonGames.html">Common Games</a> | |||||
| <a class="dropdown-item" href="bestFriends.html">Best Friends</a> | |||||
| </div> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://jrtechs.net">Blog</a> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://jrtechs.me">Resume</a> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://github.com/jrtechs">Github</a> | |||||
| </li> | |||||
| </ul> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| <div class="container"> | |||||
| <br><br><br> | |||||
| <h1>TDLTR</h1> | |||||
| </div> | |||||
| <!- | |||||
| ┈┈╱▔▔▔▔▔╲┈┈┈HM┈HM | |||||
| ┈╱┈┈╱▔╲╲╲▏┈┈┈HMMM | |||||
| ╱┈┈╱━╱▔▔▔▔▔╲━╮┈┈ | |||||
| ▏┈▕┃▕╱▔╲╱▔╲▕╮┃┈┈ | |||||
| ▏┈▕╰━▏▊▕▕▋▕▕━╯┈┈ | |||||
| ╲┈┈╲╱▔╭╮▔▔┳╲╲┈┈┈ | |||||
| ┈╲┈┈▏╭━━━━╯▕▕┈┈┈ | |||||
| ┈┈╲┈╲▂▂▂▂▂▂╱╱┈┈┈ | |||||
| ┈┈┈┈▏┊┈┈┈┈┊┈┈┈╲┈ | |||||
| ┈┈┈┈▏┊┈┈┈┈┊▕╲┈┈╲ | |||||
| ┈╱▔╲▏┊┈┈┈┈┊▕╱▔╲▕ | |||||
| ┈▏ ┈┈┈╰┈┈┈┈╯┈┈┈▕▕ | |||||
| ┈╲┈┈┈╲┈┈┈┈╱┈┈┈╱┈╲ | |||||
| ┈┈╲┈┈▕▔▔▔▔▏┈┈╱╲╲╲▏ | |||||
| ┈╱▔┈┈▕┈┈┈┈▏┈┈▔╲▔▔ | |||||
| ┈╲▂▂▂╱┈┈┈┈╲▂▂▂╱┈ | |||||
| If you are seeing this money that means that you are interested in my | |||||
| code. Yay!! If you are not here to hack me ... you should really consider | |||||
| contributing to some of my public projects on github. | |||||
| https://github.com/jrtechs | |||||
| --> | |||||
| <!-- Footer --> | |||||
| <footer class="text-center"> | |||||
| <div class="footer-above"> | |||||
| <div class="container"> | |||||
| <div class="row"> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>Location</h3> | |||||
| <p>Rochester Institute of Technology | |||||
| <br>1 Lomb Memorial Dr, Rochester, NY 14623</p> | |||||
| </div> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>Around the Web</h3> | |||||
| <ul class="list-inline"> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="https://www.youtube.com/c/JrtechsNet"> | |||||
| <i class="fa fa-fw fa-youtube"></i> | |||||
| </a> | |||||
| </li> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="https://github.com/jrtechs"> | |||||
| <i class="fa fa-fw fa-github"></i> | |||||
| </a> | |||||
| </li> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="http://jrtechs.net"> | |||||
| <i class="fa fa-fw fa-wordpress"></i> | |||||
| </a> | |||||
| </li> | |||||
| </ul> | |||||
| </div> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>About This Website</h3> | |||||
| <p>Check out the source code for this website on my | |||||
| <a href="https://github.com/jrtechs">github</a>.</p> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| <div class="footer-below"> | |||||
| <div class="container"> | |||||
| <div class="row"> | |||||
| <div class="col-lg-12"> | |||||
| <p class="m-0 text-center text-white"><a href="https://creativecommons.org/licenses/by-sa/4.0/" target="_blank">CC-BY-SA 4.0</a> <script type="text/javascript"> | |||||
| document.write(new Date().getFullYear()); | |||||
| </script> Jrtechs</p> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </footer> | |||||
| <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script> | |||||
| <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script> | |||||
| <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/js/bootstrap.min.js" integrity="sha384-smHYKdLADwkXOn1EmN1qk/HfnUcbVRZyYmZ4qpPea6sjB/pTJ0euyQp0Mk8ck+5T" crossorigin="anonymous"></script> | |||||
| </body> | |||||
| </html> | |||||
| @ -0,0 +1,136 @@ | |||||
| <!DOCTYPE html> | |||||
| <html lang="en"> | |||||
| <head> | |||||
| <meta charset="utf-8"> | |||||
| <title>Jrtechs Steam Friend Graph Project</title> | |||||
| <meta name="viewport" content="width=device-width, initial-scale=1"> | |||||
| <meta http-equiv="X-UA-Compatible" content="IE=edge" /> | |||||
| <link rel="stylesheet" href="css/bootstrap.css" media="screen"> | |||||
| <link rel="stylesheet" href="css/custom.min.css"> | |||||
| </head> | |||||
| <body> | |||||
| <div class="navbar navbar-expand-lg fixed-top navbar-dark bg-primary"> | |||||
| <div class="container"> | |||||
| <a href="#" class="navbar-brand">Jrtechs Steam Graph Project</a> | |||||
| <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarResponsive" aria-controls="navbarResponsive" aria-expanded="false" aria-label="Toggle navigation"> | |||||
| <span class="navbar-toggler-icon"></span> | |||||
| </button> | |||||
| <div class="collapse navbar-collapse" id="navbarResponsive"> | |||||
| <ul class="navbar-nav"> | |||||
| <li class="nav-item dropdown"> | |||||
| <a class="nav-link dropdown-toggle" data-toggle="dropdown" href="#" id="themes">Graphs <span class="caret"></span></a> | |||||
| <div class="dropdown-menu" aria-labelledby="themes"> | |||||
| <a class="dropdown-item" href="friendsOfFriends.html">Friends of Friends</a> | |||||
| <a class="dropdown-item" href="commonFriends.html">Common Friends</a> | |||||
| <a class="dropdown-item" href="closestPath.html">Closest Path</a> | |||||
| <a class="dropdown-item" href="commonGames.html">Common Games</a> | |||||
| <a class="dropdown-item" href="bestFriends.html">Best Friends</a> | |||||
| </div> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://jrtechs.net">Blog</a> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://jrtechs.me">Resume</a> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://github.com/jrtechs">Github</a> | |||||
| </li> | |||||
| </ul> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| <div class="container"> | |||||
| <br><br><br> | |||||
| <h1>TDLTR</h1> | |||||
| </div> | |||||
| <!- | |||||
| ┈┈╱▔▔▔▔▔╲┈┈┈HM┈HM | |||||
| ┈╱┈┈╱▔╲╲╲▏┈┈┈HMMM | |||||
| ╱┈┈╱━╱▔▔▔▔▔╲━╮┈┈ | |||||
| ▏┈▕┃▕╱▔╲╱▔╲▕╮┃┈┈ | |||||
| ▏┈▕╰━▏▊▕▕▋▕▕━╯┈┈ | |||||
| ╲┈┈╲╱▔╭╮▔▔┳╲╲┈┈┈ | |||||
| ┈╲┈┈▏╭━━━━╯▕▕┈┈┈ | |||||
| ┈┈╲┈╲▂▂▂▂▂▂╱╱┈┈┈ | |||||
| ┈┈┈┈▏┊┈┈┈┈┊┈┈┈╲┈ | |||||
| ┈┈┈┈▏┊┈┈┈┈┊▕╲┈┈╲ | |||||
| ┈╱▔╲▏┊┈┈┈┈┊▕╱▔╲▕ | |||||
| ┈▏ ┈┈┈╰┈┈┈┈╯┈┈┈▕▕ | |||||
| ┈╲┈┈┈╲┈┈┈┈╱┈┈┈╱┈╲ | |||||
| ┈┈╲┈┈▕▔▔▔▔▏┈┈╱╲╲╲▏ | |||||
| ┈╱▔┈┈▕┈┈┈┈▏┈┈▔╲▔▔ | |||||
| ┈╲▂▂▂╱┈┈┈┈╲▂▂▂╱┈ | |||||
| If you are seeing this money that means that you are interested in my | |||||
| code. Yay!! If you are not here to hack me ... you should really consider | |||||
| contributing to some of my public projects on github. | |||||
| https://github.com/jrtechs | |||||
| --> | |||||
| <!-- Footer --> | |||||
| <footer class="text-center"> | |||||
| <div class="footer-above"> | |||||
| <div class="container"> | |||||
| <div class="row"> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>Location</h3> | |||||
| <p>Rochester Institute of Technology | |||||
| <br>1 Lomb Memorial Dr, Rochester, NY 14623</p> | |||||
| </div> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>Around the Web</h3> | |||||
| <ul class="list-inline"> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="https://www.youtube.com/c/JrtechsNet"> | |||||
| <i class="fa fa-fw fa-youtube"></i> | |||||
| </a> | |||||
| </li> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="https://github.com/jrtechs"> | |||||
| <i class="fa fa-fw fa-github"></i> | |||||
| </a> | |||||
| </li> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="http://jrtechs.net"> | |||||
| <i class="fa fa-fw fa-wordpress"></i> | |||||
| </a> | |||||
| </li> | |||||
| </ul> | |||||
| </div> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>About This Website</h3> | |||||
| <p>Check out the source code for this website on my | |||||
| <a href="https://github.com/jrtechs">github</a>.</p> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| <div class="footer-below"> | |||||
| <div class="container"> | |||||
| <div class="row"> | |||||
| <div class="col-lg-12"> | |||||
| <p class="m-0 text-center text-white"><a href="https://creativecommons.org/licenses/by-sa/4.0/" target="_blank">CC-BY-SA 4.0</a> <script type="text/javascript"> | |||||
| document.write(new Date().getFullYear()); | |||||
| </script> Jrtechs</p> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </footer> | |||||
| <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script> | |||||
| <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script> | |||||
| <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/js/bootstrap.min.js" integrity="sha384-smHYKdLADwkXOn1EmN1qk/HfnUcbVRZyYmZ4qpPea6sjB/pTJ0euyQp0Mk8ck+5T" crossorigin="anonymous"></script> | |||||
| </body> | |||||
| </html> | |||||
| @ -0,0 +1,229 @@ | |||||
| <!DOCTYPE html> | |||||
| <html lang="en"> | |||||
| <head> | |||||
| <meta charset="utf-8"> | |||||
| <title>Jrtechs Steam Friend Graph Project</title> | |||||
| <meta name="viewport" content="width=device-width, initial-scale=1"> | |||||
| <meta http-equiv="X-UA-Compatible" content="IE=edge" /> | |||||
| <link rel="stylesheet" href="css/bootstrap.css" media="screen"> | |||||
| <link rel="stylesheet" href="css/custom.min.css"> | |||||
| <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> | |||||
| </head> | |||||
| <body> | |||||
| <div class="navbar navbar-expand-lg fixed-top navbar-dark bg-primary"> | |||||
| <div class="container"> | |||||
| <a href="#" class="navbar-brand">Jrtechs Steam Graph Project</a> | |||||
| <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarResponsive" aria-controls="navbarResponsive" aria-expanded="false" aria-label="Toggle navigation"> | |||||
| <span class="navbar-toggler-icon"></span> | |||||
| </button> | |||||
| <div class="collapse navbar-collapse" id="navbarResponsive"> | |||||
| <ul class="navbar-nav"> | |||||
| <li class="nav-item dropdown"> | |||||
| <a class="nav-link dropdown-toggle" data-toggle="dropdown" href="#" id="themes">Graphs <span class="caret"></span></a> | |||||
| <div class="dropdown-menu" aria-labelledby="themes"> | |||||
| <a class="dropdown-item" href="friendsOfFriends.html">Friends of Friends</a> | |||||
| <a class="dropdown-item" href="commonFriends.html">Common Friends</a> | |||||
| <a class="dropdown-item" href="closestPath.html">Closest Path</a> | |||||
| <a class="dropdown-item" href="commonGames.html">Common Games</a> | |||||
| <a class="dropdown-item" href="bestFriends.html">Best Friends</a> | |||||
| </div> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://jrtechs.net">Blog</a> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://jrtechs.me">Resume</a> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://github.com/jrtechs">Github</a> | |||||
| </li> | |||||
| </ul> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| <!-- END SIGMA IMPORTS --> | |||||
| <div id="container"> | |||||
| <style> | |||||
| #graph-container { | |||||
| top: 5%; | |||||
| bottom: 0; | |||||
| left: 0; | |||||
| right: 0; | |||||
| z-index: 0; | |||||
| position: absolute; | |||||
| } | |||||
| </style> | |||||
| <div id="graph-container" style="width:100%; height:100%"></div> | |||||
| </div> | |||||
| <script> | |||||
| var s, | |||||
| g = { | |||||
| nodes: [], | |||||
| edges: [] | |||||
| }, | |||||
| colors = [ | |||||
| '#617db4', | |||||
| '#668f3c', | |||||
| '#c6583e', | |||||
| '#b956af' | |||||
| ]; | |||||
| s = new sigma({ | |||||
| graph: g, | |||||
| renderer: { | |||||
| container: document.getElementById('graph-container'), | |||||
| type: 'canvas' | |||||
| }, | |||||
| settings: { | |||||
| minNodeSize: 8, | |||||
| maxNodeSize: 16, | |||||
| } | |||||
| }); | |||||
| 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: request.x, | |||||
| y: request.y, | |||||
| size: Math.random(), | |||||
| color: colors[Math.floor(Math.random() * colors.length)] | |||||
| }); | |||||
| s.refresh(); | |||||
| } | |||||
| function addEdgeToGraph(request) | |||||
| { | |||||
| s.graph.addEdge({ | |||||
| id: request.id, | |||||
| source: request.p1, | |||||
| target: request.p2, | |||||
| size: Math.random(), | |||||
| }); | |||||
| 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); | |||||
| }; | |||||
| </script> | |||||
| <!- | |||||
| ┈┈╱▔▔▔▔▔╲┈┈┈HM┈HM | |||||
| ┈╱┈┈╱▔╲╲╲▏┈┈┈HMMM | |||||
| ╱┈┈╱━╱▔▔▔▔▔╲━╮┈┈ | |||||
| ▏┈▕┃▕╱▔╲╱▔╲▕╮┃┈┈ | |||||
| ▏┈▕╰━▏▊▕▕▋▕▕━╯┈┈ | |||||
| ╲┈┈╲╱▔╭╮▔▔┳╲╲┈┈┈ | |||||
| ┈╲┈┈▏╭━━━━╯▕▕┈┈┈ | |||||
| ┈┈╲┈╲▂▂▂▂▂▂╱╱┈┈┈ | |||||
| ┈┈┈┈▏┊┈┈┈┈┊┈┈┈╲┈ | |||||
| ┈┈┈┈▏┊┈┈┈┈┊▕╲┈┈╲ | |||||
| ┈╱▔╲▏┊┈┈┈┈┊▕╱▔╲▕ | |||||
| ┈▏ ┈┈┈╰┈┈┈┈╯┈┈┈▕▕ | |||||
| ┈╲┈┈┈╲┈┈┈┈╱┈┈┈╱┈╲ | |||||
| ┈┈╲┈┈▕▔▔▔▔▏┈┈╱╲╲╲▏ | |||||
| ┈╱▔┈┈▕┈┈┈┈▏┈┈▔╲▔▔ | |||||
| ┈╲▂▂▂╱┈┈┈┈╲▂▂▂╱┈ | |||||
| If you are seeing this money that means that you are interested in my | |||||
| code. Yay!! If you are not here to hack me ... you should really consider | |||||
| contributing to some of my public projects on github. | |||||
| https://github.com/jrtechs | |||||
| --> | |||||
| <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script> | |||||
| <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script> | |||||
| <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/js/bootstrap.min.js" integrity="sha384-smHYKdLADwkXOn1EmN1qk/HfnUcbVRZyYmZ4qpPea6sjB/pTJ0euyQp0Mk8ck+5T" crossorigin="anonymous"></script> | |||||
| </body> | |||||
| </html> | |||||
| @ -1,290 +0,0 @@ | |||||
| <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; | |||||
| } | |||||
| </style> | |||||
| <div id="graph-container"></div> | |||||
| </div> | |||||
| <script src="src/worker.js"></script> | |||||
| <script src="src/supervisor.js"></script> | |||||
| <script> | |||||
| sigma.utils.pkg('sigma.canvas.nodes'); | |||||
| sigma.canvas.nodes.image = (function() { | |||||
| var _cache = {}, | |||||
| _loading = {}, | |||||
| _callbacks = {}; | |||||
| // Return the renderer itself: | |||||
| var renderer = function(node, context, settings) { | |||||
| var args = arguments, | |||||
| prefix = settings('prefix') || '', | |||||
| size = node[prefix + 'size'], | |||||
| color = node.color || settings('defaultNodeColor'), | |||||
| url = node.url; | |||||
| if (_cache[url]) { | |||||
| context.save(); | |||||
| // Draw the clipping disc: | |||||
| context.beginPath(); | |||||
| context.arc( | |||||
| node[prefix + 'x'], | |||||
| node[prefix + 'y'], | |||||
| node[prefix + 'size'], | |||||
| 0, | |||||
| Math.PI * 2, | |||||
| true | |||||
| ); | |||||
| context.closePath(); | |||||
| context.clip(); | |||||
| // Draw the image | |||||
| context.drawImage( | |||||
| _cache[url], | |||||
| node[prefix + 'x'] - size, | |||||
| node[prefix + 'y'] - size, | |||||
| 2 * size, | |||||
| 2 * size | |||||
| ); | |||||
| // Quit the "clipping mode": | |||||
| context.restore(); | |||||
| // Draw the border: | |||||
| context.beginPath(); | |||||
| context.arc( | |||||
| node[prefix + 'x'], | |||||
| node[prefix + 'y'], | |||||
| node[prefix + 'size'], | |||||
| 0, | |||||
| Math.PI * 2, | |||||
| true | |||||
| ); | |||||
| context.lineWidth = size / 5; | |||||
| context.strokeStyle = node.color || settings('defaultNodeColor'); | |||||
| context.stroke(); | |||||
| } else { | |||||
| sigma.canvas.nodes.image.cache(url); | |||||
| sigma.canvas.nodes.def.apply( | |||||
| sigma.canvas.nodes, | |||||
| args | |||||
| ); | |||||
| } | |||||
| }; | |||||
| // Let's add a public method to cache images, to make it possible to | |||||
| // preload images before the initial rendering: | |||||
| renderer.cache = function(url, callback) { | |||||
| if (callback) | |||||
| _callbacks[url] = callback; | |||||
| if (_loading[url]) | |||||
| return; | |||||
| var img = new Image(); | |||||
| img.onload = function() { | |||||
| _loading[url] = false; | |||||
| _cache[url] = img; | |||||
| if (_callbacks[url]) { | |||||
| _callbacks[url].call(this, img); | |||||
| delete _callbacks[url]; | |||||
| } | |||||
| }; | |||||
| _loading[url] = true; | |||||
| img.src = url; | |||||
| }; | |||||
| return renderer; | |||||
| })(); | |||||
| // Now that's the renderer has been implemented, let's generate a graph | |||||
| // to render: | |||||
| var i, | |||||
| s, | |||||
| img, | |||||
| N = 50, | |||||
| E = 300, | |||||
| g = { | |||||
| nodes: [], | |||||
| edges: [] | |||||
| }, | |||||
| urls = [ | |||||
| 'img/img1.png', | |||||
| 'img/img2.png', | |||||
| 'img/img3.png', | |||||
| 'img/img4.png' | |||||
| ], | |||||
| loaded = 0, | |||||
| colors = [ | |||||
| '#617db4', | |||||
| '#668f3c', | |||||
| '#c6583e', | |||||
| '#b956af' | |||||
| ]; | |||||
| // // Generate a random graph, with ~30% nodes having the type "image": | |||||
| // for (i = 0; i < N; i++) { | |||||
| // img = Math.random() >= 0.7; | |||||
| // g.nodes.push({ | |||||
| // id: 'n' + i, | |||||
| // label: 'Node ' + i, | |||||
| // type: img ? 'image' : 'def', | |||||
| // url: img ? urls[Math.floor(Math.random() * urls.length)] : null, | |||||
| // x: Math.random(), | |||||
| // y: Math.random(), | |||||
| // size: Math.random(), | |||||
| // color: colors[Math.floor(Math.random() * colors.length)] | |||||
| // }); | |||||
| // } | |||||
| // | |||||
| // for (i = 0; i < E; i++) | |||||
| // g.edges.push({ | |||||
| // id: 'e' + i, | |||||
| // source: 'n' + (Math.random() * N | 0), | |||||
| // target: 'n' + (Math.random() * N | 0), | |||||
| // size: Math.random() | |||||
| // }); | |||||
| // Then, wait for all images to be loaded before instanciating sigma: | |||||
| s = new sigma({ | |||||
| graph: g, | |||||
| renderer: { | |||||
| // IMPORTANT: | |||||
| // This works only with the canvas renderer, so the | |||||
| // renderer type set as "canvas" is necessary here. | |||||
| container: document.getElementById('graph-container'), | |||||
| type: 'canvas' | |||||
| }, | |||||
| settings: { | |||||
| minNodeSize: 8, | |||||
| maxNodeSize: 16, | |||||
| } | |||||
| }); | |||||
| 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, | |||||
| type: img ? 'image' : 'def', | |||||
| url: request.url, | |||||
| x: request.x, | |||||
| y: request.y, | |||||
| size: Math.random(), | |||||
| color: colors[Math.floor(Math.random() * colors.length)] | |||||
| }); | |||||
| s.refresh(); | |||||
| } | |||||
| function addEdgeToGraph(request) | |||||
| { | |||||
| s.graph.addEdge({ | |||||
| id: request.id, | |||||
| source: request.p1, | |||||
| target: request.p2, | |||||
| size: Math.random(), | |||||
| }); | |||||
| 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> | |||||
| @ -1,26 +1,136 @@ | |||||
| <!doctype html> | |||||
| <html> | |||||
| <!DOCTYPE html> | |||||
| <html lang="en"> | |||||
| <head> | <head> | ||||
| <script> | |||||
| 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); | |||||
| }; | |||||
| // Log messages from the server | |||||
| connection.onmessage = function (e) { | |||||
| console.log('Server: ' + e.data); | |||||
| }; | |||||
| </script> | |||||
| <meta charset="utf-8"> | |||||
| <title>Jrtechs Steam Friend Graph Project</title> | |||||
| <meta name="viewport" content="width=device-width, initial-scale=1"> | |||||
| <meta http-equiv="X-UA-Compatible" content="IE=edge" /> | |||||
| <link rel="stylesheet" href="css/bootstrap.css" media="screen"> | |||||
| <link rel="stylesheet" href="css/custom.min.css"> | |||||
| </head> | </head> | ||||
| <body> | <body> | ||||
| <ul id='messages'></ul> | |||||
| <div class="navbar navbar-expand-lg fixed-top navbar-dark bg-primary"> | |||||
| <div class="container"> | |||||
| <a href="#" class="navbar-brand">Jrtechs Steam Graph Project</a> | |||||
| <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarResponsive" aria-controls="navbarResponsive" aria-expanded="false" aria-label="Toggle navigation"> | |||||
| <span class="navbar-toggler-icon"></span> | |||||
| </button> | |||||
| <div class="collapse navbar-collapse" id="navbarResponsive"> | |||||
| <ul class="navbar-nav"> | |||||
| <li class="nav-item dropdown"> | |||||
| <a class="nav-link dropdown-toggle" data-toggle="dropdown" href="#" id="themes">Graphs <span class="caret"></span></a> | |||||
| <div class="dropdown-menu" aria-labelledby="themes"> | |||||
| <a class="dropdown-item" href="friendsOfFriends.html">Friends of Friends</a> | |||||
| <a class="dropdown-item" href="commonFriends.html">Common Friends</a> | |||||
| <a class="dropdown-item" href="closestPath.html">Closest Path</a> | |||||
| <a class="dropdown-item" href="commonGames.html">Common Games</a> | |||||
| <a class="dropdown-item" href="bestFriends.html">Best Friends</a> | |||||
| </div> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://jrtechs.net">Blog</a> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://jrtechs.me">Resume</a> | |||||
| </li> | |||||
| <li class="nav-item"> | |||||
| <a class="nav-link" href="https://github.com/jrtechs">Github</a> | |||||
| </li> | |||||
| </ul> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| <div class="container"> | |||||
| <br><br><br> | |||||
| <h1>TDLTR</h1> | |||||
| </div> | |||||
| <!- | |||||
| ┈┈╱▔▔▔▔▔╲┈┈┈HM┈HM | |||||
| ┈╱┈┈╱▔╲╲╲▏┈┈┈HMMM | |||||
| ╱┈┈╱━╱▔▔▔▔▔╲━╮┈┈ | |||||
| ▏┈▕┃▕╱▔╲╱▔╲▕╮┃┈┈ | |||||
| ▏┈▕╰━▏▊▕▕▋▕▕━╯┈┈ | |||||
| ╲┈┈╲╱▔╭╮▔▔┳╲╲┈┈┈ | |||||
| ┈╲┈┈▏╭━━━━╯▕▕┈┈┈ | |||||
| ┈┈╲┈╲▂▂▂▂▂▂╱╱┈┈┈ | |||||
| ┈┈┈┈▏┊┈┈┈┈┊┈┈┈╲┈ | |||||
| ┈┈┈┈▏┊┈┈┈┈┊▕╲┈┈╲ | |||||
| ┈╱▔╲▏┊┈┈┈┈┊▕╱▔╲▕ | |||||
| ┈▏ ┈┈┈╰┈┈┈┈╯┈┈┈▕▕ | |||||
| ┈╲┈┈┈╲┈┈┈┈╱┈┈┈╱┈╲ | |||||
| ┈┈╲┈┈▕▔▔▔▔▏┈┈╱╲╲╲▏ | |||||
| ┈╱▔┈┈▕┈┈┈┈▏┈┈▔╲▔▔ | |||||
| ┈╲▂▂▂╱┈┈┈┈╲▂▂▂╱┈ | |||||
| If you are seeing this money that means that you are interested in my | |||||
| code. Yay!! If you are not here to hack me ... you should really consider | |||||
| contributing to some of my public projects on github. | |||||
| https://github.com/jrtechs | |||||
| --> | |||||
| <!-- Footer --> | |||||
| <footer class="text-center"> | |||||
| <div class="footer-above"> | |||||
| <div class="container"> | |||||
| <div class="row"> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>Location</h3> | |||||
| <p>Rochester Institute of Technology | |||||
| <br>1 Lomb Memorial Dr, Rochester, NY 14623</p> | |||||
| </div> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>Around the Web</h3> | |||||
| <ul class="list-inline"> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="https://www.youtube.com/c/JrtechsNet"> | |||||
| <i class="fa fa-fw fa-youtube"></i> | |||||
| </a> | |||||
| </li> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="https://github.com/jrtechs"> | |||||
| <i class="fa fa-fw fa-github"></i> | |||||
| </a> | |||||
| </li> | |||||
| <li class="list-inline-item"> | |||||
| <a class="btn-social btn-outline" href="http://jrtechs.net"> | |||||
| <i class="fa fa-fw fa-wordpress"></i> | |||||
| </a> | |||||
| </li> | |||||
| </ul> | |||||
| </div> | |||||
| <div class="footer-col col-md-4"> | |||||
| <h3>About This Website</h3> | |||||
| <p>Check out the source code for this website on my | |||||
| <a href="https://github.com/jrtechs">github</a>.</p> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| <div class="footer-below"> | |||||
| <div class="container"> | |||||
| <div class="row"> | |||||
| <div class="col-lg-12"> | |||||
| <p class="m-0 text-center text-white"><a href="https://creativecommons.org/licenses/by-sa/4.0/" target="_blank">CC-BY-SA 4.0</a> <script type="text/javascript"> | |||||
| document.write(new Date().getFullYear()); | |||||
| </script> Jrtechs</p> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </footer> | |||||
| <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script> | |||||
| <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script> | |||||
| <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/js/bootstrap.min.js" integrity="sha384-smHYKdLADwkXOn1EmN1qk/HfnUcbVRZyYmZ4qpPea6sjB/pTJ0euyQp0Mk8ck+5T" crossorigin="anonymous"></script> | |||||
| </body> | </body> | ||||
| </html> | |||||
| </html> | |||||