Показать сообщение отдельно
  #7 (permalink)  
Старый 05.07.2017, 16:08
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,131

canvas Движение объектов по массиву координат

мысли вслух
<!DOCTYPE html>
<html>

  <head>
 <script>
     if (!Object.assign) {
  Object.defineProperty(Object, 'assign', {
    enumerable: false,
    configurable: true,
    writable: true,
    value: function(target, firstSource) {
      'use strict';
      if (target === undefined || target === null) {
        throw new TypeError('Cannot convert first argument to object');
      }

      var to = Object(target);
      for (var i = 1; i < arguments.length; i++) {
        var nextSource = arguments[i];
        if (nextSource === undefined || nextSource === null) {
          continue;
        }

        var keysArray = Object.keys(Object(nextSource));
        for (var nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex++) {
          var nextKey = keysArray[nextIndex];
          var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);
          if (desc !== undefined && desc.enumerable) {
            to[nextKey] = nextSource[nextKey];
          }
        }
      }
      return to;
    }
  });
}
 </script>
  </head>

  <body>
   <canvas id="canvas" width="400" height="400"></canvas>

   <script>
 var Ball = function(data) {
    this.opt = {
        index: -1,
        queue: [],
        loop: false,
        startTime: 0,
        timer: null
    };
    this.init(data);
    this.x, this.y
};
Ball.prototype.init = function(data) {
    var opt = Object.assign(this.opt, data || {});
    opt.startTime = performance.now();
    opt.index++;
    opt.loop && (opt.index %= opt.queue.length);
};
Ball.prototype.move = function() {

    var d = this.opt.startTime;
    var data = this.opt.queue[this.opt.index];
    if(!data) return;
    var b = (performance.now() - d) / data.duration;
        1 <= b && (b = 1);
        this.x = data.from.x + (data.to.x - data.from.x) * b | 0;
        this.y = data.from.y + (data.to.y - data.from.y) * b | 0;
        1 == b && this.init();


};
var circle = function(x, y, radius, fillCircle) {
    ctx.beginPath();
    ctx.arc(x, y, radius, 0, Math.PI * 2, false);
    ctx.fillStyle = "green";
    if (fillCircle) ctx.fill();
    else ctx.stroke()
};
Ball.prototype.draw = function() {
    circle(this.x, this.y, 10, true)
};
var canvas = document.getElementById("canvas");
var ctx = canvas.getContext("2d");
var obj = {
    queue: [{
        from: {
            x: 100,
            y: 100
        },
        to: {
            x: 150,
            y: 200
        },
        duration: 1000
    }, {
        from: {
            x: 150,
            y: 200
        },
        to: {
            x: 200,
            y: 100
        },
        duration: 3E3
    }, {
        from: {
            x: 200,
            y: 100
        },
        to: {
            x: 250,
            y: 200
        },
        duration: 1000
    }, {
        from: {
            x: 250,
            y: 200
        },
        to: {
            x: 300,
            y: 100
        },
        duration: 3000
    }],
    loop: true
};
var ball = [];
var i = 0;
(function x() {
    ball[i] = new Ball(obj);
    ++i < 50 && window.setTimeout(x, 500)
})();
var width = canvas.width;
var height = canvas.height;
requestAnimationFrame(function test() {
    ctx.clearRect(0, 0, width, height);
    for (var i = 0; i < ball.length; i++) {
    ball[i].move();
    ball[i].draw();
    }
    ctx.strokeRect(0, 0, width, height);
    requestAnimationFrame(test)
});
   </script>
  </body>

</html>

Последний раз редактировалось рони, 05.07.2017 в 17:00. Причина: небольшая оптимизация и для ie Object.assign
Ответить с цитированием