Search code examples
javascripthtmlcollision-detectionphaser-framework

Why isnt the bird colliding with the ledges?


I am making a flappy bird game using phaser.js.

My problem is that it doesn't collide with the ledges. And how do you change the camera (you know in flappy bird they like move the camera)?

Any other tips on making my game would be greatly appreciated!

JSFiddle

var game = new Phaser.Game(800, 600, Phaser.CANVAS, 'phaser-demo', {

preload: preload,
  create: create,
  update: update,
  render: render
});

var player;
var starfield;
var cursors;
var fireButton;
var gameOver;
var upLedge;
var vaRandomUpLedgeSize;
var bottomLedge;



function preload() {
  game.load.image('starfield', '');
  game.load.image('player', 'https://i.imgur.com/JArA3tQ.png');
  game.load.image('upLedge', '');
  game.load.image('bottomLedge', '');

}

function create() {
  //  The scrolling starfield background
  game.physics.startSystem(Phaser.Physics.ARCADE);

  starfield = game.add.tileSprite(0, 0, 800, 600, 'starfield');
  starfield.scale.setTo(1, 2.5);
  starfield.enableBody = true;


  //  The hero!
  player = game.add.sprite(50, 400, 'player');
  player.anchor.setTo(0.5, 0.5);
  player.scale.setTo(1.25, 1.5);
  game.physics.arcade.enable(player);
  game.physics.enable(player, Phaser.Physics.ARCADE);
  player.body.gravity.y = 450;
  player.body.collideWorldBounds = true;




  upLedge = game.add.sprite(400, 0, 'upLedge');
  bottomLedge = game.add.sprite(400, 365, 'bottomLedge');

  randomLedgeSize();
  upLedge.scale.setTo(1, vaRandomUpLedgeSize);

  randomLedgeSize();
  bottomLedge.scale.setTo(1, vaRandomUpLedgeSize);



  fireButton = game.input.keyboard.addKey(Phaser.Keyboard.SPACEBAR);
  //  And some controls to play the game with
  cursors = game.input.keyboard.createCursorKeys();
}

function update() {
  //  Scroll the background
  starfield.tilePosition.x -= 2;

  player.x++;
  //SPACEBAR 
  if (player.y >= 591.75) {
    player.y = 591.75;
    player.x--;


  }
  if (fireButton.isDown) {
    player.body.velocity.y = -250;
  }

  game.physics.arcade.collide(player, upLedge);
  game.physics.arcade.collide(player, bottomLedge);

}

function render() {

}

function randomLedgeSize() {
  vaRandomUpLedgeSize = Math.floor(Math.random() * (3 - 1)) + 1;

  if (vaRandomUpLedgeSize <= 1.5) {
    vaRandomUpLedgeSize = 1;
  } else {
    vaRandomUpLedgeSize = 2;
  }
}

function randomLedgeSizeBot() {
  vaRandomUpLedgeSize = Math.floor(Math.random() * (3 - 1)) + 1;

  if (vaRandomUpLedgeSize <= 1.5) {
    bottomLedge.y = 500;
  } else {
    vaRandomUpLedgeSize = 2;
  }
}

Solution

  • See here:

    The collisions only fire if the sprite.body has velocity.

    So what I did was change the update() function: I removed the call to player.x++; and in the create() function I added an X velocity to the player.

    JSfiddle

    var game = new Phaser.Game(800, 600, Phaser.CANVAS, 'phaser-demo', {
      preload: preload,
      create: create,
      update: update,
      render: render
    });
    
    var player;
    var starfield;
    var cursors;
    var fireButton;
    var gameOver;
    var ledges;
    
    function preload() {
      game.load.image('starfield', '');
      game.load.image('player', 'https://i.imgur.com/JArA3tQ.png');
      game.load.image('upLedge', '');
      game.load.image('bottomLedge', '');
    
    }
    
    function create() {
      //  The scrolling starfield background
      game.physics.startSystem(Phaser.Physics.ARCADE);
    
      starfield = game.add.tileSprite(0, 0, 800, 600, 'starfield');
      starfield.scale.setTo(1, 2.5);
    
      //  The hero!
      player = game.add.sprite(50, 400, 'player');
      player.anchor.setTo(0.5, 0.5);
      player.scale.setTo(1.25, 1.5);  
      game.physics.arcade.enable(player);
      game.physics.enable(player, Phaser.Physics.ARCADE);
      player.enableBody = true;
      player.body.gravity.y = 450;
      player.body.collideWorldBounds = true;
      player.body.velocity.x = 100;
    
      // The ledges
      ledges = game.add.group();
      ledges.enableBody = true;
      var upLedge = ledges.create(200, 0, 'upLedge');
      upLedge.body.immovable = true;
      var bottomLedge = ledges.create(200, 465, 'bottomLedge');
      bottomLedge.body.immovable = true;
    
      //  Controls to play the game with
      fireButton = game.input.keyboard.addKey(Phaser.Keyboard.SPACEBAR);
      cursors = game.input.keyboard.createCursorKeys();
    }
    
    function update() {
      //  Scroll the background
      starfield.tilePosition.x -= 2;
    
      // If spacebar is pressed, increase Y velocity
      if (fireButton.isDown) {
        player.body.velocity.y = -250;
      }
    
        // Check for collisions
      game.physics.arcade.collide(player, ledges);
    }
    
    function render() {
    }