Collision detection via overlap() not working in phaser.io

930 Views Asked by At

Please note that I've created the following code entirely using Phaser.io.

So I've created an enemy group and also a weapon group (using the inbuilt game.add.weapon()).

I check for overlap between these two groups but for some reason the hitEnemy() function is never fired.

I believe this has something to do with using the inbuilt weapon group, but I can't figure out what exactly it is.

var playState = {
    preload: function () {
        game.load.image('player', 'assets/player.png');
        game.load.image('enemy', 'assets/enemy.png');
        game.load.image('floor', 'assets/floor.png');
        game.load.image('bullet', 'assets/bullet.png');
    },

    create: function () {
        game.stage.backgroundColor = '#000000';
        game.physics.startSystem(Phaser.Physics.ARCADE);
        game.renderer.renderSession.roundPixels = true;

        this.cursors = game.input.keyboard.createCursorKeys();
        this.fireButton = game.input.keyboard.addKey(Phaser.Keyboard.SPACEBAR);

        this.createBullets();

        this.createEnemies(game.width/2, 120, 'enemy');
     },
     update: function () {
        game.physics.arcade.collide(this.player, this.floor);
        game.physics.arcade.overlap(this.weapon, this.enemies, this.hitEnemy, null, this);
     },
     createBullets: function () {    
        this.weapon = game.add.weapon(30, 'bullet');
        this.weapon.bulletKillType = Phaser.Weapon.KILL_WORLD_BOUNDS;
        this.weapon.bulletSpeed = 850;
        this.weapon.fireRate = 100;
        this.weapon.trackSprite(this.player);
    },
    createEnemies: function (x,y ,size) {
        this.enemies = game.add.group();
        this.enemies.enableBody = true;
        this.enemies.physicsBodyType = Phaser.Physics.ARCADE;

        var asteroid = this.enemies.create(x, y, size);
        asteroid.anchor.setTo(0.5,0.5);
        asteroid.name = "enemy1";
        asteroid.body.immovable;
    },
    hitEnemy: function (player, enemy) {
        this.enemy.kill();
        console.log("Hit");
    },
};
1

There are 1 best solutions below

0
On BEST ANSWER

Found the solution.

Instead of checking overlap with this.enemies and this.weapon. I was supposed to check collision with this.enemies and this.weapon.bullets