Anders and Briegel in Python
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

39 lines
1.2KB

  1. var materials = {};
  2. var curveProperties = {
  3. splineDensity: 10,
  4. curvature: 20
  5. };
  6. // Is called on boot
  7. materials.prepare = function() {
  8. var ballSprite = new THREE.Texture(document.getElementById("ball"));
  9. ballSprite.needsUpdate = true;
  10. materials.edge = new THREE.LineBasicMaterial({
  11. color: "gray",
  12. transparent: false,
  13. linewidth: 5
  14. });
  15. materials.edge.depthTest = false;
  16. materials.qubit = new THREE.PointsMaterial({
  17. size: 0.6,
  18. map: ballSprite,
  19. alphaTest: 0.5,
  20. transparent: true,
  21. vertexColors: THREE.VertexColors
  22. });
  23. };
  24. materials.makeCurve = function(a, b) {
  25. var length = new THREE.Vector3().subVectors(a, b).length();
  26. var bend = new THREE.Vector3(length / curveProperties.curvature, length / curveProperties.curvature, 0);
  27. var mid = new THREE.Vector3().add(a).add(b).multiplyScalar(0.5).add(bend);
  28. var spline = new THREE.CatmullRomCurve3([a, mid, b]);
  29. var geometry = new THREE.Geometry();
  30. var splinePoints = spline.getPoints(curveProperties.splineDensity);
  31. Array.prototype.push.apply(geometry.vertices, splinePoints);
  32. return new THREE.Line(geometry, materials.edge);
  33. };