Hello,
It seems to me that setting a sprite to a set velocity actually sets a lower amount, then sets it higher after a duration. See the following code:
import Phaser from "phaser";
const config = {
type: Phaser.AUTO,
width: 800,
height: 600,
backgroundColor: "#000",
parent: "game-container",
pixelArt: true,
scene: {
preload: preload,
create: create
},
physics: {
default: "arcade",
arcade: {
debug: true
}
}
};
const game = new Phaser.Game(config);
function preload() {
this.load.image('cursor', '../assets/images/crosshair.png');
this.load.image("player", "../assets/images/player.png");
}
function create() {
this.calculateDegreesFromRadian = (radian) => {
return radian * 180 / Math.PI;
}
this.calculateAngleInDegrees = (x, y, x2, y2) => {
return this.calculateDegreesFromRadian(Phaser.Math.Angle.Between(x, y, x2, y2));
}
this.player = this.physics.add.image(20, 20, "player", 0);
this.cursor = this.add.image(0, 0, 'cursor').setVisible(true);
this.input.on('pointermove', function (pointer) {
this.cursor.setPosition(pointer.x, pointer.y);
this.physics.velocityFromAngle(this.calculateAngleInDegrees(this.player.x, this.player.y, this.cursor.x, this.cursor.y), 100, this.player.body.velocity);
}, this);
}
Which produces the following: https://gyazo.com/8444a740545136c0029588c87396655b
Why does the sprite speed up after a time? It seems to do this even if i am just statically setting a X or Y velocity with no calculations as to the cursor.
Thanks