summaryrefslogtreecommitdiff
path: root/src/engine/systems/Render.ts
blob: 7cb5d8151db38ffeb3b7e2d843030e57d1153e91 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
import { System, SystemNames } from ".";
import { BoundingBox, ComponentNames, Sprite } from "../components";
import { Game } from "..";
import { clamp } from "../utils";
import { DrawArgs } from "../interfaces";

export class Render extends System {
  private ctx: CanvasRenderingContext2D;

  constructor(ctx: CanvasRenderingContext2D) {
    super(SystemNames.Render);
    this.ctx = ctx;
  }

  public update(dt: number, game: Game) {
    this.ctx.clearRect(0, 0, this.ctx.canvas.width, this.ctx.canvas.height);

    game.forEachEntityWithComponent(ComponentNames.Sprite, (entity) => {
      const sprite = entity.getComponent<Sprite>(ComponentNames.Sprite);
      sprite.update(dt);

      const boundingBox = entity.getComponent<BoundingBox>(
        ComponentNames.BoundingBox,
      );

      // don't render if we're outside the screen
      if (
        clamp(
          boundingBox.center.y,
          -boundingBox.dimension.height / 2,
          this.ctx.canvas.height + boundingBox.dimension.height / 2,
        ) != boundingBox.center.y ||
        clamp(
          boundingBox.center.x,
          -boundingBox.dimension.width / 2,
          this.ctx.canvas.width + boundingBox.dimension.width / 2,
        ) != boundingBox.center.x
      ) {
        return;
      }

      const drawArgs: DrawArgs = {
        center: boundingBox.center,
        dimension: boundingBox.dimension,
        rotation: boundingBox.rotation,
        tint: entity.hasComponent(ComponentNames.Highlight) ? "red" : undefined,
      };

      sprite.draw(this.ctx, drawArgs);
    });
  }
}