about summary refs log tree commit diff stats
path: root/html/rogue/js/world.js
diff options
context:
space:
mode:
Diffstat (limited to 'html/rogue/js/world.js')
-rw-r--r--html/rogue/js/world.js46
1 files changed, 29 insertions, 17 deletions
diff --git a/html/rogue/js/world.js b/html/rogue/js/world.js
index fb29e27..789b5f4 100644
--- a/html/rogue/js/world.js
+++ b/html/rogue/js/world.js
@@ -112,7 +112,6 @@ const GRASS_TYPES = {
         type: 'grass',
         width: 30,
         height: 40,
-        blades: 5,
         color: '#33aa55',
         shadowColor: '#229944'
     },
@@ -120,7 +119,6 @@ const GRASS_TYPES = {
         type: 'grass',
         width: 20,
         height: 25,
-        blades: 4,
         color: '#33bb66',
         shadowColor: '#22aa55'
     },
@@ -128,7 +126,6 @@ const GRASS_TYPES = {
         type: 'grass',
         width: 30,
         height: 40,
-        blades: 5,
         color: '#eebb33',
         shadowColor: '#cc9922'
     },
@@ -136,7 +133,6 @@ const GRASS_TYPES = {
         type: 'grass',
         width: 20,
         height: 25,
-        blades: 4,
         color: '#ffcc44',
         shadowColor: '#ddaa33'
     },
@@ -144,7 +140,6 @@ const GRASS_TYPES = {
         type: 'grass',
         width: 30,
         height: 40,
-        blades: 5,
         color: '#44aaff',
         shadowColor: '#2299ff',
         glowing: true
@@ -153,7 +148,6 @@ const GRASS_TYPES = {
         type: 'grass',
         width: 20,
         height: 25,
-        blades: 4,
         color: '#55bbff',
         shadowColor: '#33aaff',
         glowing: true
@@ -848,22 +842,35 @@ const renderRock = (ctx, rock, groundY) => {
 // Add grass rendering function
 const renderGrass = (ctx, grass, groundY, time) => {
     const { x, config } = grass;
-    const { width, height, blades, color, shadowColor, glowing } = config;
+    const { width, height, color, shadowColor, glowing } = config;
     
     // Get or initialize grass state
     const stateKey = `grass_${x}`;
     if (!window.gameState.world.grassStates[stateKey]) {
+        // Ensure blade count is between 4 and 8 (inclusive)
+        const minBlades = 4;
+        const maxBlades = 8;
+        // Use Math.round instead of Math.floor and ensure positive value
+        const randomValue = Math.abs(seededRandom(x, height));
+        const bladeCount = minBlades + Math.round(randomValue * (maxBlades - minBlades));
+        
         window.gameState.world.grassStates[stateKey] = {
             rustleAmount: 0,
-            rustleDecay: 0.95
+            rustleDecay: 0.95,
+            bladeCount: bladeCount
         };
     }
     const state = window.gameState.world.grassStates[stateKey];
-    
+
+    // Additional validation as a safety net
+    if (!state.bladeCount || state.bladeCount < 4) {
+        state.bladeCount = 4;
+    }
+
     // Check for player interaction
     const player = window.gameState.player;
     const interactionDistance = width;
-    const distanceToPlayer = Math.abs(player.x + player.width/2 - x);
+    const distanceToPlayer = Math.abs(player.x + player.width / 2 - x);
     
     if (distanceToPlayer < interactionDistance) {
         state.rustleAmount = Math.min(1, state.rustleAmount + 0.3);
@@ -875,17 +882,22 @@ const renderGrass = (ctx, grass, groundY, time) => {
     if (glowing) {
         ctx.save();
         ctx.shadowColor = color;
-        ctx.shadowBlur = 10 + Math.sin(time/500) * 3; // Pulsing glow effect
+        ctx.shadowBlur = 10 + Math.sin(time/500) * 3;
     }
 
     // Draw each blade of grass
-    for (let i = 0; i < blades; i++) {
-        const bladeX = x + (i - blades/2) * (width/blades);
-        const bladeWidth = width / blades * 0.7;
+    for (let i = 0; i < state.bladeCount; i++) {
+        // Calculate blade width - consistent regardless of blade count
+        const bladeWidth = width / 5 * 0.7;
+        
+        // Calculate blade position - cluster them together more tightly
+        const spreadFactor = 0.7; // Reduces the spread to create tighter clumps
+        const centerOffset = (i - (state.bladeCount - 1) / 2) * (width * spreadFactor / state.bladeCount);
+        const bladeX = x + centerOffset;
         
         // Calculate blade curve based on rustle and time
-        const rustleOffset = Math.sin(time/300 + i) * 5 * state.rustleAmount;
-        const baseWave = Math.sin(time/1000 + i) * 2;
+        const rustleOffset = Math.sin(time / 300 + i) * 5 * state.rustleAmount;
+        const baseWave = Math.sin(time / 1000 + i) * 2;
         
         // Draw blade
         ctx.fillStyle = i % 2 === 0 ? color : shadowColor;
@@ -894,7 +906,7 @@ const renderGrass = (ctx, grass, groundY, time) => {
         
         // Control points for quadratic curve
         const cp1x = bladeX + rustleOffset + baseWave;
-        const cp1y = groundY - height/2;
+        const cp1y = groundY - height / 2;
         const cp2x = bladeX + rustleOffset * 1.5 + baseWave;
         const cp2y = groundY - height;