@@ -1,34 +0,0 @@ | |||
var ws; | |||
function connect_to_server() { | |||
ws = new WebSocket("ws://localhost:5000"); | |||
ws.onopen = function() | |||
{ | |||
message.innerHTML = "Connected to server."; | |||
message.className = "visible"; | |||
}; | |||
ws.onerror = function(err) | |||
{ | |||
message.innerHTML = "Could not connect to server."; | |||
message.className = "visible"; | |||
}; | |||
ws.onmessage = function (evt) | |||
{ | |||
console.log("Received update"); | |||
var new_state = JSON.parse(evt.data); | |||
vops = new_state.vops; | |||
ngbh = new_state.ngbh; | |||
meta = new_state.meta; | |||
updateScene(); | |||
}; | |||
ws.onclose = function() | |||
{ | |||
message.innerHTML = "Connection to server lost. <a href='#' onclick='javascript:connect_to_server()'>Reconnect</a>."; | |||
message.className = "visible"; | |||
}; | |||
} | |||
@@ -1,26 +0,0 @@ | |||
// Curve settings | |||
var curveProperties = { | |||
splineDensity: 10, | |||
curvature: 100 | |||
}; | |||
// Add a curved edge between two points | |||
function makeEdge(start, end) { | |||
// Make the geometry of the curve | |||
//var a = new THREE.Vector3(start.x, start.y, start.z); | |||
//var b = new THREE.Vector3(end.x, end.y, end.z); | |||
var a = start; | |||
var b = end; | |||
var length = new THREE.Vector3().subVectors(a, b).length(); | |||
var bend = new THREE.Vector3(length / curveProperties.curvature, length / curveProperties.curvature, 0); | |||
var mid = new THREE.Vector3().add(a).add(b).multiplyScalar(0.5).add(bend); | |||
var spline = new THREE.CatmullRomCurve3([a, mid, b]); | |||
var geometry = new THREE.Geometry(); | |||
var splinePoints = spline.getPoints(curveProperties.splineDensity); | |||
Array.prototype.push.apply(geometry.vertices, splinePoints); | |||
// Make the actual Object3d thing | |||
var line = new THREE.Line(geometry, materials.edge); | |||
return line; | |||
} | |||
@@ -1,4 +1,36 @@ | |||
var colors = ["red", "green", "yellow", "blue", "pink", "orange", "purple"]; | |||
var ws; | |||
function connect_to_server() { | |||
ws = new WebSocket("ws://localhost:5000"); | |||
ws.onopen = function() | |||
{ | |||
message.innerHTML = "Connected to server."; | |||
message.className = "visible"; | |||
}; | |||
ws.onerror = function(err) | |||
{ | |||
message.innerHTML = "Could not connect to server."; | |||
message.className = "visible"; | |||
}; | |||
ws.onmessage = function (evt) | |||
{ | |||
console.log("Received update"); | |||
var new_state = JSON.parse(evt.data); | |||
vops = new_state.vops; | |||
ngbh = new_state.ngbh; | |||
meta = new_state.meta; | |||
updateScene(); | |||
}; | |||
ws.onclose = function() | |||
{ | |||
message.innerHTML = "Connection to server lost. <a href='#' onclick='javascript:connect_to_server()'>Reconnect</a>."; | |||
message.className = "visible"; | |||
}; | |||
} | |||
function updateScene() { | |||
var oldState = scene.getObjectByName("graphstate"); | |||
@@ -22,7 +54,7 @@ function updateScene() { | |||
var startpos = new THREE.Vector3(start[0], start[1], start[2]); | |||
var end = abj.meta[edge[1]].position; | |||
var endpos = new THREE.Vector3(end[0], end[1], end[2]); | |||
var newEdge = makeEdge(startpos, endpos); | |||
var newEdge = makeCurve(startpos, endpos); | |||
edges.add(newEdge); | |||
} | |||
@@ -10,13 +10,12 @@ | |||
<body> | |||
<script type="text/javascript" src="three.js"></script> | |||
<script type="text/javascript" src="libs.js"></script> | |||
<script type="text/javascript" src="orbitcontrols.js"></script> | |||
<script type="text/javascript" src="tables.js"></script> | |||
<script type="text/javascript" src="anders_briegel.js"></script> | |||
<script type="text/javascript" src="materials.js"></script> | |||
<script type="text/javascript" src="api.js"></script> | |||
<script type="text/javascript" src="curve.js"></script> | |||
<script type="text/javascript" src="graph.js"></script> | |||
<script type="text/javascript" src="tables.js"></script> | |||
<script type="text/javascript" src="anders_briegel.js"></script> | |||
<script type="text/javascript" src="main.js"></script> | |||
<img id="ball" src=""/ | |||
style=display:none;> | |||
@@ -32,3 +32,26 @@ function loadMaterials(argument) { | |||
materials.qubit = new THREE.PointsMaterial(qubitStyle); | |||
} | |||
// Curve settings | |||
var curveProperties = { | |||
splineDensity: 10, | |||
curvature: 100 | |||
}; | |||
// Add a curved edge between two points | |||
function makeCurve(a, b) { | |||
// Make the geometry of the curve | |||
var length = new THREE.Vector3().subVectors(a, b).length(); | |||
var bend = new THREE.Vector3(length / curveProperties.curvature, length / curveProperties.curvature, 0); | |||
var mid = new THREE.Vector3().add(a).add(b).multiplyScalar(0.5).add(bend); | |||
var spline = new THREE.CatmullRomCurve3([a, mid, b]); | |||
var geometry = new THREE.Geometry(); | |||
var splinePoints = spline.getPoints(curveProperties.splineDensity); | |||
Array.prototype.push.apply(geometry.vertices, splinePoints); | |||
// Make the actual Object3d thing | |||
var line = new THREE.Line(geometry, materials.edge); | |||
return line; | |||
} | |||