godzilla-toma / index.html
Deleteduser86's picture
Add 2 files
03c0ff2 verified
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Godzilla Tamagotchi</title>
<script src="https://cdn.tailwindcss.com"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
<style>
@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=VT323&display=swap');
:root {
--eink-bg: #f0f0e0;
--eink-text: #111;
--eink-highlight: #555;
--eink-pixel: #333;
--lcd-bg: #c8f7c5;
}
body {
font-family: 'VT323', monospace;
background-color: #222;
color: var(--eink-text);
overflow: hidden;
user-select: none;
}
.device {
background: linear-gradient(145deg, #3a3a3a, #2a2a2a);
box-shadow: 0 0 30px rgba(0, 0, 0, 0.7);
border-radius: 2rem;
position: relative;
}
.screen-border {
background: linear-gradient(145deg, #4a4a4a, #3a3a3a);
box-shadow: inset 0 0 15px rgba(0, 0, 0, 0.5);
border-radius: 1rem;
}
.eink-screen {
background-color: var(--eink-bg);
font-family: 'VT323', monospace;
color: var(--eink-text);
image-rendering: pixelated;
position: relative;
overflow: hidden;
}
.lcd-screen {
background-color: var(--lcd-bg);
font-family: 'VT323', monospace;
color: #333;
image-rendering: pixelated;
position: relative;
overflow: hidden;
}
.pixel-grid {
background-image:
linear-gradient(var(--eink-pixel) 0.1px, transparent 0.1px),
linear-gradient(90deg, var(--eink-pixel) 0.1px, transparent 0.1px);
background-size: 4px 4px;
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
opacity: 0.15;
pointer-events: none;
}
.godzilla-sprite {
image-rendering: pixelated;
filter: contrast(1.2) brightness(0.9);
transition: transform 0.3s ease;
}
.button {
background: linear-gradient(145deg, #5a5a5a, #3a3a3a);
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
transition: all 0.1s ease;
}
.button:active {
transform: translateY(2px);
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}
.screen-glare {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0) 60%);
pointer-events: none;
}
.scanlines {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: linear-gradient(
to bottom,
transparent 95%,
rgba(0,0,0,0.1) 96%
);
background-size: 100% 3px;
pointer-events: none;
animation: scanline 8s linear infinite;
}
@keyframes scanline {
0% { background-position: 0 0; }
100% { background-position: 0 100%; }
}
.status-bar {
border-bottom: 2px solid var(--eink-highlight);
padding: 0.25rem 0.5rem;
}
.health-bar {
background: linear-gradient(90deg, #ff5555, #ff0000);
height: 6px;
border-radius: 3px;
}
.hunger-bar {
background: linear-gradient(90deg, #ffaa00, #ff7700);
height: 6px;
border-radius: 3px;
}
.energy-bar {
background: linear-gradient(90deg, #55ff55, #00aa00);
height: 6px;
border-radius: 3px;
}
.mood-indicator {
width: 12px;
height: 12px;
border-radius: 50%;
box-shadow: 0 0 4px currentColor;
}
.mood-happy { background-color: #ff5555; color: #ff0000; }
.mood-neutral { background-color: #aaaaaa; color: #666666; }
.mood-angry { background-color: #55ff55; color: #00aa00; }
.pixel-border {
border: 2px solid var(--eink-text);
box-shadow:
inset 2px 2px 0 var(--eink-highlight),
inset -2px -2px 0 var(--eink-highlight);
}
.retro-text {
text-shadow: 1px 1px 0 var(--eink-highlight);
letter-spacing: 0.5px;
}
.action-button {
transition: all 0.1s ease;
border: 2px solid rgba(0,0,0,0.2);
box-shadow: inset 0 -2px 0 rgba(0,0,0,0.2);
}
.action-button:active {
transform: scale(0.95);
filter: brightness(0.9);
box-shadow: inset 0 0 4px rgba(0,0,0,0.3);
}
.godzilla-evolution {
animation: pulse 1s infinite alternate, glow 1.5s infinite alternate;
}
@keyframes pulse {
from { transform: scale(1); }
to { transform: scale(1.05); }
}
@keyframes glow {
from { filter: drop-shadow(0 0 4px rgba(255, 100, 0, 0.7)); }
to { filter: drop-shadow(0 0 10px rgba(255, 200, 0, 0.9)); }
}
.damage-effect {
animation: shake 0.5s cubic-bezier(.36,.07,.19,.97) both;
}
@keyframes shake {
10%, 90% { transform: translateX(-1px); }
20%, 80% { transform: translateX(2px); }
30%, 50%, 70% { transform: translateX(-3px); }
40%, 60% { transform: translateX(3px); }
}
.attack-effect {
position: absolute;
width: 100%;
height: 100%;
background: radial-gradient(circle, rgba(255,100,0,0.8) 0%, transparent 70%);
opacity: 0;
pointer-events: none;
animation: attackFlash 0.5s ease-out;
}
@keyframes attackFlash {
0% { opacity: 0; transform: scale(0.5); }
50% { opacity: 0.8; transform: scale(1); }
100% { opacity: 0; transform: scale(1.2); }
}
.sleep-effect {
position: absolute;
width: 100%;
height: 100%;
background: radial-gradient(circle, rgba(0,100,255,0.1) 0%, transparent 70%);
pointer-events: none;
}
.sleep-bubble {
position: absolute;
background-color: rgba(255,255,255,0.7);
border-radius: 50%;
animation: floatUp 4s linear infinite;
}
@keyframes floatUp {
0% { transform: translateY(0) scale(0.5); opacity: 0; }
10% { opacity: 1; }
90% { opacity: 1; }
100% { transform: translateY(-100px) scale(1.2); opacity: 0; }
}
.progress-container {
position: relative;
height: 8px;
background-color: rgba(0,0,0,0.1);
border-radius: 4px;
overflow: hidden;
}
.progress-bar {
height: 100%;
border-radius: 4px;
background: linear-gradient(90deg, #ff5555, #ff0000);
transition: width 0.3s ease;
}
.evolution-points {
position: absolute;
top: 0;
left: 0;
width: 100%;
text-align: center;
font-size: 0.6rem;
color: white;
text-shadow: 1px 1px 0 #000;
}
.menu-screen {
display: none;
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: rgba(0,0,0,0.7);
z-index: 10;
padding: 1rem;
}
.menu-content {
background-color: var(--lcd-bg);
border: 2px solid #000;
border-radius: 0.5rem;
padding: 1rem;
height: 100%;
overflow-y: auto;
}
.menu-item {
padding: 0.5rem;
margin-bottom: 0.5rem;
background-color: rgba(255,255,255,0.3);
border-radius: 0.25rem;
cursor: pointer;
transition: all 0.2s ease;
}
.menu-item:hover {
background-color: rgba(255,255,255,0.5);
}
.menu-item:active {
transform: scale(0.98);
}
.close-menu {
position: absolute;
top: 0.5rem;
right: 0.5rem;
background: none;
border: none;
font-size: 1.5rem;
cursor: pointer;
}
.city-background {
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: 30%;
background-color: #555;
background-image:
linear-gradient(90deg, #666 1px, transparent 1px),
linear-gradient(#666 1px, transparent 1px);
background-size: 20px 20px;
z-index: -1;
}
.explosion {
position: absolute;
width: 100px;
height: 100px;
background: radial-gradient(circle, rgba(255,200,0,0.8) 0%, rgba(255,100,0,0.8) 50%, transparent 70%);
border-radius: 50%;
transform: scale(0);
animation: explode 0.5s ease-out forwards;
pointer-events: none;
z-index: 5;
}
@keyframes explode {
0% { transform: scale(0); opacity: 1; }
100% { transform: scale(3); opacity: 0; }
}
.battle-screen {
display: none;
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: rgba(255,0,0,0.1);
z-index: 10;
}
.enemy {
position: absolute;
right: 20%;
bottom: 30%;
width: 60px;
height: 60px;
background-color: #333;
border-radius: 50%;
z-index: 2;
}
.battle-message {
position: absolute;
bottom: 10%;
left: 50%;
transform: translateX(-50%);
background-color: rgba(0,0,0,0.7);
color: white;
padding: 0.5rem 1rem;
border-radius: 0.5rem;
text-align: center;
z-index: 11;
}
.battle-options {
position: absolute;
bottom: 5%;
left: 0;
width: 100%;
display: flex;
justify-content: center;
gap: 1rem;
z-index: 11;
}
.battle-option {
background-color: rgba(255,255,255,0.8);
border: 2px solid #000;
border-radius: 0.5rem;
padding: 0.5rem 1rem;
cursor: pointer;
transition: all 0.2s ease;
}
.battle-option:hover {
background-color: rgba(255,255,255,1);
}
.battle-option:active {
transform: scale(0.95);
}
</style>
</head>
<body class="flex items-center justify-center min-h-screen p-4">
<div class="device rounded-3xl p-6 relative w-full max-w-md">
<!-- Upper E-ink Display -->
<div class="screen-border rounded-xl p-3 mb-4">
<div class="eink-screen rounded-lg pixel-border h-64 relative overflow-hidden">
<div class="pixel-grid"></div>
<div class="scanlines"></div>
<div class="screen-glare"></div>
<div class="city-background"></div>
<!-- Status Bar -->
<div class="status-bar flex justify-between items-center px-2 py-1">
<div class="text-xs retro-text">GODZILLA-TAMA</div>
<div class="flex items-center space-x-3">
<div class="flex items-center space-x-1">
<div class="mood-indicator mood-happy"></div>
<span class="text-xs retro-text" id="mood-text">HAPPY</span>
</div>
<div class="text-xs retro-text">AGE: <span id="age">1</span></div>
</div>
</div>
<!-- Main Display Content -->
<div class="flex flex-col items-center justify-center h-40 relative">
<div id="godzilla-container" class="relative">
<img id="godzilla-sprite" src="" class="godzilla-sprite w-32 h-32" alt="Baby Godzilla">
<div id="damage-overlay" class="absolute inset-0 bg-red-500 opacity-0 pointer-events-none"></div>
<div id="sleep-overlay" class="absolute inset-0 pointer-events-none" style="display: none;"></div>
<div id="attack-effect" class="attack-effect"></div>
</div>
<div id="action-text" class="text-sm mt-2 retro-text px-2 py-1 bg-white bg-opacity-70 rounded">*RAWR!*</div>
</div>
<!-- Stats Bars -->
<div class="absolute bottom-0 left-0 right-0 px-2 pb-2">
<div class="flex justify-between text-xs mb-1">
<span>HP</span>
<span>HGR</span>
<span>NRG</span>
<span>EVOL</span>
</div>
<div class="flex space-x-1">
<div class="health-bar flex-grow" id="health-bar"></div>
<div class="hunger-bar flex-grow" id="hunger-bar"></div>
<div class="energy-bar flex-grow" id="energy-bar"></div>
<div class="progress-container w-16" id="evolution-container">
<div class="progress-bar" id="evolution-bar"></div>
<div class="evolution-points" id="evolution-text">0%</div>
</div>
</div>
</div>
<!-- Battle Screen (Hidden by default) -->
<div id="battle-screen" class="battle-screen">
<div class="enemy" id="enemy"></div>
<div class="battle-message" id="battle-message"></div>
<div class="battle-options">
<div class="battle-option" id="battle-attack">ATTACK</div>
<div class="battle-option" id="battle-special">SPECIAL</div>
<div class="battle-option" id="battle-flee">FLEE</div>
</div>
</div>
</div>
</div>
<!-- Lower LCD Display -->
<div class="screen-border rounded-xl p-3">
<div class="lcd-screen rounded-lg pixel-border h-40 relative overflow-hidden">
<div class="pixel-grid"></div>
<div class="scanlines"></div>
<!-- Menu Buttons -->
<div class="grid grid-cols-3 gap-2 p-2 h-full">
<button id="feed-btn" class="action-button bg-yellow-400 rounded-md flex flex-col items-center justify-center p-1 hover:bg-yellow-500">
<i class="fas fa-hamburger text-xl"></i>
<span class="text-xs mt-1">FEED</span>
</button>
<button id="train-btn" class="action-button bg-blue-400 rounded-md flex flex-col items-center justify-center p-1 hover:bg-blue-500">
<i class="fas fa-dumbbell text-xl"></i>
<span class="text-xs mt-1">TRAIN</span>
</button>
<button id="battle-btn" class="action-button bg-red-400 rounded-md flex flex-col items-center justify-center p-1 hover:bg-red-500">
<i class="fas fa-fist-raised text-xl"></i>
<span class="text-xs mt-1">BATTLE</span>
</button>
<button id="sleep-btn" class="action-button bg-purple-400 rounded-md flex flex-col items-center justify-center p-1 hover:bg-purple-500">
<i class="fas fa-moon text-xl"></i>
<span class="text-xs mt-1">SLEEP</span>
</button>
<button id="stats-btn" class="action-button bg-green-400 rounded-md flex flex-col items-center justify-center p-1 hover:bg-green-500">
<i class="fas fa-chart-line text-xl"></i>
<span class="text-xs mt-1">STATS</span>
</button>
<button id="special-btn" class="action-button bg-pink-400 rounded-md flex flex-col items-center justify-center p-1 hover:bg-pink-500">
<i class="fas fa-bolt text-xl"></i>
<span class="text-xs mt-1">SPECIAL</span>
</button>
</div>
<!-- Menu Screen (Hidden by default) -->
<div id="menu-screen" class="menu-screen">
<div class="menu-content">
<button class="close-menu" id="close-menu">×</button>
<h2 class="text-lg mb-4 text-center border-b-2 border-black pb-2">GODZILLA STATS</h2>
<div class="menu-item">
<div class="font-bold">Stage:</div>
<div id="menu-stage">Baby</div>
</div>
<div class="menu-item">
<div class="font-bold">Health:</div>
<div id="menu-health">100/100</div>
</div>
<div class="menu-item">
<div class="font-bold">Hunger:</div>
<div id="menu-hunger">50/100</div>
</div>
<div class="menu-item">
<div class="font-bold">Energy:</div>
<div id="menu-energy">100/100</div>
</div>
<div class="menu-item">
<div class="font-bold">Evolution:</div>
<div id="menu-evolution">0%</div>
</div>
<div class="menu-item">
<div class="font-bold">Age:</div>
<div id="menu-age">1 day</div>
</div>
<div class="menu-item">
<div class="font-bold">Mood:</div>
<div id="menu-mood">Happy</div>
</div>
<div class="menu-item">
<div class="font-bold">Battles Won:</div>
<div id="menu-battles">0</div>
</div>
</div>
</div>
</div>
</div>
<!-- Physical Buttons -->
<div class="flex justify-between mt-4 px-4">
<div class="flex space-x-6">
<button id="left-btn" class="button rounded-full w-12 h-12 flex items-center justify-center hover:bg-gray-600">
<i class="fas fa-arrow-left text-xl"></i>
</button>
<button id="right-btn" class="button rounded-full w-12 h-12 flex items-center justify-center hover:bg-gray-600">
<i class="fas fa-arrow-right text-xl"></i>
</button>
</div>
<button id="select-btn" class="button rounded-full w-12 h-12 flex items-center justify-center hover:bg-gray-600">
<i class="fas fa-circle text-xl"></i>
</button>
</div>
<!-- Device Details -->
<div class="absolute top-0 left-0 right-0 flex justify-center mt-2">
<div class="bg-gray-800 rounded-full w-16 h-4"></div>
</div>
<div class="absolute bottom-0 left-0 right-0 flex justify-center mb-1">
<div class="text-xs text-gray-400">©1997 BANDAI TOHO</div>
</div>
</div>
<script>
// Enhanced Game State
const state = {
health: 100,
maxHealth: 100,
hunger: 50,
maxHunger: 100,
energy: 100,
maxEnergy: 100,
age: 1,
stage: 'baby',
mood: 'happy',
isSleeping: false,
isBattling: false,
evolutionPoints: 0,
maxEvolutionPoints: 30,
lastFed: Date.now(),
lastTrained: Date.now(),
lastAction: Date.now(),
battlesWon: 0,
battlesLost: 0,
enemiesDefeated: [],
specialAttackReady: true,
evolutionReady: false,
sleepBubbles: []
};
// Enhanced Godzilla Sprites (Base64 encoded SVGs)
const sprites = {
baby: "",
teen: "",
adult: "",
king: ""
};
// Enemies for battle
const enemies = {
mothra: { name: "Mothra", health: 30, attack: 5, sprite: "" },
ghidorah: { name: "Ghidorah", health: 50, attack: 8, sprite: "" },
mechagodzilla: { name: "Mechagodzilla", health: 70, attack: 12, sprite: "" }
};
// Action Messages
const messages = {
happy: ["*RAWR!*", "*STOMP STOMP*", "Feed me humans!", "Let's destroy Tokyo!", "I feel powerful!", "Atomic breath ready!", "King of monsters!"],
neutral: ["...zzz...", "Hmm...", "I'm bored", "What now?", "Not bad", "Maybe I'll nap", "Where's my snack?"],
angry: ["GRRRR!!!", "I'll destroy you!", "RAAAAH!", "FIGHT ME!", "I'M HUNGRY!", "OUT OF MY WAY!", "DESTROY!!!"]
};
// Initialize game
function initGame() {
updateDisplay();
setInterval(gameLoop, 3000);
setInterval(decrementStats, 10000);
setInterval(updateSleepBubbles, 1000);
// Button event listeners
document.getElementById('feed-btn').addEventListener('click', feed);
document.getElementById('train-btn').addEventListener('click', train);
document.getElementById('battle-btn').addEventListener('click', startBattle);
document.getElementById('sleep-btn').addEventListener('click', toggleSleep);
document.getElementById('stats-btn').addEventListener('click', showStats);
document.getElementById('special-btn').addEventListener('click', specialAction);
document.getElementById('left-btn').addEventListener('click', () => navigate('left'));
document.getElementById('right-btn').addEventListener('click', () => navigate('right'));
document.getElementById('select-btn').addEventListener('click', selectAction);
document.getElementById('close-menu').addEventListener('click', closeMenu);
// Battle event listeners
document.getElementById('battle-attack').addEventListener('click', battleAttack);
document.getElementById('battle-special').addEventListener('click', battleSpecial);
document.getElementById('battle-flee').addEventListener('click', fleeBattle);
}
// Main game loop
function gameLoop() {
if (state.isSleeping) {
state.energy = Math.min(state.maxEnergy, state.energy + 15);
state.health = Math.min(state.maxHealth, state.health + 5);
if (Math.random() > 0.85) toggleSleep(); // Wake up randomly
} else {
state.hunger = Math.min(state.maxHunger, state.hunger + 5);
state.energy = Math.max(0, state.energy - 2);
}
// Check for evolution
checkEvolution();
// Update mood
updateMood();
// Random events
if (!state.isSleeping && !state.isBattling && Math.random() > 0.9) {
randomEvent();
}
updateDisplay();
}
// Decrement stats over time
function decrementStats() {
if (!state.isSleeping && !state.isBattling) {
state.health = Math.max(0, state.health - 1);
if (state.hunger > 80) {
state.health = Math.max(0, state.health - 3);
}
if (state.energy < 20) {
state.health = Math.max(0, state.health - 2);
}
}
// Age over time
if (Date.now() - state.lastAction > 60000) {
state.age++;
state.lastAction = Date.now();
}
updateDisplay();
}
// Update all display elements
function updateDisplay() {
// Update bars
document.getElementById('health-bar').style.width = `${(state.health / state.maxHealth) * 100}%`;
document.getElementById('hunger-bar').style.width = `${(state.hunger / state.maxHunger) * 100}%`;
document.getElementById('energy-bar').style.width = `${(state.energy / state.maxEnergy) * 100}%`;
// Update evolution progress
const evolutionPercent = Math.min(100, (state.evolutionPoints / state.maxEvolutionPoints) * 100);
document.getElementById('evolution-bar').style.width = `${evolutionPercent}%`;
document.getElementById('evolution-text').textContent = `${Math.floor(evolutionPercent)}%`;
// Update age
document.getElementById('age').textContent = state.age;
// Update sprite
document.getElementById('godzilla-sprite').src = sprites[state.stage];
// Update mood indicator and text
const moodIndicator = document.querySelector('.mood-indicator');
moodIndicator.className = 'mood-indicator';
moodIndicator.classList.add(`mood-${state.mood}`);
document.getElementById('mood-text').textContent = state.mood.toUpperCase();
// Random action text
if (!state.isBattling && Date.now() - state.lastAction > 5000) {
showRandomMessage();
}
// Update sleep overlay
const sleepOverlay = document.getElementById('sleep-overlay');
if (state.isSleeping) {
sleepOverlay.style.display = 'block';
} else {
sleepOverlay.style.display = 'none';
}
// Update menu stats if open
if (document.getElementById('menu-screen').style.display === 'block') {
updateMenuStats();
}
}
// Update menu stats
function updateMenuStats() {
document.getElementById('menu-stage').textContent = state.stage.charAt(0).toUpperCase() + state.stage.slice(1);
document.getElementById('menu-health').textContent = `${state.health}/${state.maxHealth}`;
document.getElementById('menu-hunger').textContent = `${state.hunger}/${state.maxHunger}`;
document.getElementById('menu-energy').textContent = `${state.energy}/${state.maxEnergy}`;
document.getElementById('menu-evolution').textContent = `${Math.floor((state.evolutionPoints / state.maxEvolutionPoints) * 100)}%`;
document.getElementById('menu-age').textContent = `${state.age} day${state.age !== 1 ? 's' : ''}`;
document.getElementById('menu-mood').textContent = state.mood.charAt(0).toUpperCase() + state.mood.slice(1);
document.getElementById('menu-battles').textContent = state.battlesWon;
}
// Show random message based on mood
function showRandomMessage() {
const messagesArray = messages[state.mood];
const randomMessage = messagesArray[Math.floor(Math.random() * messagesArray.length)];
showMessage(randomMessage);
}
// Update mood based on stats
function updateMood() {
if (state.health < 30 || state.hunger > 80) {
state.mood = 'angry';
} else if (state.energy < 30 || state.hunger > 60) {
state.mood = 'neutral';
} else {
state.mood = 'happy';
}
}
// Check for evolution
function checkEvolution() {
if (state.evolutionPoints >= state.maxEvolutionPoints && !state.evolutionReady) {
state.evolutionReady = true;
showMessage("READY TO EVOLVE!");
document.getElementById('godzilla-container').classList.add('godzilla-evolution');
}
// Manual evolution when ready
if (state.evolutionReady && document.getElementById('evolution-container').getAttribute('data-click-to-evolve')) {
if (state.stage === 'baby') {
evolveToTeen();
} else if (state.stage === 'teen') {
evolveToAdult();
} else if (state.stage === 'adult') {
evolveToKing();
}
}
}
// Evolve to teen stage
function evolveToTeen() {
state.stage = 'teen';
state.evolutionPoints = 0;
state.maxEvolutionPoints = 60;
state.evolutionReady = false;
state.maxHealth = 120;
state.health = 120;
state.maxEnergy = 120;
state.energy = 120;
showMessage("EVOLVED TO TEEN!");
document.getElementById('godzilla-container').classList.remove('godzilla-evolution');
document.getElementById('evolution-container').removeAttribute('data-click-to-evolve');
createExplosion(64, 64);
}
// Evolve to adult stage
function evolveToAdult() {
state.stage = 'adult';
state.evolutionPoints = 0;
state.maxEvolutionPoints = 100;
state.evolutionReady = false;
state.maxHealth = 150;
state.health = 150;
state.maxEnergy = 150;
state.energy = 150;
showMessage("EVOLVED TO ADULT!");
document.getElementById('godzilla-container').classList.remove('godzilla-evolution');
document.getElementById('evolution-container').removeAttribute('data-click-to-evolve');
createExplosion(64, 64);
}
// Evolve to king stage
function evolveToKing() {
state.stage = 'king';
state.evolutionPoints = 0;
state.maxEvolutionPoints = 0; // Max evolution reached
state.evolutionReady = false;
state.maxHealth = 200;
state.health = 200;
state.maxEnergy = 200;
state.energy = 200;
showMessage("KING OF MONSTERS!");
document.getElementById('godzilla-container').classList.remove('godzilla-evolution');
document.getElementById('evolution-container').removeAttribute('data-click-to-evolve');
createExplosion(64, 64);
}
// Feed action
function feed() {
if (state.isSleeping) {
showMessage("Zzz... sleeping");
return;
}
if (state.isBattling) {
showMessage("Can't feed during battle!");
return;
}
state.hunger = Math.max(0, state.hunger - 30);
state.health = Math.min(state.maxHealth, state.health + 5);
state.lastFed = Date.now();
state.lastAction = Date.now();
// Animate eating
document.getElementById('godzilla-sprite').style.transform = 'scale(1.1)';
setTimeout(() => {
document.getElementById('godzilla-sprite').style.transform = 'scale(1)';
}, 300);
showMessage("YUM! Nuclear waste!");
updateDisplay();
}
// Train action
function train() {
if (state.isSleeping) {
showMessage("Zzz... sleeping");
return;
}
if (state.isBattling) {
showMessage("Already in battle!");
return;
}
if (state.energy < 20) {
showMessage("Too tired...");
return;
}
state.energy = Math.max(0, state.energy - 15);
state.hunger = Math.min(state.maxHunger, state.hunger + 10);
state.evolutionPoints += 5;
state.lastTrained = Date.now();
state.lastAction = Date.now();
// Animate training
document.getElementById('godzilla-sprite').style.transform = 'translateY(-5px)';
setTimeout(() => {
document.getElementById('godzilla-sprite').style.transform = 'translateY(0)';
}, 300);
showMessage("Training my atomic breath!");
updateDisplay();
}
// Start battle
function startBattle() {
if (state.isSleeping) {
showMessage("Zzz... sleeping");
return;
}
if (state.isBattling) {
showMessage("Already in battle!");
return;
}
if (state.energy < 10) {
showMessage("Need more energy...");
return;
}
state.isBattling = true;
state.battleEnemy = getRandomEnemy();
document.getElementById('battle-screen').style.display = 'block';
document.getElementById('enemy').style.backgroundImage = `url('${state.battleEnemy.sprite}')`;
document.getElementById('battle-message').textContent = `A wild ${state.battleEnemy.name} appears!`;
state.lastAction = Date.now();
updateDisplay();
}
// Get random enemy
function getRandomEnemy() {
const enemyKeys = Object.keys(enemies);
const randomKey = enemyKeys[Math.floor(Math.random() * enemyKeys.length)];
return {
...enemies[randomKey],
currentHealth: enemies[randomKey].health
};
}
// Battle attack
function battleAttack() {
if (!state.isBattling) return;
// Godzilla attacks
const godzillaDamage = Math.floor(Math.random() * 10) + 5 + (state.stage === 'teen' ? 5 : state.stage === 'adult' ? 10 : state.stage === 'king' ? 15 : 0);
state.battleEnemy.currentHealth = Math.max(0, state.battleEnemy.currentHealth - godzillaDamage);
// Enemy attacks back
const enemyDamage = Math.floor(Math.random() * state.battleEnemy.attack) + 1;
state.health = Math.max(0, state.health - enemyDamage);
// Update battle message
document.getElementById('battle-message').textContent =
`You hit ${state.battleEnemy.name} for ${godzillaDamage} damage!\n` +
`${state.battleEnemy.name} hits you for ${enemyDamage} damage!`;
// Show attack effects
showAttackEffect();
showDamage();
createExplosion(80, 40);
// Check battle outcome
checkBattleOutcome();
state.lastAction = Date.now();
updateDisplay();
}
// Battle special attack
function battleSpecial() {
if (!state.isBattling || !state.specialAttackReady) return;
// Godzilla special attack
const godzillaDamage = Math.floor(Math.random() * 20) + 15 + (state.stage === 'teen' ? 5 : state.stage === 'adult' ? 10 : state.stage === 'king' ? 20 : 0);
state.battleEnemy.currentHealth = Math.max(0, state.battleEnemy.currentHealth - godzillaDamage);
// Update battle message
document.getElementById('battle-message').textContent =
`ATOMIC BREATH! You hit ${state.battleEnemy.name} for ${godzillaDamage} damage!`;
// Show special attack effects
showAttackEffect();
createExplosion(80, 40);
document.getElementById('godzilla-container').classList.add('godzilla-evolution');
setTimeout(() => {
document.getElementById('godzilla-container').classList.remove('godzilla-evolution');
}, 1000);
state.specialAttackReady = false;
setTimeout(() => {
state.specialAttackReady = true;
}, 30000);
// Check battle outcome
checkBattleOutcome();
state.lastAction = Date.now();
updateDisplay();
}
// Flee battle
function fleeBattle() {
if (!state.isBattling) return;
// 50% chance to flee successfully
if (Math.random() > 0.5) {
document.getElementById('battle-message').textContent = `You fled from ${state.battleEnemy.name}!`;
setTimeout(() => {
endBattle(false);
}, 1500);
} else {
// Enemy gets a free attack
const enemyDamage = Math.floor(Math.random() * state.battleEnemy.attack) + 5;
state.health = Math.max(0, state.health - enemyDamage);
document.getElementById('battle-message').textContent =
`Failed to flee!\n${state.battleEnemy.name} hits you for ${enemyDamage} damage!`;
showDamage();
}
state.lastAction = Date.now();
updateDisplay();
}
// Check battle outcome
function checkBattleOutcome() {
if (state.battleEnemy.currentHealth <= 0) {
// Victory
document.getElementById('battle-message').textContent = `You defeated ${state.battleEnemy.name}!`;
state.evolutionPoints += 10;
state.battlesWon++;
state.enemiesDefeated.push(state.battleEnemy.name);
setTimeout(() => {
endBattle(true);
}, 1500);
} else if (state.health <= 0) {
// Defeat
document.getElementById('battle-message').textContent = `You were defeated by ${state.battleEnemy.name}!`;
state.battlesLost++;
setTimeout(() => {
endBattle(false);
}, 1500);
}
}
// End battle
function endBattle(victory) {
state.isBattling = false;
document.getElementById('battle-screen').style.display = 'none';
if (victory) {
showMessage(`VICTORY! +10 EP`);
document.getElementById('godzilla-container').classList.add('godzilla-evolution');
setTimeout(() => {
document.getElementById('godzilla-container').classList.remove('godzilla-evolution');
}, 1000);
} else {
showMessage("DEFEAT! Need to train more...");
}
state.lastAction = Date.now();
updateDisplay();
}
// Toggle sleep
function toggleSleep() {
state.isSleeping = !state.isSleeping;
state.lastAction = Date.now();
if (state.isSleeping) {
showMessage("Zzz... sleeping");
startSleepBubbles();
} else {
showMessage("I'm awake!");
stopSleepBubbles();
}
updateDisplay();
}
// Create sleep bubbles
function startSleepBubbles() {
state.sleepBubbles = [];
for (let i = 0; i < 3; i++) {
state.sleepBubbles.push({
x: Math.random() * 100,
y: 100,
size: Math.random() * 10 + 5,
speed: Math.random() * 2 + 1
});
}
}
// Update sleep bubbles
function updateSleepBubbles() {
if (!state.isSleeping) return;
const sleepOverlay = document.getElementById('sleep-overlay');
// Remove old bubbles
while (sleepOverlay.firstChild) {
sleepOverlay.removeChild(sleepOverlay.firstChild);
}
// Update and create new bubbles
for (let i = 0; i < state.sleepBubbles.length; i++) {
const bubble = state.sleepBubbles[i];
bubble.y -= bubble.speed;
if (bubble.y < -10) {
bubble.y = 110;
bubble.x = Math.random() * 100;
}
const bubbleEl = document.createElement('div');
bubbleEl.className = 'sleep-bubble';
bubbleEl.style.left = `${bubble.x}%`;
bubbleEl.style.top = `${bubble.y}%`;
bubbleEl.style.width = `${bubble.size}px`;
bubbleEl.style.height = `${bubble.size}px`;
bubbleEl.style.animationDelay = `${i * 0.5}s`;
sleepOverlay.appendChild(bubbleEl);
}
// Occasionally add new bubbles
if (Math.random() > 0.7 && state.sleepBubbles.length < 10) {
state.sleepBubbles.push({
x: Math.random() * 100,
y: 100,
size: Math.random() * 10 + 5,
speed: Math.random() * 2 + 1
});
}
}
// Stop sleep bubbles
function stopSleepBubbles() {
state.sleepBubbles = [];
const sleepOverlay = document.getElementById('sleep-overlay');
while (sleepOverlay.firstChild) {
sleepOverlay.removeChild(sleepOverlay.firstChild);
}
}
// Show stats menu
function showStats() {
if (state.isBattling) {
showMessage("Can't check stats in battle!");
return;
}
updateMenuStats();
document.getElementById('menu-screen').style.display = 'block';
state.lastAction = Date.now();
}
// Close menu
function closeMenu() {
document.getElementById('menu-screen').style.display = 'none';
state.lastAction = Date.now();
}
// Special action
function specialAction() {
if (state.isSleeping) {
showMessage("Zzz... sleeping");
return;
}
if (state.isBattling) {
showMessage("Use special in battle!");
return;
}
if (state.energy < 50) {
showMessage("Not enough energy!");
return;
}
if (state.evolutionReady) {
// Trigger evolution
if (state.stage === 'baby') {
evolveToTeen();
} else if (state.stage === 'teen') {
evolveToAdult();
} else if (state.stage === 'adult') {
evolveToKing();
}
return;
}
state.energy = Math.max(0, state.energy - 50);
state.hunger = Math.min(state.maxHunger, state.hunger + 20);
if (state.stage === 'king') {
showMessage("ATOMIC BREATH!!!");
document.getElementById('godzilla-container').classList.add('godzilla-evolution');
setTimeout(() => {
document.getElementById('godzilla-container').classList.remove('godzilla-evolution');
}, 1000);
createExplosion(64, 64);
} else {
showMessage("Special attack practice!");
document.getElementById('godzilla-container').classList.add('godzilla-evolution');
setTimeout(() => {
document.getElementById('godzilla-container').classList.remove('godzilla-evolution');
}, 1000);
}
state.lastAction = Date.now();
updateDisplay();
}
// Navigation
function navigate(direction) {
showMessage(direction === 'left' ? "<--" : "-->");
state.lastAction = Date.now();
}
// Select action
function selectAction() {
if (state.evolutionReady) {
document.getElementById('evolution-container').setAttribute('data-click-to-evolve', 'true');
showMessage("CLICK EVOLUTION BAR!");
} else {
showMessage("SELECTED");
}
state.lastAction = Date.now();
}
// Show message
function showMessage(msg) {
const actionText = document.getElementById('action-text');
actionText.textContent = msg;
actionText.style.animation = 'none';
void actionText.offsetWidth; // Trigger reflow
actionText.style.animation = 'fadeIn 0.5s';
}
// Show damage effect
function showDamage() {
const damageOverlay = document.getElementById('damage-overlay');
damageOverlay.classList.add('damage-effect');
damageOverlay.style.opacity = '0.3';
setTimeout(() => {
damageOverlay.style.opacity = '0';
damageOverlay.classList.remove('damage-effect');
}, 500);
}
// Show attack effect
function showAttackEffect() {
const attackEffect = document.getElementById('attack-effect');
attackEffect.style.animation = 'none';
void attackEffect.offsetWidth; // Trigger reflow
attackEffect.style.animation = 'attackFlash 0.5s ease-out';
}
// Create explosion effect
function createExplosion(x, y) {
const explosion = document.createElement('div');
explosion.className = 'explosion';
explosion.style.left = `${x}px`;
explosion.style.top = `${y}px`;
document.getElementById('godzilla-container').appendChild(explosion);
setTimeout(() => {
explosion.remove();
}, 500);
}
// Random events
function randomEvent() {
const events = [
() => {
state.health = Math.min(state.maxHealth, state.health + 10);
showMessage("Found nuclear waste! +10 HP");
createExplosion(20, 100);
},
() => {
state.health = Math.max(0, state.health - 10);
showMessage("Attacked by Mothra! -10 HP");
showDamage();
createExplosion(64, 64);
},
() => {
state.evolutionPoints += 5;
showMessage("Training pays off! +5 EP");
},
() => {
showMessage("The city fears you!");
},
() => {
state.energy = Math.min(state.maxEnergy, state.energy + 20);
showMessage("Energy boost! +20 NRG");
},
() => {
if (state.stage === 'king') {
showMessage("Citizens worship you!");
} else {
showMessage("Grow stronger to rule!");
}
}
];
const randomEvent = events[Math.floor(Math.random() * events.length)];
randomEvent();
state.lastAction = Date.now();
updateDisplay();
}
// Initialize the game when the page loads
window.onload = initGame;
</script>
<p style="border-radius: 8px; text-align: center; font-size: 12px; color: #fff; margin-top: 16px;position: fixed; left: 8px; bottom: 8px; z-index: 10; background: rgba(0, 0, 0, 0.8); padding: 4px 8px;">Made with <img src="https://enzostvs-deepsite.hf.space/logo.svg" alt="DeepSite Logo" style="width: 16px; height: 16px; vertical-align: middle;display:inline-block;margin-right:3px;filter:brightness(0) invert(1);"><a href="https://enzostvs-deepsite.hf.space" style="color: #fff;text-decoration: underline;" target="_blank" >DeepSite</a> - <a href="https://enzostvs-deepsite.hf.space?remix=Deleteduser86/godzilla-toma" style="color: #fff;text-decoration: underline;" target="_blank" >🧬 Remix</a></p></body>
</html>