Changes to wavewar.breckyunits.com

Breck Yunits
Breck Yunits
1 month ago
WaveWar.js
Changed around line 209: this.earthHealth = 1.0; // 1.0 = full health, 0 = dead
- this.maxDrones = 500 // Maximum number of drones allowed
+ this.maxDrones = 200 // Maximum number of drones allowed
Breck Yunits
Breck Yunits
1 month ago
WaveWar.js
Changed around line 209: this.earthHealth = 1.0; // 1.0 = full health, 0 = dead
- this.maxDrones = 1000 // Maximum number of drones allowed
+ this.maxDrones = 500 // Maximum number of drones allowed
Changed around line 816: const texture = new THREE.TextureLoader().load("earth_atmos_2048.jpg")
- this.droneSpawnInterval = Math.max(10, this.droneSpawnInterval * .98)
+ this.droneSpawnInterval = Math.max(10, this.droneSpawnInterval * .95)
Breck Yunits
Breck Yunits
1 month ago
WaveWar.js
Changed around line 816: const texture = new THREE.TextureLoader().load("earth_atmos_2048.jpg")
- this.droneSpawnInterval = Math.max(10, this.droneSpawnInterval * .99)
+ this.droneSpawnInterval = Math.max(10, this.droneSpawnInterval * .98)
Breck Yunits
Breck Yunits
1 month ago
WaveWar.js
Changed around line 812: const texture = new THREE.TextureLoader().load("earth_atmos_2048.jpg")
- this.drones.length < this.maxDrones
+ this.drones.length < this.maxDrones && !this.gameOver
Breck Yunits
Breck Yunits
1 month ago
WaveWar.js
Changed around line 1
- this.speed = 0.01 + Math.random() * 0.02
+ this.speed = 0.01 + Math.random() * 0.2
Changed around line 56: class Drone {
- update(delta) {
+ update(delta) {
+ if (this.globe.gameOver) return;
Changed around line 172: class Globe {
-
+ this.earthHealth = 1.0; // 1.0 = full health, 0 = dead
+ this.gameOver = false;
Changed around line 576: class Globe {
+
+
- const texture = new THREE.TextureLoader().load("earth_atmos_2048.jpg")
-
- // Use PhongMaterial for better lighting
+ const texture = new THREE.TextureLoader().load("earth_atmos_2048.jpg")
+ emissive: 0xff0000, // Red glow for damage
+ emissiveIntensity: 0 // Start with no damage glow
+
Changed around line 612: class Globe {
+ damageEarth() {
+ if (this.gameOver) return;
+
+ this.earthHealth = Math.max(0, this.earthHealth - 0.1); // Reduce health by 10%
+ this.earth.material.emissiveIntensity = 1 - this.earthHealth; // Increase red glow
+
+ if (this.earthHealth <= 0) {
+ this.triggerGameOver();
+ }
+ }
+
+
+ triggerGameOver() {
+ this.gameOver = true;
+
+ // Create explosion particles
+ const particleCount = 1000;
+ const particles = new THREE.Group();
+
+ for (let i = 0; i < particleCount; i++) {
+ const geometry = new THREE.BoxGeometry(0.02, 0.02, 0.02);
+ const material = new THREE.MeshPhongMaterial({
+ color: Math.random() > 0.5 ? 0xff4444 : 0xff7700,
+ emissive: 0x441111,
+ });
+ const particle = new THREE.Mesh(geometry, material);
+
+ // Position particles on earth's surface
+ const theta = Math.random() * Math.PI * 2;
+ const phi = Math.random() * Math.PI;
+ const radius = 0.5;
+
+ particle.position.x = radius * Math.sin(phi) * Math.cos(theta);
+ particle.position.y = radius * Math.sin(phi) * Math.sin(theta);
+ particle.position.z = radius * Math.cos(phi);
+
+ // Add velocity for explosion
+ const velocity = new THREE.Vector3()
+ .copy(particle.position)
+ .normalize()
+ .multiplyScalar(0.03);
+ particle.velocity = velocity;
+
+ particles.add(particle);
+ }
+
+ this.scene.add(particles);
+ this.explosionParticles = particles;
+
+ // Hide Earth
+ this.earth.visible = false;
+
+ // Create game over text
+ const gameOverDiv = document.createElement('div');
+ gameOverDiv.style.position = 'fixed';
+ gameOverDiv.style.top = '50%';
+ gameOverDiv.style.left = '50%';
+ gameOverDiv.style.transform = 'translate(-50%, -50%)';
+ gameOverDiv.style.color = '#ff0000';
+ gameOverDiv.style.fontSize = '64px';
+ gameOverDiv.style.fontFamily = 'Arial, sans-serif';
+ gameOverDiv.style.fontWeight = 'bold';
+ gameOverDiv.style.textShadow = '0 0 10px #ff0000';
+ gameOverDiv.style.zIndex = '1000';
+ gameOverDiv.innerHTML = `GAME OVER
Score: ${this.score}`;
+ document.body.appendChild(gameOverDiv);
+
+ // Start explosion animation
+ this.animateExplosion();
+ }
+
+ animateExplosion() {
+ if (!this.explosionParticles) return;
+
+ this.explosionParticles.children.forEach(particle => {
+ particle.position.add(particle.velocity);
+ particle.scale.multiplyScalar(0.98);
+ });
+
+ requestAnimationFrame(() => this.animateExplosion());
+ }
+
Changed around line 819: class Globe {
+
+ // Check for drone collisions with Earth
+ this.drones.forEach((drone) => {
+ if (!drone.isExploding) {
+ const distanceFromCenter = drone.position.length();
+ if (distanceFromCenter <= 0.52) { // Slightly larger than Earth's radius (0.5)
+ this.damageEarth();
+ drone.startExplosion();
+ }
+ }
+ });
+
Breck Yunits
Breck Yunits
1 month ago
WaveWar.js
Changed around line 313: class Globe {
+ }else if (e.key.toLowerCase() === " ") {
+ this.handleAction("EMP")
Breck Yunits
Breck Yunits
1 month ago
WaveWar.js
Changed around line 108: class Drone {
+ // Increment score when drone is destroyed
+ this.globe.score++;
+ document.getElementById('score-display').textContent = `Drones Destroyed: ${this.globe.score}`;
Changed around line 148: class Drone {
- // Increment score when drone is destroyed
- this.globe.score++;
- document.getElementById('score-display').textContent = `Drones: ${this.globe.score}`;
-
Breck Yunits
Breck Yunits
1 month ago
WaveWar.js
Changed around line 134: class Drone {
-
+ // Modify the Drone class's updateExplosion method
- const elapsed = Date.now() - this.explosionStartTime
- const progress = elapsed / this.explosionDuration
+ const elapsed = Date.now() - this.explosionStartTime;
+ const progress = elapsed / this.explosionDuration;
- this.globe.scene.remove(this.mesh)
- this.globe.scene.remove(this.explosionParticles)
- this.globe.drones = this.globe.drones.filter((d) => d !== this)
- return
+ this.globe.scene.remove(this.mesh);
+ this.globe.scene.remove(this.explosionParticles);
+ this.globe.drones = this.globe.drones.filter((d) => d !== this);
+
+ // Increment score when drone is destroyed
+ this.globe.score++;
+ document.getElementById('score-display').textContent = `Drones: ${this.globe.score}`;
+
+ return;
- particle.position.add(particle.velocity)
- particle.scale.multiplyScalar(0.95)
- })
+ particle.position.add(particle.velocity);
+ particle.scale.multiplyScalar(0.95);
+ });
- this.mesh.scale.multiplyScalar(0.9)
+ this.mesh.scale.multiplyScalar(0.9);
Changed around line 173: class Globe {
+ this.score = 0;
+ this.createScoreDisplay();
+
Changed around line 211: class Globe {
+
+ createScoreDisplay() {
+ const scoreDisplay = document.createElement("div");
+ scoreDisplay.style.position = "fixed";
+ scoreDisplay.style.top = "20px";
+ scoreDisplay.style.right = "20px";
+ scoreDisplay.style.padding = "10px 20px";
+ scoreDisplay.style.backgroundColor = "rgba(0, 0, 0, 0.8)";
+ scoreDisplay.style.color = "#4CAF50";
+ scoreDisplay.style.borderRadius = "10px";
+ scoreDisplay.style.fontSize = "24px";
+ scoreDisplay.style.fontFamily = "monospace";
+ scoreDisplay.style.zIndex = "1000";
+ scoreDisplay.style.border = "1px solid rgba(76, 175, 80, 0.3)";
+ scoreDisplay.id = "score-display";
+ scoreDisplay.textContent = "Drones Destroyed: 0";
+ document.body.appendChild(scoreDisplay);
+ }
+
+
Changed around line 340: class Globe {
- triggerSound() {
+ triggerSound() {
Changed around line 364: class Globe {
- float edge = 0.1;
+ float edge = 0.5;
Changed around line 380: class Globe {
- duration: 2000,
+ duration: 4000, // Increased from 2000 to 4000 for slower wave
Changed around line 403: class Globe {
- const scale = 1 + (wave.maxScale - 1) * progress
+ // Slower expansion rate
+ const scale = 1 + (wave.maxScale - 1) * (progress * 0.5) // Added 0.5 multiplier to slow expansion
Changed around line 440: class Globe {
- float edge = 0.05;
+ float edge = 0.2;
test.js
Breck Yunits
Breck Yunits
1 month ago
WaveWar.js
Changed around line 699: class Globe {
- this.droneSpawnInterval = Math.max(10, this.droneSpawnInterval * .8)
+ this.droneSpawnInterval = Math.max(10, this.droneSpawnInterval * .99)
Breck Yunits
Breck Yunits
1 month ago
index.html
Changed around line 33
-