class Example extends Phaser.Scene { constructor () { super(); this.string = 'Phaser 3\nBitmapText\nScaling\nwith bounds'; } preload () { this.load.setBaseURL('https://cdn.phaserfiles.com/v385'); this.load.bitmapFont('atari', 'assets/fonts/bitmap/atari-smooth.png', 'assets/fonts/bitmap/atari-smooth.xml'); } create () { this.text = this.add.bitmapText(0, 0, 'atari', this.string) .setFontSize(32); this.graphics = this.add.graphics({ x: 0, y: 0, lineStyle: { thickness: 1, color: 0xffff00, alpha: 1 } }); this.tweens.add({ targets: this.text, duration: 4000, scaleX: 2, ease: 'Quad.easeInOut', repeat: -1, yoyo: true }); this.tweens.add({ targets: this.text, duration: 2000, scaleY: 4, ease: 'Quad.easeInOut', repeat: -1, yoyo: true }); } update () { this.text.setText(this.string + '\nScale X: ' + this.text.scaleX.toFixed(4)); const bounds = this.text.getTextBounds(); this.graphics.clear(); this.graphics.strokeRect(bounds.global.x, bounds.global.y, bounds.global.width, bounds.global.height); } } const config = { type: Phaser.WEBGL, parent: 'phaser-example', scene: Example }; const game = new Phaser.Game(config);
Scan to open on your mobile device
class Example extends Phaser.Scene { constructor () { super(); this.string = 'Phaser 3\nBitmapText\nScaling\nwith bounds'; } preload () { this.load.setBaseURL('https://cdn.phaserfiles.com/v385'); this.load.bitmapFont('atari', 'assets/fonts/bitmap/atari-smooth.png', 'assets/fonts/bitmap/atari-smooth.xml'); } create () { this.text = this.add.bitmapText(0, 0, 'atari', this.string) .setFontSize(32); this.graphics = this.add.graphics({ x: 0, y: 0, lineStyle: { thickness: 1, color: 0xffff00, alpha: 1 } }); this.tweens.add({ targets: this.text, duration: 4000, scaleX: 2, ease: 'Quad.easeInOut', repeat: -1, yoyo: true }); this.tweens.add({ targets: this.text, duration: 2000, scaleY: 4, ease: 'Quad.easeInOut', repeat: -1, yoyo: true }); } update () { this.text.setText(this.string + '\nScale X: ' + this.text.scaleX.toFixed(4)); const bounds = this.text.getTextBounds(); this.graphics.clear(); this.graphics.strokeRect(bounds.global.x, bounds.global.y, bounds.global.width, bounds.global.height); } } const config = { type: Phaser.WEBGL, parent: 'phaser-example', scene: Example }; const game = new Phaser.Game(config);