« get me outta code hell

csb-game - Pixelly spin-off of the Command Synergy Battle system used in Final Fantasy XIII
summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--index.js34
1 files changed, 32 insertions, 2 deletions
diff --git a/index.js b/index.js
index 0dedbb1..2a2f074 100644
--- a/index.js
+++ b/index.js
@@ -553,6 +553,7 @@ class BattleCharacter extends Sprite {
     this.isExecutingChain = false
     this.isExecutingAction = false
     this.actionExecuteTime = 0
+    this.actionBeingExecuted = null
 
     this.targetType = null // ally or enemy
     this.targetCharacter = null
@@ -632,6 +633,7 @@ class BattleCharacter extends Sprite {
       if (this.actionExecuteTime <= 0) {
         this.actionExecuteTime = 0
         this.isExecutingAction = false
+        this.actionBeingExecuted = null
       }
     }
   }
@@ -664,6 +666,7 @@ class BattleCharacter extends Sprite {
     this.isExecutingChain = true
     this.isExecutingAction = true
     this.actionExecuteTime = 0.4 + 0.2 * action.size
+    this.actionBeingExecuted = action
 
     if (this.targetCharacter) {
       this.battle.animationEntities.push(new MagicProjectile(this, this.targetCharacter, action))
@@ -799,7 +802,7 @@ class Battle {
       }
     }
 
-    ctx.save()
+    ctx.save() // Begin camera-translated drawing
     ctx.translate(Math.round(-camera.x), Math.round(-camera.y))
     for (const sprite of [this.backdrop, ...this.getAllBattleCharacters(), ...this.animationEntities]) {
       const x = Math.round(sprite.x - sprite.canvas.width / 2)
@@ -813,7 +816,34 @@ class Battle {
         overlayHPBar.y = y - camera.y
       }
     }
-    ctx.restore()
+
+    for (const battleCharacter of this.getAllBattleCharacters()) {
+      if (battleCharacter.isExecutingAction) {
+        const sprite = battleCharacter
+        const { label } = battleCharacter.actionBeingExecuted
+
+        ctx.font = '5px pixel-font'
+        const width = ctx.measureText(label).width + 4
+        const x = Math.round(sprite.x - sprite.canvas.width / 2 - width / 2)
+        const y = Math.round(sprite.y - sprite.canvas.height / 2)
+
+        let textFillStyle
+        if (battleCharacter.team === this.playerCharacter.team) {
+          ctx.fillStyle = 'rgba(45, 128, 255, 0.3)'
+          ctx.strokeStyle = 'rgb(30, 85, 170)'
+        } else {
+          ctx.fillStyle = 'rgba(255, 45, 45, 0.3)'
+          ctx.strokeStyle = 'rgb(170, 30, 30)'
+        }
+        ctx.fillRect(x, y, width, 9)
+        ctx.strokeRect(x + 0.5, y + 0.5, width, 8)
+        ctx.font = '5px pixel-font' // It gets reset for some reason?
+        ctx.fillStyle = 'white'
+        ctx.textAlign = 'left'
+        ctx.fillText(label, x + 3, y + 7)
+      }
+    }
+    ctx.restore() // End camera-translated drawing
 
     const { atbBar } = this.playerCharacter