vis.js is a dynamic, browser-based visualization library
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.

36 lines
882 B

  1. class CentralGravitySolver {
  2. constructor(body, physicsBody, options) {
  3. this.body = body;
  4. this.physicsBody = physicsBody;
  5. this.setOptions(options);
  6. }
  7. setOptions(options) {
  8. this.options = options;
  9. }
  10. solve() {
  11. var dx, dy, distance, node, i;
  12. var nodes = this.body.nodes;
  13. var nodeIndices = this.physicsBody.physicsNodeIndices;
  14. var forces = this.physicsBody.forces;
  15. var gravity = this.options.centralGravity;
  16. var gravityForce = 0;
  17. for (i = 0; i < nodeIndices.length; i++) {
  18. let nodeId = nodeIndices[i];
  19. node = nodes[nodeId];
  20. dx = -node.x;
  21. dy = -node.y;
  22. distance = Math.sqrt(dx * dx + dy * dy);
  23. gravityForce = (distance === 0) ? 0 : (gravity / distance);
  24. forces[nodeId].x = dx * gravityForce;
  25. forces[nodeId].y = dy * gravityForce;
  26. }
  27. }
  28. }
  29. export default CentralGravitySolver;