1
0
Fork 0
spacetac/src/app/view/map/UniverseMapView.ts

118 lines
3.9 KiB
TypeScript
Raw Normal View History

/// <reference path="../BaseView.ts"/>
module SpaceTac.View {
"use strict";
// Interactive map of the universe
export class UniverseMapView extends BaseView {
// Displayed universe
universe: Game.Universe;
// Interacting player
player: Game.Player;
// Group for the stars and links
2015-03-24 00:00:00 +00:00
private stars: Phaser.Group;
// Scaling used to transform game coordinates in screen ones
private scaling: number;
// Init the view, binding it to a universe
init(universe: Game.Universe, player: Game.Player) {
super.init();
this.universe = universe;
this.player = player;
}
// Create view graphics
create() {
super.create();
this.stars = this.add.group();
var display_margin = 50;
var display_width = 720 - (display_margin * 2);
this.scaling = display_width / (this.universe.radius * 2);
this.stars.position.set(display_margin + display_width / 2, display_margin + display_width / 2);
2015-03-24 00:00:00 +00:00
this.stars.scale.set(this.scaling);
this.drawAll();
2015-03-25 00:00:00 +00:00
this.gameui.audio.startMusic("walking-along");
// Inputs
this.input.keyboard.addKey(Phaser.Keyboard.R).onUp.addOnce(this.revealAll, this);
}
// Leaving the view, unbind and destroy
shutdown() {
this.universe = null;
this.player = null;
super.shutdown();
}
// Redraw the whole scene
drawAll(): void {
this.stars.removeAll(true, true);
this.drawStars();
this.drawFleet();
}
// Draw the fleet marker
drawFleet(): void {
var location = this.player.fleet.location.star;
var fleet = this.add.sprite(location.x, location.y, "map-fleet-icon", 0, this.stars);
fleet.scale.set(1.0 / this.scaling, 1.0 / this.scaling);
fleet.anchor.set(0.5, -0.5);
this.game.tweens.create(fleet).to({angle: -360}, 5000, undefined, true, 0, -1);
}
// Draw the stars and links
drawStars(): void {
this.universe.starlinks.forEach((link: Game.StarLink) => {
if (this.player.hasVisited(link.first) || this.player.hasVisited(link.second)) {
var line = this.add.graphics(0, 0, this.stars);
line.lineStyle(0.3, 0xA0A0A0);
line.moveTo(link.first.x, link.first.y);
line.lineTo(link.second.x, link.second.y);
}
});
this.universe.stars.forEach((star: Game.Star) => {
if (this.player.hasVisited(star)) {
2015-03-24 00:00:00 +00:00
var sprite = new Phaser.Button(this.game, star.x, star.y, "map-star-icon");
sprite.scale.set(1.0 / this.scaling, 1.0 / this.scaling);
sprite.anchor.set(0.5, 0.5);
2015-03-24 00:00:00 +00:00
sprite.onInputUp.add(() => {
(<GameUI>this.game).star = star;
this.game.state.start("router", true, false);
2015-03-24 00:00:00 +00:00
});
2015-03-25 00:00:00 +00:00
sprite.input.useHandCursor = true;
2015-03-24 00:00:00 +00:00
this.stars.addChild(sprite);
2015-03-25 00:00:00 +00:00
var name = new Phaser.Text(this.game, star.x, star.y, star.name,
{align: "center", font: "bold 14px Arial", fill: "#90FEE3"});
name.scale.set(1.0 / this.scaling, 1.0 / this.scaling);
name.anchor.set(0.5, -0.4);
this.stars.addChild(name);
}
});
}
// Reveal the whole map (this is a cheat)
revealAll(): void {
console.warn("Cheat : reveal whole map");
this.universe.stars.forEach((star: Game.Star) => {
this.player.setVisited(star);
});
this.drawAll();
}
}
}