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.

98 lines
3.2KB

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