space-smasher-9001/src/classes/Asteroid.ts
2021-10-16 02:13:23 +02:00

66 lines
1.7 KiB
TypeScript

import Phaser from 'phaser'
export default class Asteroid extends Phaser.Physics.Arcade.Sprite {
static unbornAge = 1000 // asteroid can't kill player
// if younger than 1000ms
readonly wrapMargin = 30
age = 0
constructor(scene: Phaser.Scene) {
super(
scene,
Phaser.Math.RND.integerInRange(0, scene.physics.world.bounds.width),
Phaser.Math.RND.integerInRange(0, scene.physics.world.bounds.height),
'asteroids'
)
scene.add.existing(this)
scene.physics.add.existing(this)
this.anims.play(Asteroid.getRandomAnimationName())
this.setCircle(30, 30, 30)
this.setScale(Phaser.Math.RND.realInRange(0.7, 1.3))
this.setVelocity(
Phaser.Math.RND.realInRange(-100, 100),
Phaser.Math.RND.realInRange(-100, 100)
)
this.setRandomShade()
}
preUpdate(time: number, delta: number) {
super.preUpdate(time, delta)
this.scene.physics.world.wrap(this, this.scale * this.wrapMargin)
this.age += delta
}
private setRandomShade() {
const color = new Phaser.Display.Color()
color.randomGray(0xa0) //the darkest possible dye is 0xa0a0a0
this.setTint(color.color)
}
static createAnimations(scene: Phaser.Scene) {
["a", "b", "c", "d"].forEach((animationName, i) => {
const frames = scene.anims.generateFrameNames('asteroids', {
start: 0, end: 15,
zeroPad: 4,
prefix: `${animationName}4`
});
scene.anims.create({
key: `asteroid${i}`,
frames: frames,
frameRate: 16,
repeat: -1
})
})
}
static getRandomAnimationName() {
const animationsAmount = 3
const id = Phaser.Math.RND.integerInRange(0, animationsAmount)
return `asteroid${id}`
}
}