diff options
author | Elizabeth Hunt <elizabeth.hunt@simponic.xyz> | 2023-07-20 20:47:32 -0700 |
---|---|---|
committer | Elizabeth Hunt <elizabeth.hunt@simponic.xyz> | 2023-07-20 20:47:32 -0700 |
commit | 72c6c7de12e9833f52bf2d0718d70f044f8ab57e (patch) | |
tree | 152f5f31d59011bb8c617bfbcfc44cc8f47ecad5 /engine/systems/WallBounds.ts | |
parent | 0fd9fb097552686f2257c1aa689d797e80057bd1 (diff) | |
download | jumpstorm-72c6c7de12e9833f52bf2d0718d70f044f8ab57e.tar.gz jumpstorm-72c6c7de12e9833f52bf2d0718d70f044f8ab57e.zip |
a bit of refactoring; importing engine into bun for server
Diffstat (limited to 'engine/systems/WallBounds.ts')
-rw-r--r-- | engine/systems/WallBounds.ts | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/engine/systems/WallBounds.ts b/engine/systems/WallBounds.ts new file mode 100644 index 0000000..6ea2267 --- /dev/null +++ b/engine/systems/WallBounds.ts @@ -0,0 +1,36 @@ +import { System, SystemNames } from "."; +import { BoundingBox, ComponentNames } from "../components"; +import { Game } from "../Game"; +import type { Entity } from "../entities"; +import { clamp } from "../utils"; + +export class WallBounds extends System { + private screenWidth: number; + + constructor(screenWidth: number) { + super(SystemNames.WallBounds); + + this.screenWidth = screenWidth; + } + + public update(_dt: number, game: Game) { + game.componentEntities + .get(ComponentNames.WallBounded) + ?.forEach((entityId) => { + const entity = game.entities.get(entityId); + if (!entity.hasComponent(ComponentNames.BoundingBox)) { + return; + } + + const boundingBox = entity.getComponent<BoundingBox>( + ComponentNames.BoundingBox + ); + + boundingBox.center.x = clamp( + boundingBox.center.x, + boundingBox.dimension.width / 2, + this.screenWidth - boundingBox.dimension.width / 2 + ); + }); + } +} |