106 line
3.4KB

  1. function Слежение(состояние, изображения, тела)
  2. {
  3. this.создать = function()
  4. {
  5. this.умолчание = {
  6. смещение: [0, 0],
  7. скорость: 1,
  8. предел: 0,
  9. };
  10. this.задано = {};
  11. };
  12. this.обновить = function()
  13. {
  14. for (var имя in this.задано)
  15. {
  16. this.расположитьИзображение(имя);
  17. }
  18. };
  19. this.обработатьКлюч = function(ключ, путь, значение)
  20. {
  21. if (путь[0] != "слежение")
  22. {
  23. return;
  24. }
  25. var имя = путь[1];
  26. var свойство = путь.slice(2).join(".");
  27. if (!this.задано[имя])
  28. {
  29. this.задано[имя] = {};
  30. }
  31. this.задано[имя][свойство] = значение;
  32. };
  33. this.расположитьИзображение = function(имя)
  34. {
  35. let за = this.задано[имя];
  36. let тело = тела.тела[за.тело];
  37. let элемент = изображения.элементы[за.изображение];
  38. if (!тело || !элемент)
  39. {
  40. return;
  41. }
  42. let ум = this.умолчание;
  43. // Параметры.
  44. var скорость = за.скорость ? за.скорость : ум.скорость;
  45. var смещениеX = за["смещение.0"] ? за["смещение.0"] : ум.смещение[0];
  46. var смещениеY = за["смещение.1"] ? за["смещение.1"] : ум.смещение[1];
  47. var предел = за.предел ? за.предел : ум.предел;
  48. // Текущая позиция.
  49. var x0 = 0;
  50. if (элемент.dataset.слежениеX)
  51. {
  52. x0 = элемент.dataset.слежениеX;
  53. }
  54. var y0 = 0;
  55. if (элемент.dataset.слежениеY)
  56. {
  57. y0 = элемент.dataset.слежениеY;
  58. }
  59. // Целевая позиция.
  60. var x1 = тело.position.x + смещениеX;
  61. var y1 = тело.position.y + смещениеY;
  62. // Radians -> Degrees.
  63. var угол = тело.angle * 180 / Math.PI;
  64. // Устанавливаемая плавно позиция.
  65. var x = this.lerp(x0, x1, скорость, предел);
  66. var y = this.lerp(y0, y1, скорость, предел);
  67. элемент.dataset.слежениеX = x;
  68. элемент.dataset.слежениеY = y;
  69. var описание = {
  70. пр: [x, y],
  71. угол: угол,
  72. };
  73. состояние.разобрать({
  74. изображения: {
  75. [за.изображение]: описание,
  76. },
  77. });
  78. };
  79. this.lerp = function(v0, v1, t, предел) {
  80. // Убираем мельтешение в случае наличия предела.
  81. if (предел)
  82. {
  83. var delta = Math.abs(v0 - v1);
  84. if (delta < предел) {
  85. return v0;
  86. }
  87. }
  88. return v0 * (1 - t) + v1 * t;
  89. };
  90. // Конструктор.
  91. this.создать();
  92. };