function randomTerrain() const r = Math.random(); if (r < 0.5) return TERRAIN.PLAIN; if (r < 0.75) return TERRAIN.FOREST; return TERRAIN.HILL;
// Calcular daño con terreno function calculateDamage(attacker, defender, attackerTerrain, defenderTerrain) let baseDmg = attacker.baseAtk - defender.baseDef; if (baseDmg < 2) baseDmg = 2; let terrainAtkMod = attackerTerrain.dmgModAttacker; let terrainDefMod = defenderTerrain.dmgModDefender; let finalDamage = Math.floor(baseDmg * terrainAtkMod * terrainDefMod); finalDamage += Math.floor(Math.random() * 4); // azar pequeño if (finalDamage < 1) finalDamage = 1; return finalDamage; batalla por terra
// Verificar si está en rango (distancia Manhattan) function isInRange(ax, ay, dx, dy, range) return (Math.abs(ax - dx) + Math.abs(ay - dy)) <= range; function randomTerrain() const r = Math
// Terrenos const TERRAIN = PLAIN: name: "🌾", dmgModAttacker: 1.0, dmgModDefender: 1.0, defBonus: 0 , FOREST: name: "🌲", dmgModAttacker: 0.9, dmgModDefender: 1.1, defBonus: 2 , HILL: name: "⛰️", dmgModAttacker: 1.15, dmgModDefender: 0.95, defBonus: 1 ; "attacker" : "defender"
def calculate_damage(self, attacker, defender, att_terrain, def_terrain): base = attacker.atk - defender.defense if base < 2: base = 2 damage = int(base * att_terrain["dmg_atk"] * def_terrain["dmg_def"]) + random.randint(-1, 3) return max(1, damage)
// Renderizar grid function renderGrid() const gridContainer = document.getElementById("battle-grid"); gridContainer.innerHTML = ""; for (let i = 0; i < GRID_SIZE; i++) for (let j = 0; j < GRID_SIZE; j++) const cell = grid[i][j]; const cellDiv = document.createElement("div"); cellDiv.className = `cell $cell.terrain.name === "🌾" ? "plain" : (cell.terrain.name === "🌲" ? "forest" : "hill")`; if (selectedUnit && selectedUnit.x === i && selectedUnit.y === j) cellDiv.classList.add("selected"); let innerHtml = `<div class="unit $ """>$cell.terrain.name</div>`; if (cell.unit) const sideClass = cell.side === "attacker" ? "attacker" : "defender"; innerHtml = `<div class="unit $sideClass">$cell.unit.icon</div> <div class="hp">❤️$cell.unit.hp/$cell.unit.maxHp</div>`; cellDiv.innerHTML = innerHtml; cellDiv.addEventListener("click", (function(x,y) return function() handleCellClick(x,y); ; )(i,j)); gridContainer.appendChild(cellDiv);
// Inicializar grid function initGrid() grid = Array(GRID_SIZE).fill().map(() => Array(GRID_SIZE).fill().map(() => ( terrain: randomTerrain(), unit: null, side: null // "attacker", "defender" )));