Changes for how play time is handled
parent
f9c3023e6d
commit
4c07c6d5cb
|
@ -363,9 +363,8 @@ export class EncounterPhase extends BattlePhase {
|
|||
start() {
|
||||
super.start();
|
||||
|
||||
this.scene.updateWaveCountText();
|
||||
this.scene.updateMoneyText();
|
||||
|
||||
this.scene.initSession();
|
||||
|
||||
const loadEnemyAssets = [];
|
||||
|
||||
const battle = this.scene.currentBattle;
|
||||
|
|
|
@ -84,6 +84,7 @@ export default class BattleScene extends Phaser.Scene {
|
|||
public rexUI: UIPlugin;
|
||||
|
||||
public auto: boolean;
|
||||
public sessionPlayTime: integer = null;
|
||||
public masterVolume: number = 0.5;
|
||||
public bgmVolume: number = 1;
|
||||
public seVolume: number = 1;
|
||||
|
@ -141,6 +142,7 @@ export default class BattleScene extends Phaser.Scene {
|
|||
private bgm: AnySound;
|
||||
private bgmResumeTimer: Phaser.Time.TimerEvent;
|
||||
private bgmCache: Set<string> = new Set();
|
||||
private playTimeTimer: Phaser.Time.TimerEvent;
|
||||
|
||||
private buttonKeys: Phaser.Input.Keyboard.Key[][];
|
||||
|
||||
|
@ -402,15 +404,6 @@ export default class BattleScene extends Phaser.Scene {
|
|||
|
||||
this.gameData = new GameData(this);
|
||||
|
||||
this.time.addEvent({
|
||||
delay: Utils.fixedInt(1000),
|
||||
repeat: -1,
|
||||
callback: () => {
|
||||
if (this.gameData)
|
||||
this.gameData.gameStats.playTime++;
|
||||
}
|
||||
})
|
||||
|
||||
this.setupControls();
|
||||
|
||||
this.load.setBaseURL();
|
||||
|
@ -578,6 +571,27 @@ export default class BattleScene extends Phaser.Scene {
|
|||
});
|
||||
}
|
||||
|
||||
initSession(): void {
|
||||
this.sessionPlayTime = 0;
|
||||
|
||||
if (this.playTimeTimer)
|
||||
this.playTimeTimer.destroy();
|
||||
|
||||
this.playTimeTimer = this.time.addEvent({
|
||||
delay: Utils.fixedInt(1000),
|
||||
repeat: -1,
|
||||
callback: () => {
|
||||
if (this.gameData)
|
||||
this.gameData.gameStats.playTime++;
|
||||
if (this.sessionPlayTime !== null)
|
||||
this.sessionPlayTime++;
|
||||
}
|
||||
});
|
||||
|
||||
this.updateWaveCountText();
|
||||
this.updateMoneyText();
|
||||
}
|
||||
|
||||
setupControls() {
|
||||
const keyCodes = Phaser.Input.Keyboard.KeyCodes;
|
||||
const keyConfig = {
|
||||
|
|
|
@ -58,6 +58,7 @@ interface SystemSaveData {
|
|||
|
||||
interface SessionSaveData {
|
||||
seed: string;
|
||||
playTime: integer;
|
||||
gameMode: GameMode;
|
||||
party: PokemonData[];
|
||||
enemyParty: PokemonData[];
|
||||
|
@ -360,6 +361,7 @@ export class GameData {
|
|||
|
||||
const sessionData = {
|
||||
seed: scene.seed,
|
||||
playTime: scene.sessionPlayTime,
|
||||
gameMode: scene.gameMode,
|
||||
party: scene.getParty().map(p => new PokemonData(p)),
|
||||
enemyParty: scene.getEnemyParty().map(p => new PokemonData(p)),
|
||||
|
@ -408,6 +410,8 @@ export class GameData {
|
|||
scene.seed = sessionData.seed || scene.game.config.seed[0];
|
||||
scene.resetSeed();
|
||||
|
||||
scene.sessionPlayTime = sessionData.playTime || 0;
|
||||
|
||||
scene.gameMode = sessionData.gameMode || GameMode.CLASSIC;
|
||||
|
||||
const loadPokemonAssets: Promise<void>[] = [];
|
||||
|
|
|
@ -1,5 +1,4 @@
|
|||
import BattleScene, { Button } from "../battle-scene";
|
||||
import { GameStats } from "../system/game-stats";
|
||||
import { TextStyle, addTextObject, getTextColor } from "./text";
|
||||
import { Mode } from "./ui";
|
||||
import UiHandler from "./ui-handler";
|
||||
|
@ -18,20 +17,9 @@ interface DisplayStats {
|
|||
[key: string]: DisplayStat | string
|
||||
}
|
||||
|
||||
const secondsInHour = 3600;
|
||||
|
||||
const displayStats: DisplayStats = {
|
||||
playTime: {
|
||||
sourceFunc: gameData => {
|
||||
const totalSeconds = gameData.gameStats.playTime;
|
||||
|
||||
const days = `${Math.floor(totalSeconds / (secondsInHour * 24))}`;
|
||||
const hours = `${Math.floor(totalSeconds % (secondsInHour * 24) / secondsInHour)}`;
|
||||
const minutes = `${Math.floor(totalSeconds % secondsInHour / 60)}`;
|
||||
const seconds = `${Math.floor(totalSeconds % 60)}`;
|
||||
|
||||
return `${days.padStart(2, '0')}:${hours.padStart(2, '0')}:${minutes.padStart(2, '0')}:${seconds.padStart(2, '0')}`;
|
||||
}
|
||||
sourceFunc: gameData => Utils.getPlayTimeString(gameData.gameStats.playTime)
|
||||
},
|
||||
battles: 'Total Battles',
|
||||
startersUnlocked: {
|
||||
|
|
11
src/utils.ts
11
src/utils.ts
|
@ -88,6 +88,17 @@ export function getCurrentTime(): number {
|
|||
return (((date.getHours() * 60 + date.getMinutes()) / 1440) + 0.675) % 1;
|
||||
}
|
||||
|
||||
const secondsInHour = 3600;
|
||||
|
||||
export function getPlayTimeString(totalSeconds: integer): string {
|
||||
const days = `${Math.floor(totalSeconds / (secondsInHour * 24))}`;
|
||||
const hours = `${Math.floor(totalSeconds % (secondsInHour * 24) / secondsInHour)}`;
|
||||
const minutes = `${Math.floor(totalSeconds % secondsInHour / 60)}`;
|
||||
const seconds = `${Math.floor(totalSeconds % 60)}`;
|
||||
|
||||
return `${days.padStart(2, '0')}:${hours.padStart(2, '0')}:${minutes.padStart(2, '0')}:${seconds.padStart(2, '0')}`;
|
||||
}
|
||||
|
||||
export function binToDec(input: string): integer {
|
||||
let place: integer[] = [];
|
||||
let binary: string[] = [];
|
||||
|
|
Loading…
Reference in New Issue