mirror of
https://github.com/photonstorm/phaser
synced 2024-11-23 21:24:09 +00:00
89 lines
No EOL
1.8 KiB
PHP
89 lines
No EOL
1.8 KiB
PHP
<?php
|
|
$title = "Tilemap Collision";
|
|
require('../head.php');
|
|
?>
|
|
|
|
<script type="text/javascript">
|
|
|
|
var game = new Phaser.Game(800, 600, Phaser.CANVAS, '', { preload: preload, create: create, update: update, render: render });
|
|
|
|
function preload() {
|
|
|
|
game.load.tilemap('mario', 'assets/maps/mario1.png', 'assets/maps/mario1.json', null, Phaser.Tilemap.JSON);
|
|
game.load.image('player', 'assets/sprites/phaser-dude.png');
|
|
|
|
}
|
|
|
|
var map;
|
|
var p;
|
|
var cursors;
|
|
|
|
function create() {
|
|
|
|
game.stage.backgroundColor = '#787878';
|
|
|
|
map = game.add.tilemap(0, 0, 'mario');
|
|
|
|
// floor
|
|
map.setCollisionRange(80, 97, true, true, true, true);
|
|
|
|
// one-ways
|
|
map.setCollisionRange(15, 17, true, true, false, true);
|
|
|
|
p = game.add.sprite(32, 32, 'player');
|
|
|
|
p.body.gravity.y = 10;
|
|
p.body.bounce.y = 0.4;
|
|
p.body.collideWorldBounds = true;
|
|
|
|
game.world.setBounds(0, 0, map.width, 600);
|
|
|
|
game.camera.follow(p);
|
|
|
|
cursors = game.input.keyboard.createCursorKeys();
|
|
|
|
}
|
|
|
|
function update() {
|
|
|
|
map.collide(p);
|
|
|
|
p.body.velocity.x = 0;
|
|
|
|
if (cursors.up.isDown)
|
|
{
|
|
if (p.body.touching.down)
|
|
{
|
|
p.body.velocity.y = -400;
|
|
}
|
|
}
|
|
else if (cursors.down.isDown)
|
|
{
|
|
// game.camera.y += 4;
|
|
}
|
|
|
|
if (cursors.left.isDown)
|
|
{
|
|
p.body.velocity.x = -150;
|
|
}
|
|
else if (cursors.right.isDown)
|
|
{
|
|
p.body.velocity.x = 150;
|
|
}
|
|
|
|
}
|
|
|
|
function render() {
|
|
|
|
game.debug.renderCameraInfo(game.camera, 32, 32);
|
|
// game.debug.renderSpriteCorners(p);
|
|
game.debug.renderSpriteCollision(p, 32, 320);
|
|
|
|
}
|
|
|
|
|
|
</script>
|
|
|
|
<?php
|
|
require('../foot.php');
|
|
?>
|