Jump to content

Why isnt the bird and ledges colliding?


amanuel
 Share

Recommended Posts

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


Here is the code:



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;
}
}

Link to comment
Share on other sites

  • 1 month later...
 Share

  • Recently Browsing   0 members

    • No registered users viewing this page.
×
×
  • Create New...