Предположим имеется 1 изображение машины. Необходимо создать два объекта Image с этой машиной и двигать эти два изображения асинхронно. Привожу код, работает он явно не так как нужно, по задумке - вторая машина должна изначально отставать от первой и обе должны двигать влево с какой-то скоростью. В итоге получается слияние двух машин, будто это не два разных объекта, а один.
Наработки: https://jsfiddle.net/o236kta5/2/
<html>
<head>
</head>
<body>
<canvas id="canvas" width="550" height="550"></canvas>
<script type="text/javascript">
window.onload = function() {
var canvas = document.getElementById("canvas")
ctx = canvas.getContext('2d')
//
var pic = [];
var timers = [];
for (var i = 0; i < 2; i++) {
pic[i] = new Image()
pic[i].src = "http://icons.iconarchive.com/icons/iconshow/transport/64/Sportscar-car-2-icon.png";
//pic[i].onload = function(pic) {
animate(pic[i]);
//}
}
function animate (pic, x){
timers[i] = setInterval(function() {
var x = 250 + i * 20; // начальная координата картинки по горизонтали
motion(pic, x);
}, 1000 / 30);
}
// функция движения картинки
function motion(picture, xcord) {
console.log(picture);
var pic = picture;
var x = xcord;
setInterval(function() {
ctx.clearRect(0, 0, canvas.width, canvas.height);
ctx.drawImage(pic, x, 0) // выводим картинку по координатам (pic, x, 0)
x-- // увеличиваем координату X
}, 1000 / 30);
}
}
</script>
</body>
</html>
Залог плавной анимации - функция положения объектов от времени между кадрами
setInterval
это плохо, но срабатывает через фиксированные интервалы времени, для вызова отрисовки в современных браузерах есть специальный метод -requestAnimationFrame
, браузер сам вызывает функцию переданную в этот метод, когда соберется отрисовать следующий кадр, на разных платформах это работает по-разному, например на мобильных устройствах он вызывается реже для экономии электроэнергии, так же он реже вызывается для неактивных вкладок.
let t = 0
let c = canvas.getContext('2d');
let cars = Array(7).fill(0).map((e,i) => ({
x: 560, y: i*20,
v: 0.2 + Math.random()/3
}));
function draw(dt) { // dt время с начала анимации
c.clearRect(0, 0, canvas.width, canvas.height);
cars.forEach(car => {
car.x -= (dt-t)*car.v;
car.x = car.x < 0 ? 600 : car.x;
c.drawImage(img, car.x , car.y, img.width, img.height);
});
t = dt;
requestAnimationFrame(draw);
}
<canvas id="canvas" width="640" height="175"></canvas>
<img id="img" style="display:none" onload="draw(0)" src=""/>
Айфон мало держит заряд, разбираемся с проблемой вместе с AppLab
Изучая backend, столкнулся с такой проблемой недопонимания: есть сайт, сервер Nodejs (в принципе, какой угодно, но меня интересует именно Nodejs) и зашел...
Никак не получается добиться желаемого результата со slider-ом жуквэриЕсть шаг в 5, хотелось бы получить labels в виде 1,5,10,15,20 и т
Есть вот такой код формыОн по сути отправляет директорию, в которой расположено изображение и само название изображения