Lompat ke konten Lompat ke sidebar Lompat ke footer

Batalla Por Terra 🆕 Must Read

def check_victory(self): if self.count_units("attacker") == 0: print("\n🏆 VICTORIA DEL DEFENSOR - Tierra defendida con éxito!") return True if self.count_units("defender") == 0: print("\n🏆 VICTORIA DEL ATACANTE - Tierra conquistada!") return True return False

// Verificar fin de batalla function checkVictory() const attackerCount = countUnits("attacker"); const defenderCount = countUnits("defender"); document.getElementById("attacker-stats").innerText = attackerCount; document.getElementById("defender-stats").innerText = defenderCount; if (attackerCount === 0) addLog("🏆 ¡VICTORIA DEL DEFENSOR! La tierra permanece firme."); return "defender"; if (defenderCount === 0) addLog("🏆 ¡VICTORIA DEL ATACANTE! La tierra es conquistada."); return "attacker"; return null; batalla por terra

// Lógica de selección y ataque function handleCellClick(x, y) if (checkVictory()) return; const cell = grid[x][y]; // Si tenemos unidad seleccionada if (selectedUnit) const sel = selectedUnit; if (cell.side && cell.side !== currentTurn) // Atacar attack(sel.x, sel.y, x, y); selectedUnit = null; updateUI(); const winner = checkVictory(); if (!winner) // Después de atacar no se cambia turno automáticamente (opcional, puedes cambiarlo) // Por diseño: ataque consume turno? En muchos juegos sí. Aquí decidimos que después de atacar termina turno // Descomentar si quieres que atacar termine turno: endTurn(); updateUI(); else // Selección inválida addLog("❌ No puedes atacar ahí"); selectedUnit = null; updateUI(); // Si no hay selección, seleccionar unidad propia si es el turno correcto else if (cell.side === currentTurn && cell.unit !== null) selectedUnit = x, y ; addLog(`✅ Unidad $cell.unit.icon seleccionada en ($x,$y)`); updateUI(); else addLog("⚠️ Selecciona una unidad de tu ejército."); def check_victory(self): if self

def play(self): while True: self.display() if self.check_victory(): break print("\nOpciones: ") print("1. Atacar (coordenadas atacante x y | defensor x y)") print("2. Terminar turno") print("3. Rendirse") opt = input("Elige: ") if opt == "3": print(f"self.current_turn se rinde. Batalla terminada.") break elif opt == "2": self.change_turn() continue elif opt == "1": try: ax, ay, dx, dy = map(int, input("Atacante (x y) y Defensor (x y): ").split()) if 0<=ax<self.size and 0<=ay<self.size and 0<=dx<self.size and 0<=dy<self.size: success, msg = self.attack(ax, ay, dx, dy) print(msg) if success: if self.check_victory(): break self.change_turn() else: print("Coordenadas inválidas") except: print("Formato incorrecto. Ejemplo: 1 0 6 7") input("\nPresiona Enter para continuar...") if == " main ": game = LandBattle(8) game.play() Características del Feature "Batalla por Tierra" ✅ Campo de batalla con terreno variable ✅ Dos facciones (Atacante/Defensor) ✅ Unidades con atributos distintos (daño, defensa, rango, HP) ✅ El terreno modifica el daño y defensa ✅ Sistema por turnos ✅ Interfaz visual para web o consola En muchos juegos sí

// Tipos de unidad const UNITS = INFANTRY: name: "⚔️", baseAtk: 8, baseDef: 5, range: 1, hp: 20, icon: "⚔️" , ARCHER: name: "🏹", baseAtk: 6, baseDef: 3, range: 3, hp: 15, icon: "🏹" , CAVALRY: name: "🐎", baseAtk: 10, baseDef: 4, range: 1, hp: 18, icon: "🐎" ;

class Unit: def (self, unit_type, side): self.type = unit_type self.side = side if unit_type == "Infantry": self.atk, self.defense, self.range, self.max_hp = 8, 5, 1, 20 self.icon = "⚔️" elif unit_type == "Archer": self.atk, self.defense, self.range, self.max_hp = 6, 3, 3, 15 self.icon = "🏹" else: # Cavalry self.atk, self.defense, self.range, self.max_hp = 10, 4, 1, 18 self.icon = "🐎" self.hp = self.max_hp