From 48a15a37618db5945a9b8060e8a05ab4110c244c Mon Sep 17 00:00:00 2001 From: Peter Klingelhofer Date: Mon, 13 Mar 2023 19:13:13 -0500 Subject: [PATCH] feat: circle is configurable option --- src/renderer.ts | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/src/renderer.ts b/src/renderer.ts index 3e41c1d..5f2d6b8 100755 --- a/src/renderer.ts +++ b/src/renderer.ts @@ -11,9 +11,12 @@ enum State { EXHALE, POST_EXHALE, } +enum Shape { + CIRCLE = "circle", + RECTANGLE = "rectangle", +} const FRAMES_PER_SECOND = 60; const BACKDROP_COLOR: Color = "#000"; -const IS_CIRCULAR = true; const calculateEndFrame = (duration: number) => startFrame + duration * FRAMES_PER_SECOND; const calculateElapsed = (frames: number) => @@ -35,6 +38,7 @@ const ctx = canvas.getContext("2d"); const { colorExhale = "rgb(0, 221, 255)", colorInhale = "rgb(168, 50, 150)", + circleOrRectangle = Shape.CIRCLE, durationExhale = 10, durationInhale = 5, durationPostExhale = 0, @@ -43,6 +47,7 @@ const { } = localStorage; Object.assign(localStorage, { + circleOrRectangle, durationInhale, durationExhale, durationPostExhale, @@ -132,7 +137,7 @@ function draw(): void { ctx.fillStyle = color; } - if (IS_CIRCULAR) { + if (circleOrRectangle === Shape.CIRCLE) { const centerX = canvasWidth / 2; const centerY = canvasHeight / 2; const startAngle = 0;