tanks/www/player.mjs

79 lines
1.7 KiB
JavaScript
Raw Permalink Normal View History

2024-11-26 17:52:30 -07:00
import {Tank} from "./tank.mjs"
const Millisecond = 1
2024-12-04 18:39:55 -07:00
const Second = 1000 * Millisecond
2024-11-26 17:52:30 -07:00
const FPS = 12
export class Player {
constructor(ctx) {
this.ctx = ctx
}
load(game) {
this.ctx.canvas.width = game.field[0]
this.ctx.canvas.height = game.field[1]
this.tanks = []
for (let tankDef of game.tanks) {
let tank = new Tank(this.ctx, tankDef.color, tankDef.sensors)
this.tanks.push(tank)
}
this.rounds = game.rounds
this.start()
}
start(frameno = 0) {
if (!this.loop_id) {
this.loop_id = setInterval(
() => this.update(),
Second / FPS,
)
}
this.frameno = frameno
}
stop() {
if (this.loop_id) {
clearInterval(this.loop_id)
2024-11-26 18:14:24 -07:00
this.loop_id = null
2024-11-26 17:52:30 -07:00
}
}
update() {
let frame = this.rounds[this.frameno]
if (!frame) {
this.stop()
2024-11-26 18:09:28 -07:00
setTimeout(
() => {
this.start()
},
2024-11-26 18:14:24 -07:00
4 * Second,
2024-11-26 18:09:28 -07:00
)
2024-11-26 17:52:30 -07:00
return
}
this.ctx.clearRect(0, 0, this.ctx.canvas.width, this.ctx.canvas.height)
// Update and draw craters first
for (let i in frame) {
let tank = this.tanks[i]
tank.set_state(...frame[i])
tank.draw_crater()
}
// Then sensors
for (let tank of this.tanks) {
tank.draw_wrap_sensors()
}
// Then tanks
for (let tank of this.tanks) {
tank.draw_tank()
}
this.frameno += 1
}
}
2024-12-04 18:39:55 -07:00