Code edit (2 edits merged)
Please save this source code
User prompt
every time the heroboss spawns should be bigger and after than the previous time
Code edit (1 edits merged)
Please save this source code
User prompt
after hero bullet is shot. if hero bullet still on screen after half a second, destroy it.
Code edit (1 edits merged)
Please save this source code
User prompt
move enemy boss lifebard 10 pixels to the left
Code edit (1 edits merged)
Please save this source code
User prompt
every time a new enemy boss is spawned, increase it's size 10% and its velocity 10%
Code edit (1 edits merged)
Please save this source code
User prompt
when spanwned assign a random color to enemy boss
User prompt
move heath bar 40 pixels up of enemnyboss
User prompt
change enemy movement to be different for every enemy spawned. boss should stay the same.
User prompt
if there is a herobullet rendered in the screen and has not been shot, destroy it.
User prompt
each enemy spawned should start hismovement on a different direction than the previous one
User prompt
make enemy moovement less synchronous
User prompt
triple enemy boss speed
User prompt
enemy boss should have random movement but allways towards the hero
User prompt
fist enemyy boss whould spawn after the first 10 enemies have spawned
User prompt
fist enemyy boss whould spawn after the first 10 enemies have spawned
User prompt
enemyboss should spawn every 10 enemies
User prompt
create a new enemyboss class
User prompt
Fix Bug: 'TypeError: Cannot read properties of undefined (reading 'undefined')' in this line: 'if (self.enemyCount < self.waveEnemyCount[self.waveIndex]) {' Line Number: 105
User prompt
Fix Bug: 'TypeError: Cannot read properties of undefined (reading 'undefined')' in this line: 'if (this.enemyCount < this.waveEnemyCount[this.waveIndex]) {' Line Number: 104
User prompt
Fix Bug: 'TypeError: Cannot read properties of undefined (reading 'undefined')' in this line: 'if (self.enemyCount < self.waveEnemyCount[self.waveIndex]) {' Line Number: 104
User prompt
Fix Bug: 'TypeError: Cannot read properties of undefined (reading 'undefined')' in this line: 'if (this.enemyCount < this.waveEnemyCount[this.waveIndex]) {' Line Number: 104
var EnemyBoss = Container.expand(function (hero) {
	var self = Container.call(this);
	var bossGraphics = self.createAsset('enemyBoss', 'Enemy Boss Graphics', .5, .5);
	self.speedY = 3;
	self.hero = hero;
	self.lifebar = self.createAsset('lifebar', 'Boss Lifebar', .5, 0);
	self.lifebar.y = -self.lifebar.height - 140;
	self.life = 500;
	self.move = function () {
		var dx = this.hero.x - this.x + (Math.random() - 0.5) * 100;
		var dy = this.hero.y - this.y + (Math.random() - 0.5) * 100;
		var angle = Math.atan2(dy, dx);
		self.x += Math.cos(angle) * self.speedY;
		self.y += Math.sin(angle) * self.speedY;
		self.lifebar.scale.x = self.life / 500;
		if (self.life <= 0) {
			self.destroy();
		}
	};
	self.shoot = function () {};
	self.on('tick', function () {
		self.move();
		self.shoot();
	});
});
var Cloud = Container.expand(function () {
	var self = Container.call(this);
	var trail = LK.getAsset('trail', 'Trail Graphics', 0.5, 0.5);
	var cloudGraphics = self.createAsset('cloud', 'Cloud Graphics', 0.5, 0.5);
	self.speedY = 1;
	self.move = function () {
		var cloudSpeed = 3.5;
		self.y += cloudSpeed;
		if (self.y > 2732) {
			self.y = -cloudGraphics.height;
		}
	};
});
var HeroBullet = Container.expand(function (hero) {
	var self = Container.call(this);
	var bulletGraphics = self.createAsset('heroBullet', 'Hero Bullet Graphics', .5, .5);
	self.speed = -1.5;
	self.damage = 1;
	self.move = function () {
		self.x += self.speedX * self.scale.x * self.scale.x;
		self.y += self.speedY * self.scale.y * self.scale.y;
		self.rotation = hero.rotation + Math.PI / 2;
		self.damage = self.scale.x * self.scale.y;
	};
});
var EnemyBullet = Container.expand(function () {
	var self = Container.call(this);
	var bulletGraphics = self.createAsset('enemyBullet', 'Enemy Bullet Graphics', .5, .5);
	self.speed = 3;
	self.move = function () {
		self.y += self.speed;
	};
});
var Hero = Container.expand(function () {
	var self = Container.call(this);
	var heroGraphics = self.createAsset('hero', 'Hero character', .5, .5);
	var trail = self.createAsset('trail', 'Trail Graphics', 1, 0.5);
	trail.rotation = Math.PI / 4;
	trail.y = heroGraphics.height / 2 - 80;
	trail.x = -heroGraphics.width / 2 + 30;
	trail.flicker = true;
	trail.flickerSpeed = 0.1;
	trail.flickerMinAlpha = 0.3;
	trail.flickerMaxAlpha = 0.7;
	LK.on('tick', function () {
		if (trail.flicker) {
			trail.alpha += trail.flickerSpeed;
			if (trail.alpha < trail.flickerMinAlpha || trail.alpha > trail.flickerMaxAlpha) {
				trail.flickerSpeed *= -1;
				trail.alpha = Math.max(trail.flickerMinAlpha, Math.min(trail.alpha, trail.flickerMaxAlpha));
			}
		}
	});
	self.movementDirection = 1;
	self.movementSpeed = 0.5;
	self.movementRange = 50;
	self.originalX = 2048 / 2;
	self.x = self.originalX;
	self.updateMovement = function () {
		self.x += self.movementDirection * self.movementSpeed;
		if (self.x < self.originalX - self.movementRange || self.x > self.originalX + self.movementRange) {
			self.movementDirection *= -1;
		}
	};
});
var Enemy = Container.expand(function (hero) {
	var self = Container.call(this);
	var enemyGraphics = self.createAsset('enemy', 'Enemy character', .5, .5);
	self.speedY = 2;
	self.hero = hero;
	self.lifebar = self.createAsset('lifebar', 'Enemy Lifebar', .5, 0);
	self.lifebar.y = -self.lifebar.height - 100;
	self.life = 100;
	self.move = function () {
		var dx = this.hero.x - this.x;
		var dy = this.hero.y - this.y;
		var angle = Math.atan2(dy, dx);
		var speedMultiplier = 1 + Math.floor(LK.ticks / 7200);
		self.x += (Math.cos(angle) * self.speedY + Math.sin(LK.ticks / 60) * 5) * speedMultiplier;
		self.y += Math.sin(angle) * self.speedY * speedMultiplier;
		self.lifebar.scale.x = self.life / 100;
	};
});
var Background = Container.expand(function () {
	var self = Container.call(this);
	var bg1 = self.createAsset('background', 'Game Background 1', 0, 0);
	var bg2 = self.createAsset('background', 'Game Background 2', 0, 0);
	bg1.width = bg2.width = 2048;
	bg1.height = bg2.height = 2732;
	bg2.y = -2732;
	self.addChild(bg1);
	self.addChild(bg2);
	self.move = function () {
		bg1.y += 1;
		bg2.y += 1;
		if (bg1.y >= 2732) bg1.y = -2732;
		if (bg2.y >= 2732) bg2.y = -2732;
	};
});
var Game = Container.expand(function () {
	var self = Container.call(this);
	var enemies = [];
	var enemiesSpawnedCount = 0;
	var particles = [];
	var background = self.addChild(new Background());
	background.alpha = 0.3;
	self.spawnEnemy = function () {
		var enemy;
		if (enemiesSpawnedCount % 10 === 0 && enemiesSpawnedCount !== 0) {
			enemy = new EnemyBoss(hero);
		} else {
			enemy = new Enemy(hero);
		}
		enemy.x = Math.random() * 2048;
		enemy.y = -enemy.height;
		enemies.push(enemy);
		self.addChild(enemy);
		enemiesSpawnedCount++;
	};
	var enemySpawnTicker = 0;
	LK.on('tick', function () {
		var spawnRate = Math.max(30, 120 - Math.floor(LK.ticks / 3600));
		if (enemySpawnTicker++ % spawnRate === 0) {
			self.spawnEnemy();
		}
	});
	stage.on('up', function (obj) {
		if (currentBullet) {
			var pos = obj.event.getLocalPosition(self);
			var dx = pos.x - hero.x;
			var dy = pos.y - hero.y;
			var angle = Math.atan2(dy, dx);
			currentBullet.speedX = Math.cos(angle) * 15;
			currentBullet.speedY = Math.sin(angle) * 15;
			hero.rotation = angle;
			heroBullets.push(currentBullet);
			currentBullet = null;
		}
	});
	LK.on('tick', function () {
		hero.updateMovement();
		background.move();
		if (currentBullet) {
			var holdDuration = LK.ticks - holdTime;
			var sizeMultiplier = Math.max(1, 1 + Math.abs(Math.sin(holdDuration / 60)) * 3);
			currentBullet.scale.x = sizeMultiplier;
			currentBullet.scale.y = sizeMultiplier;
			currentBullet.rotation = hero.rotation;
		}
	});
	var currentBullet = null;
	var holdTime = 0;
	var hero;
	hero = self.addChild(new Hero());
	hero.rotation = -Math.PI / 2;
	stage.on('down', function (obj) {
		var pos = obj.event.getLocalPosition(self);
		var dx = pos.x - hero.x;
		var dy = pos.y - hero.y;
		var angle = Math.atan2(dy, dx);
		hero.rotation = angle;
		currentBullet = new HeroBullet(hero);
		currentBullet.x = hero.x;
		currentBullet.y = hero.y - hero.height / 2 - currentBullet.height / 2 - 10;
		currentBullet.rotation = hero.rotation;
		self.addChild(currentBullet);
		holdTime = LK.ticks;
	});
	stage.on('move', function (obj) {
		var pos = obj.event.getLocalPosition(self);
		var dx = pos.x - hero.x;
		var dy = pos.y - hero.y;
		var angle = Math.atan2(dy, dx);
		hero.rotation = angle;
	});
	var enemies = [];
	var heroBullets = [];
	var enemyBullets = [];
	var clouds = [];
	var particles = [];
	for (var i = 0; i < 3; i++) {
		var cloud = new Cloud();
		cloud.alpha = 0.49;
		cloud.x = Math.random() * 2048;
		cloud.y = Math.random() * -2732;
		clouds.push(cloud);
		self.addChildAt(cloud, 1);
	}
	var scoreTxt = new Text2('0', {
		size: 150,
		fill: "#ffffff",
		dropShadow: true,
		dropShadowColor: "#000000",
		dropShadowBlur: 4,
		dropShadowAngle: Math.PI / 6,
		dropShadowDistance: 6
	});
	LK.gui.topCenter.addChild(scoreTxt);
	var isGameOver = false;
	hero.x = 2048 / 2;
	hero.y = 2732 - 280;
	LK.setTimeout(function () {
		var startPosition = hero.y;
		var endPosition = startPosition - 500;
		var duration = 120;
		var step = (startPosition - endPosition) / duration;
		var currentStep = 0;
		var moveHero = function () {
			if (currentStep < duration) {
				hero.y -= step;
				currentStep++;
			} else if (currentStep < duration * 2) {
				hero.y += step;
				currentStep++;
			} else {
				hero.y = startPosition;
				LK.clearInterval(heroMoveInterval);
			}
		};
		var heroMoveInterval = LK.setInterval(moveHero, 1000 / 60);
	}, 0);
	LK.on('tick', function () {
		for (var i = 0; i < heroBullets.length; i++) {
			if (heroBullets[i]) heroBullets[i].move();
			for (var j = 0; j < enemies.length; j++) {
				if (heroBullets[i] && heroBullets[i].intersects(enemies[j])) {
					enemies[j].life -= heroBullets[i].damage * 10;
					if (enemies[j].life <= 0) {
						var scoreIncrement = 10 + Math.floor(LK.ticks / 3600);
						LK.setScore(LK.getScore() + scoreIncrement);
						scoreTxt.setText(LK.getScore().toString());
						enemies[j].destroy();
						enemies.splice(j, 1);
					}
					heroBullets[i].destroy();
					heroBullets.splice(i, 1);
					break;
				}
			}
			if (heroBullets[i] && heroBullets[i].y < -50) {
				heroBullets[i].destroy();
				heroBullets.splice(i, 1);
				i--;
				i--;
			}
		}
		for (var i = 0; i < enemyBullets.length; i++) {
			enemyBullets[i].move();
			if (enemyBullets[i].y > 2732 + 50) {
				enemyBullets[i].destroy();
				enemyBullets.splice(i, 1);
			}
		}
		for (var i = 0; i < enemies.length; i++) {
			if (enemies[i].intersects(hero)) {
				isGameOver = true;
				break;
			}
		}
		for (var i = 0; i < enemies.length; i++) {
			enemies[i].move();
			if (enemies[i].y > 2732) {
				enemies[i].destroy();
				enemies.splice(i, 1);
				i--;
			}
		}
		clouds.forEach(function (cloud) {
			cloud.move();
		});
		if (isGameOver) {
			LK.effects.flashScreen(0xff0000, 1000);
			LK.showGameOver();
		}
	});
});
 ===================================================================
