使用移相器时调整平铺地图的大小

时间:2014-12-23 13:21:08

标签: javascript jquery phaser-framework

var cw = window.innerWidth;
        var ch = window.innerHeight;
        var game = new Phaser.Game(cw, ch, Phaser.AUTO, 'game', { preload: preload, create: create, update: update });

        function preload() {
            game.load.tilemap('Background', 'https://gist.githubusercontent.com/anonymous/c61b37df015a0b2af1d7/raw/172bf9c2d4c20c56699eacce263525409caaf743/54996634e4b0a35d00c9b516.json', null, Phaser.Tilemap.TILED_JSON);
            game.load.image('tiles', 'http://i.imgur.com/gmWQIFK.png');
            game.load.image('player', 'http://i.imgur.com/tCCrLyh.png');
        }

        var map;
        var layer;
        var player;
        var _keyboard;
        var playerJumping;
        function create() {
            player = game.add.sprite(0, ch - 32, 'player');
            game.world.setBounds(0, 0, cw, ch);
            game.physics.startSystem(Phaser.Physics.ARCADE);
            game.physics.arcade.gravity.y = 300;
            game.physics.enable(player, Phaser.Physics.ARCADE);
            player.body.collideWorldBounds = true;
            game.stage.backgroundColor = '#787878';
            map = game.add.tilemap('Background');
            map.addTilesetImage('smb_tiles', 'tiles');
            layer = map.createLayer('Tile Layer 1');
            layer.resizeWorld();

            _keyboard = game.input.keyboard.createCursorKeys();
            game.camera.follow(player);
        }
        function update()
        {
            player.body.x += 2;
            if (_keyboard.up.isDown && player.body.onFloor()) {
                playerJumping = true;
                player.body.velocity.y = -2;

            }
            else {
                playerJumping = false;
            }
        }
<script src="http://yourjavascript.com/222115941388/phaser-min.js"></script>
<div id="game"></div>

正如你可以看到平铺地图从320px bcs的高度开始,地图有这个高度,如果我将游戏高度改为320px,一切正常,但我的问题是,如果我想要使tilesMap响应innerHeight和屏幕宽度我该怎么做才能使平铺地图从屏幕底部开始而不是320px

enter image description here

您可以看到平铺地图图层是如何在屏幕中间开始的。我有什么机会可以让它从屏幕的底部开始

1 个答案:

答案 0 :(得分:2)

当您想要创建游戏时,请使用百分比值来修改值,如下所示:

var game = new Phaser.Game("100%", "100%", Phaser.AUTO, '');

你也可以使用scaleManager告诉游戏调整渲染器大小以匹配游戏尺寸(即100%浏览器宽度/高度):

game.scale.scaleMode = Phaser.ScaleManager.RESIZE;

您还可以查看scaleManager documentation以了解更多设置。 此外,还有一本关于scaleManager的社区书籍,如果您想了解更多here,可以帮助您进行响应式游戏设计。