mirror of
https://github.com/photonstorm/phaser
synced 2025-01-10 20:28:56 +00:00
131 lines
No EOL
5.1 KiB
TypeScript
131 lines
No EOL
5.1 KiB
TypeScript
/// <reference path="../../_definitions.ts" />
|
|
|
|
/**
|
|
* Phaser - BootScreen
|
|
*
|
|
* The BootScreen is displayed when Phaser is started without any default functions or State
|
|
*/
|
|
|
|
module Phaser {
|
|
|
|
export class BootScreen {
|
|
|
|
/**
|
|
* BootScreen constructor
|
|
* Create a new <code>BootScreen</code> with specific width and height.
|
|
*
|
|
* @param width {number} Screen canvas width.
|
|
* @param height {number} Screen canvas height.
|
|
*/
|
|
constructor(game: Phaser.Game) {
|
|
|
|
this.game = game;
|
|
|
|
this._logo = new Image();
|
|
this._logo.src = this._logoData;
|
|
|
|
}
|
|
|
|
/**
|
|
* Local reference to Game.
|
|
*/
|
|
public game: Phaser.Game;
|
|
|
|
/**
|
|
* Engine logo.
|
|
*/
|
|
private _logo;
|
|
|
|
/**
|
|
* Engine logo image data.
|
|
*/
|
|
private _logoData: string = "";
|
|
|
|
/**
|
|
* Background gradient effect color 1.
|
|
*/
|
|
private _color1 = { r: 20, g: 20, b: 20 };
|
|
|
|
/**
|
|
* Background gradient effect color 2.
|
|
*/
|
|
private _color2 = { r: 200, g: 200, b: 200 };
|
|
|
|
/**
|
|
* Fade effect tween.
|
|
* @type {Phaser.Tween}
|
|
*/
|
|
private _fade: Phaser.Tween = null;
|
|
|
|
/**
|
|
* Update color and fade.
|
|
*/
|
|
public update() {
|
|
|
|
if (this._fade == null)
|
|
{
|
|
this.colorCycle();
|
|
}
|
|
|
|
this._color1.r = Math.round(this._color1.r);
|
|
this._color1.g = Math.round(this._color1.g);
|
|
this._color1.b = Math.round(this._color1.b);
|
|
this._color2.r = Math.round(this._color2.r);
|
|
this._color2.g = Math.round(this._color2.g);
|
|
this._color2.b = Math.round(this._color2.b);
|
|
|
|
}
|
|
|
|
/**
|
|
* Render BootScreen.
|
|
*/
|
|
public render() {
|
|
|
|
var grd = this.game.stage.context.createLinearGradient(0, 0, 0, this.game.stage.height);
|
|
grd.addColorStop(0, 'rgb(' + this._color1.r + ', ' + this._color1.g + ', ' + this._color1.b + ')');
|
|
grd.addColorStop(0.5, 'rgb(' + this._color2.r + ', ' + this._color2.g + ', ' + this._color2.b + ')');
|
|
grd.addColorStop(1, 'rgb(' + this._color1.r + ', ' + this._color1.g + ', ' + this._color1.b + ')');
|
|
this.game.stage.context.fillStyle = grd;
|
|
this.game.stage.context.fillRect(0, 0, this.game.stage.width, this.game.stage.height);
|
|
|
|
this.game.stage.context.shadowOffsetX = 0;
|
|
this.game.stage.context.shadowOffsetY = 0;
|
|
|
|
if (this._logo)
|
|
{
|
|
this.game.stage.context.drawImage(this._logo, 32, 32);
|
|
}
|
|
|
|
this.game.stage.context.shadowColor = 'rgb(0,0,0)';
|
|
this.game.stage.context.shadowOffsetX = 1;
|
|
this.game.stage.context.shadowOffsetY = 1;
|
|
this.game.stage.context.shadowBlur = 0;
|
|
this.game.stage.context.fillStyle = 'rgb(255,255,255)';
|
|
this.game.stage.context.font = 'bold 18px Arial';
|
|
this.game.stage.context.textBaseline = 'top';
|
|
this.game.stage.context.fillText(Phaser.VERSION, 32, 64+32);
|
|
this.game.stage.context.fillText('Game Size: ' + this.game.stage.width + ' x ' + this.game.stage.height, 32, 64+64);
|
|
this.game.stage.context.fillText('www.photonstorm.com', 32, 64+96);
|
|
this.game.stage.context.font = '16px Arial';
|
|
this.game.stage.context.fillText('You are seeing this screen because you didn\'t specify any default', 32, 64+160);
|
|
this.game.stage.context.fillText('functions in the Game constructor or use Game.switchState()', 32, 64+184);
|
|
|
|
}
|
|
|
|
/**
|
|
* Start color fading cycle.
|
|
*/
|
|
private colorCycle() {
|
|
|
|
this._fade = this.game.add.tween(this._color2);
|
|
|
|
this._fade.to({ r: Math.random() * 250, g: Math.random() * 250, b: Math.random() * 250 }, 3000, Phaser.Easing.Linear.None);
|
|
this._fade.onComplete.add(this.colorCycle, this);
|
|
this._fade.start();
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
} |