User prompt
fix the performance issue related to this.
User prompt
instead of spawning ballons when arrow hits the other ballons, spawn them at some interval
User prompt
there is some issue with the ballon spawning logic when wave changes, there should be only 2 ballons at a time when i am in wave 2, but it is spawning a lot.
User prompt
and also do not increase the movement speed of the ballons as the wave increases.
User prompt
change the wave logic to like, spawn the wave number of ballons at the same time.
User prompt
make arrow invincible
User prompt
player can shoot mulitple ballons with single arrow.
User prompt
fix the wave not changing issue, i want change the wave on every 50 points.
User prompt
solve the issue
User prompt
to collect the powerup player need to shoot arrow on the powerup
User prompt
on arrow can shoot multiple ballons.
User prompt
wave logic should be like this, if it is wave 2 then there will max two ballons can be spawn at the same time, if it is wave 3 there will be max 3 ballons can be spawned at the same time and so on.. and make the reduce the peak speed of the ballon movement.
User prompt
do not increase the movement speed of the ballons, when wave changes.
User prompt
reduce the max speed of ballons to go from bottom to up.
User prompt
on each ballon hit, give only 2 score.
User prompt
Also randomly spawn a power up, called Ballon bust which will destroy all the ballons spawned on the screen, when stickman collect the powerup.
User prompt
increase the rate of ballon spawn after each 50 points and, show the wave text for 2 sec at the middle of the screen.
User prompt
After all the ballon skips are finished, game over and show the final score.
User prompt
Stickman have 5 ballon skips, show as ballon on the top left of the screen, and whenever the stickman is not able to shoot the ballon and it reached the top then reduce the ballon skip by one.
User prompt
Now the targets are three types of ballons ( red , gree, and blue ) , they will randomly spawn from the bottom of the screen and with random speed they move from bottom to top.
User prompt
reduce the gravity little more.
User prompt
increase the shooting power of bow
User prompt
reduce the gravity little bit.
User prompt
Gravity is not working on the arrow after shoot. fix the issue.
User prompt
after click, stickman should be continue to rotate in the direction of the mouse pointer, untill released.
/**** 
* Classes
****/ 
//<Assets used in the game will automatically appear here>
// Arrow class
var Arrow = Container.expand(function () {
	var self = Container.call(this);
	var arrowGraphics = self.attachAsset('arrow', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.speed = 10;
	self.update = function () {
		// Apply physics
		self.speedY = (self.speedY || 0) + 0.2; // further reduced gravity
		self.y += Math.sin(self.rotation) * self.speed + self.speedY;
		self.x += Math.cos(self.rotation) * self.speed;
		// Check for collisions with balloons
		for (var i = 0; i < targets.length; i++) {
			if (self.intersects(targets[i])) {
				// Increase score
				score += 2;
				updateScore();
				// Destroy the balloon
				targets[i].destroy();
				targets.splice(i, 1);
			}
		}
	};
});
// Balloon class
var Balloon = Container.expand(function () {
	var self = Container.call(this);
	var balloonColors = ['redBalloon', 'greenBalloon', 'blueBalloon'];
	var randomColor = balloonColors[Math.floor(Math.random() * balloonColors.length)];
	var balloonGraphics = self.attachAsset(randomColor, {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.speed = Math.random() * 2 + 1;
	self.update = function () {
		self.y -= self.speed;
	};
});
// PowerUp class
var PowerUp = Container.expand(function () {
	var self = Container.call(this);
	var powerUpGraphics = self.attachAsset('powerUp', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.speed = Math.random() * 5 + 1;
	self.update = function () {
		self.y -= self.speed;
	};
});
// Stickman class
var Stickman = Container.expand(function () {
	var self = Container.call(this);
	var stickmanGraphics = self.attachAsset('stickman', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.update = function () {
		// Stickman can have some movement logic if needed
	};
});
// Target class
var Target = Container.expand(function () {
	var self = Container.call(this);
	var targetGraphics = self.attachAsset('target', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.update = function () {
		// Targets can have some movement logic if needed
	};
});
/**** 
* Initialize Game
****/ 
var game = new LK.Game({
	backgroundColor: 0x87CEEB // Sky blue background
});
/**** 
* Game Code
****/ 
var arrows = [];
var stickman = new Stickman();
stickman.x = 2048 / 2;
stickman.y = 2732 / 2;
game.addChild(stickman);
var targets = [];
var wave = 1;
var score = 0;
var scoreTxt = new Text2('0', {
	size: 150,
	fill: "#ffffff"
});
scoreTxt.anchor.set(0.5, 0);
LK.gui.top.addChild(scoreTxt);
var balloonSkips = 5;
var balloonSkipIcons = [];
for (var i = 0; i < balloonSkips; i++) {
	var balloonSkipIcon = LK.getAsset('balloonSkip', {
		anchorX: 0.0,
		anchorY: 0.0,
		x: i * 120,
		y: 0
	});
	balloonSkipIcons.push(balloonSkipIcon);
	LK.gui.topLeft.addChild(balloonSkipIcon);
}
// Create initial target
function createTarget() {
	var balloon = new Balloon();
	balloon.x = Math.random() * 2048;
	balloon.y = 2732;
	targets.push(balloon);
	game.addChild(balloon);
}
// Update score
function updateScore() {
	scoreTxt.setText(score);
}
// Handle shooting arrows
game.down = function (x, y, obj) {
	// Do nothing on mouse down
};
var isMouseDown = false;
game.down = function (x, y, obj) {
	isMouseDown = true;
};
game.up = function (x, y, obj) {
	if (isMouseDown) {
		var arrow = new Arrow();
		arrow.x = stickman.x;
		arrow.y = stickman.y;
		arrow.rotation = Math.atan2(stickman.y - y, stickman.x - x);
		// Rotate the stickman in the direction of the drag
		stickman.rotation = arrow.rotation;
		// Calculate the distance between the stickman and the point where the drag was released
		var distance = Math.sqrt(Math.pow(stickman.x - x, 2) + Math.pow(stickman.y - y, 2));
		// Use this distance to set the speed of the arrow
		arrow.speed = distance / 50;
		arrows.push(arrow);
		game.addChild(arrow);
		isMouseDown = false;
	}
};
game.move = function (x, y, obj) {
	if (isMouseDown) {
		// Rotate the stickman towards the mouse pointer
		stickman.rotation = Math.atan2(stickman.y - y, stickman.x - x);
	}
};
// Game update loop
game.update = function () {
	for (var i = arrows.length - 1; i >= 0; i--) {
		arrows[i].update();
		if (arrows[i].y < -50) {
			arrows[i].destroy();
			arrows.splice(i, 1);
		}
	}
	for (var j = targets.length - 1; j >= 0; j--) {
		targets[j].update();
		if (targets[j].y < -50) {
			targets[j].destroy();
			targets.splice(j, 1);
			balloonSkips--;
			if (balloonSkips >= 0) {
				balloonSkipIcons[balloonSkips].destroy();
				balloonSkipIcons.splice(balloonSkips, 1);
			}
			if (balloonSkips <= 0) {
				LK.showGameOver();
				LK.gui.center.addChild(new Text2('Final Score: ' + score, {
					size: 150,
					fill: "#ffffff"
				}));
			}
		} else {
			for (var k = arrows.length - 1; k >= 0; k--) {
				if (arrows[k].intersects(targets[j])) {
					score += 2;
					updateScore();
					targets[j].destroy();
					targets.splice(j, 1);
					arrows[k].destroy();
					arrows.splice(k, 1);
					if (score % 50 == 0) {
						wave++;
						var waveText = new Text2('Wave ' + wave, {
							size: 150,
							fill: "#ffffff"
						});
						waveText.anchor.set(0.5, 0.5);
						LK.gui.center.addChild(waveText);
						LK.setTimeout(function () {
							waveText.destroy();
						}, 2000);
					}
					for (var i = 0; i < wave; i++) {
						createTarget();
					}
					break;
				}
			}
		}
	}
	if (targets.length < wave) {
		createTarget();
		// Randomly spawn a power up
		if (Math.random() < 0.1) {
			var powerUp = new PowerUp();
			powerUp.x = Math.random() * 2048;
			powerUp.y = 2732;
			game.addChild(powerUp);
		}
	}
	// Handle power up collection
	for (var i = 0; i < game.children.length; i++) {
		if (game.children[i] instanceof PowerUp) {
			for (var k = arrows.length - 1; k >= 0; k--) {
				if (arrows[k].intersects(game.children[i])) {
					// Destroy all balloons
					for (var j = targets.length - 1; j >= 0; j--) {
						targets[j].destroy();
						targets.splice(j, 1);
					}
					// Destroy the power up
					game.children[i].destroy();
					// Destroy the arrow
					arrows[k].destroy();
					arrows.splice(k, 1);
					break;
				}
			}
		}
	}
};
// Initialize first target
createTarget(); ===================================================================
--- original.js
+++ change.js
@@ -190,9 +190,9 @@
 					targets[j].destroy();
 					targets.splice(j, 1);
 					arrows[k].destroy();
 					arrows.splice(k, 1);
-					if (score % 10 == 0) {
+					if (score % 50 == 0) {
 						wave++;
 						var waveText = new Text2('Wave ' + wave, {
 							size: 150,
 							fill: "#ffffff"
:quality(85)/https://cdn.frvr.ai/66b0b287027c988e7cd10ecc.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/66b0b297027c988e7cd10ed0.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/66b0b2a3027c988e7cd10ed3.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/66b0b31f027c988e7cd10edf.png%3F3) 
 Ballon Skiped. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/66b0b363027c988e7cd10ee2.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/66b0b3ad027c988e7cd10ef6.png%3F3) 
 Needle Shooting Stickman. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/66b0b8e4027c988e7cd10f22.png%3F3) 
 A clear blue sky with fluffy white clouds drifting lazily across.. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/66b0c1e0027c988e7cd10f67.png%3F3)