--- original.js
+++ change.js
@@ -3,13 +3,13 @@
 	var bossGraphics = self.createAsset('enemyBoss', 'Enemy Boss Graphics', .5, .5);
 	self.speedY = 3;
 	self.hero = hero;
 	self.lifebar = self.createAsset('lifebar', 'Boss Lifebar', .5, 0);
-	self.lifebar.y = -self.lifebar.height - 100;
+	self.lifebar.y = -self.lifebar.height - 140;
 	self.life = 500;
 	self.move = function () {
-		var dx = this.hero.x - this.x + (Math.random() - 0.5) * 200;
-		var dy = this.hero.y - this.y + (Math.random() - 0.5) * 200;
+		var dx = this.hero.x - this.x + (Math.random() - 0.5) * 100;
+		var dy = this.hero.y - this.y + (Math.random() - 0.5) * 100;
 		var angle = Math.atan2(dy, dx);
 		self.x += Math.cos(angle) * self.speedY;
 		self.y += Math.sin(angle) * self.speedY;
 		self.lifebar.scale.x = self.life / 500;
@@ -87,19 +87,19 @@
 			self.movementDirection *= -1;
 		}
 	};
 });
-var RegularEnemy = Container.expand(function (hero) {
+var Enemy = Container.expand(function (hero) {
 	var self = Container.call(this);
 	var enemyGraphics = self.createAsset('enemy', 'Enemy character', .5, .5);
 	self.speedY = 2;
 	self.hero = hero;
 	self.lifebar = self.createAsset('lifebar', 'Enemy Lifebar', .5, 0);
 	self.lifebar.y = -self.lifebar.height - 100;
 	self.life = 100;
 	self.move = function () {
-		var dx = this.hero.x - this.x + (Math.random() - 0.5) * 100;
-		var dy = this.hero.y - this.y + (Math.random() - 0.5) * 100;
+		var dx = this.hero.x - this.x;
+		var dy = this.hero.y - this.y;
 		var angle = Math.atan2(dy, dx);
 		var speedMultiplier = 1 + Math.floor(LK.ticks / 7200);
 		self.x += (Math.cos(angle) * self.speedY + Math.sin(LK.ticks / 60) * 5) * speedMultiplier;
 		self.y += Math.sin(angle) * self.speedY * speedMultiplier;
@@ -133,13 +133,12 @@
 		var enemy;
 		if (enemiesSpawnedCount % 10 === 0 && enemiesSpawnedCount !== 0) {
 			enemy = new EnemyBoss(hero);
 		} else {
-			enemy = new RegularEnemy(hero);
+			enemy = new Enemy(hero);
 		}
 		enemy.x = Math.random() * 2048;
 		enemy.y = -enemy.height;
-		enemy.movementDirection = enemiesSpawnedCount % 2 === 0 ? 1 : -1;
 		enemies.push(enemy);
 		self.addChild(enemy);
 		enemiesSpawnedCount++;
 	};
:quality(85)/https://cdn.frvr.ai/6589e4e8a7179ee9874d778a.png%3F3) 
 Goku arms doing kamehameha. seen from above. 8-bit. Cartoon. In game asset. No shadow Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/658a001af093e2712f8c3caf.png%3F3) 
 8-bit. Cartoon. Orange energy ball. . In game asset. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/658aa86f1910c89cf03292df.png%3F3) 
 rotate image 45 degrees
:quality(85)/https://cdn.frvr.ai/658ac6d11910c89cf0329374.png%3F3) 
 8-bit. cartoon. white energy ball. gradieint. transparent. in game asset. flicker. shoot. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/658ae0cd1910c89cf0329455.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658ae1d31910c89cf032947c.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658ae3281910c89cf03294a1.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658ae9231910c89cf032957e.png%3F3) 
 8-bit. cartoon. front view. flying final boss. white. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.