User prompt
самолеты противников слева и справа опускаются и поднимаются на рандомное расстояние через 3 секунды после начала мата
User prompt
самолеты противником опускаются и поднимаются на рандомное расстояние
User prompt
самолеты противников плано опускаются и поднимаются
User prompt
после 5 секунды самолеты противников добавляют движение по y координате на 10 пикселей
User prompt
после 5й секунды, самолеты противников начинают перемещаться вверх и вниз
Code edit (1 edits merged)
Please save this source code
User prompt
скорость пули 8
User prompt
пули вылетают от 10 до 170 градусов
Code edit (2 edits merged)
Please save this source code
User prompt
дубликат пуль вылетают от 90 до 180 градусов
Code edit (1 edits merged)
Please save this source code
User prompt
добавить дубликат пуль, но на расстоянии x = 500 y = 2590
User prompt
Please fix the bug: 'ReferenceError: bullets is not defined' in or related to this line: 'for (var j = 0; j < bullets.length; j++) {' Line Number: 212
User prompt
добавить новый массив пуль. новый массив пуль появляются на расстоянии x = 500 y = 2590 и вылетают в рандомную сторону от 90 до 180 градусов
User prompt
пули также появляются на расстоянии x = 500 y = 2590 и вылетают в рандомную сторону от 90 до 180 градусов
Code edit (1 edits merged)
Please save this source code
User prompt
исправить ошибку, когда bullet2 не отображается в центре экрана
User prompt
создать класс bullet 2 в центре экрана
User prompt
Создать объект bullet2 в центре экрана
User prompt
Добавить объект bullet2 в центре экрана
User prompt
Добавить объект bullet2 в центре экрана
Code edit (1 edits merged)
Please save this source code
User prompt
удалить bullet2
Code edit (1 edits merged)
Please save this source code
User prompt
добавить массив пуль2 аналогичный массив пуль
/**** 
* Classes
****/ 
var Bullet = Container.expand(function () {
	var self = Container.call(this);
	var bulletGraphics = self.attachAsset('bullet', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.speed = 8;
	self.visible = false;
	self.angle = Math.PI / 18 + Math.random() * (17 * Math.PI / 18); // Random angle between 10 and 170 degrees
	self.update = function () {
		if (LK.ticks > 240) {
			// 4 seconds at 60FPS
			self.visible = true;
			self.x += self.speed * Math.cos(self.angle);
			self.y -= self.speed * Math.sin(self.angle);
		}
	};
});
var Cannon = Container.expand(function () {
	var self = Container.call(this);
	var cannonGraphics = self.attachAsset('Cannon', {
		anchorX: 0.5,
		anchorY: 0.5
	});
});
// Cannon2 class
var Cannon2 = Container.expand(function () {
	var self = Container.call(this);
	var cannon2Graphics = self.attachAsset('Cannon2', {
		anchorX: 0.5,
		anchorY: 0.5
	});
});
// EnemyPlane class
var EnemyPlane = Container.expand(function () {
	var self = Container.call(this);
	var enemyPlaneGraphics = self.attachAsset('enemy', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.speedX = -6;
	self.speedY = 0;
	// Update enemy plane position
	self.update = function () {
		self.x += self.speedX;
		self.y -= self.speed;
	};
});
// EnemyPlaneLeft class
var EnemyPlaneLeft = Container.expand(function () {
	var self = Container.call(this);
	var enemyPlaneGraphics = self.attachAsset('Enemyleft', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.speedX = 6;
	self.speedY = 0;
	// Update enemy plane position
	self.update = function () {
		self.x += self.speedX;
		self.y += self.speedY;
	};
});
// Plane1 class
var Plane1 = Container.expand(function () {
	var self = Container.call(this);
	var planeGraphics = self.attachAsset('plane', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.speedX = 7;
	self.speedY = 0;
	// Update plane position
	self.update = function () {
		self.x += self.speedX;
		self.y += self.speedY;
		// Check if the plane has crossed the screen boundary
		if (self.x < 0) {
			self.x = 2048;
		} else if (self.x > 2048) {
			self.x = 0;
		}
		// Prevent the plane from crossing the floor and ceiling
		if (self.y < 0) {
			self.y = 0;
			self.speedY = 0;
		} else if (self.y > 2752 - self.height) {
			self.y = 2752 - self.height;
			self.speedY = 0;
		}
	};
});
/**** 
* Initialize Game
****/ 
// Assets are automatically created based on usage in the code.
var game = new LK.Game({
	backgroundColor: 0xffffff // Init game with white background
});
/**** 
* Game Code
****/ 
var background2 = game.attachAsset('background2', {
	anchorX: 0.5,
	anchorY: 0.5,
	scaleX: 1,
	scaleY: 1
});
background2.x = 2175 / 2;
background2.y = 2620 / 2;
// Add background to the bottom of the game
var background = game.attachAsset('background', {
	anchorX: 0,
	anchorY: 1,
	scaleX: 1,
	scaleY: 1
});
background.y = 2732;
var enemyPlanes = []; // Global array to keep track of enemy planes
var enemyPlane; // Global variable to keep track of the enemy plane
// Create a player plane
var plane1 = new Plane1();
plane1.x = 150; // Moved 50 units to the right
plane1.y = 2750 - plane1.height; // Bottom of the screen
game.addChild(plane1);
// Create a cannon
var cannon = new Cannon();
cannon.x = -100; // Position at the bottom left of the screen
cannon.y = 2660;
game.addChild(cannon);
// Create a cannon2
var cannon2 = new Cannon2();
cannon2.x = 2150; // Position at the bottom left of the screen
cannon2.y = 2660;
game.addChild(cannon2);
var bullets = []; // Initialize an array to manage multiple bullets
LK.setTimeout(function () {
	var bulletSpawnInterval = LK.setInterval(function () {
		var newBullet = new Bullet();
		newBullet.x = 175;
		newBullet.y = 2590;
		game.addChild(newBullet);
		bullets.push(newBullet);
		var newBulletDuplicate = new Bullet();
		newBulletDuplicate.x = 1882; // New x position
		newBulletDuplicate.y = 2590; // New y position, same as original
		game.addChild(newBulletDuplicate);
		bullets.push(newBulletDuplicate);
	}, 800); // Spawn a new bullet every second, starting from the fourth second
}, 18000);
// Create the rest of the enemy planes every 2 seconds for the first 7 seconds
var enemySpawnTimer = LK.setInterval(function () {
	enemyPlane = new EnemyPlane();
	enemyPlane.x = 2150;
	enemyPlane.y = 100 + Math.random() * (2732 - enemyPlane.height - 100); // Random y-coordinate between 100 and 2732 minus the height of the enemy plane
	game.addChild(enemyPlane);
	enemyPlanes.push(enemyPlane);
	var enemyPlaneLeft = new EnemyPlaneLeft();
	enemyPlaneLeft.x = -100;
	enemyPlaneLeft.y = 100 + Math.random() * (2732 - enemyPlaneLeft.height - 100); // Random y-coordinate between 100 and 2732 minus the height of the enemy plane
	game.addChild(enemyPlaneLeft);
	enemyPlanes.push(enemyPlaneLeft);
}, 1300);
// After 7 seconds, change the enemy spawn interval to 1 every 1.3 seconds
LK.setTimeout(function () {
	LK.clearInterval(enemySpawnTimer);
	enemySpawnTimer = LK.setInterval(function () {
		enemyPlane = new EnemyPlane();
		enemyPlane.x = 2150;
		enemyPlane.y = 100 + Math.random() * (2732 - enemyPlane.height - 100); // Random y-coordinate between 100 and 2732 minus the height of the enemy plane
		game.addChild(enemyPlane);
		enemyPlanes.push(enemyPlane);
		var enemyPlaneLeft = new EnemyPlaneLeft();
		enemyPlaneLeft.x = -100;
		enemyPlaneLeft.y = 100 + Math.random() * (2732 - enemyPlaneLeft.height - 100); // Random y-coordinate between 100 and 2732 minus the height of the enemy plane
		game.addChild(enemyPlaneLeft);
		enemyPlanes.push(enemyPlaneLeft);
	}, 1100);
}, 5000);
// After 14 seconds, change the enemy spawn interval to 1 every second and move them randomly up and down every 3 seconds
LK.setTimeout(function () {
	LK.clearInterval(enemySpawnTimer);
	enemySpawnTimer = LK.setInterval(function () {
		enemyPlane = new EnemyPlane();
		enemyPlane.x = 2150;
		enemyPlane.y = 100 + Math.random() * (2732 - enemyPlane.height - 100); // Random y-coordinate between 100 and 2732 minus the height of the enemy plane
		game.addChild(enemyPlane);
		enemyPlanes.push(enemyPlane);
		var enemyPlaneLeft = new EnemyPlaneLeft();
		enemyPlaneLeft.x = -100;
		enemyPlaneLeft.y = 100 + Math.random() * (2732 - enemyPlaneLeft.height - 100); // Random y-coordinate between 100 and 2732 minus the height of the enemy plane
		game.addChild(enemyPlaneLeft);
		enemyPlanes.push(enemyPlaneLeft);
	}, 900);
	// Move enemy planes up and down randomly every 3 seconds
	LK.setInterval(function () {
		enemyPlanes.forEach(function (plane) {
			var randomY = 100 + Math.random() * (2732 - plane.height - 100);
			plane.y = randomY;
		});
	}, 3000);
}, 11000);
// Set up game tick
LK.on('tick', function () {
	plane1.update();
	for (var j = 0; j < bullets.length; j++) {
		bullets[j].update();
	}
	for (var i = 0; i < enemyPlanes.length; i++) {
		enemyPlanes[i].update();
	}
});
// Flags to track if the screen is being touched
var isTouchingLeft = false;
var isTouchingRight = false;
// Change enemy direction when the screen is touched
var initialTouchPosition = null;
game.on('down', function (obj) {
	initialTouchPosition = obj.event.getLocalPosition(game);
});
game.on('move', function (obj) {
	if (initialTouchPosition) {
		var currentTouchPosition = obj.event.getLocalPosition(game);
		var swipeDirection = currentTouchPosition.x - initialTouchPosition.x;
		if (swipeDirection < 0) {
			isTouchingLeft = true;
			isTouchingRight = false;
		} else if (swipeDirection > 0) {
			isTouchingRight = true;
			isTouchingLeft = false;
		}
	}
});
// Stop changing enemy direction when the screen is no longer being touched
game.on('up', function (obj) {
	isTouchingLeft = false;
	isTouchingRight = false;
	initialTouchPosition = null;
});
// In the game tick, change plane direction while the screen is being touched
LK.on('tick', function () {
	if (isTouchingLeft) {
		var angle = Math.atan2(plane1.speedY, plane1.speedX);
		angle -= Math.PI / 60; // Subtract 1.5 degrees (in radians) for counter-clockwise rotation
		plane1.speedX = Math.cos(angle) * 7;
		plane1.speedY = Math.sin(angle) * 7;
		plane1.rotation -= Math.PI / 60; // Rotate the plane counter-clockwise
	}
	if (isTouchingRight && LK.ticks > 78) {
		var angle = Math.atan2(plane1.speedY, plane1.speedX);
		angle += Math.PI / 60; // Add 1.5 degrees (in radians) for clockwise rotation
		plane1.speedX = Math.cos(angle) * 7;
		plane1.speedY = Math.sin(angle) * 7;
		plane1.rotation += Math.PI / 60; // Rotate the plane clockwise
	}
	// Check if the plane crosses the side boundaries of the screen, touches the top or bottom of the screen, or collides with the health_bar
	if (plane1.x <= 70 || plane1.x >= 2170 - plane1.width || plane1.y <= 70 || plane1.y >= 2752 - plane1.height) {
		// Trigger game over
		LK.effects.flashScreen(0xff0000, 1000);
		LK.showGameOver();
	}
	// Check if the bullet touches the player within a 100x100 square area
	for (var j = 0; j < bullets.length; j++) {
		if (bullets[j].visible && Math.abs(bullets[j].x - plane1.x) <= 50 && Math.abs(bullets[j].y - plane1.y) <= 50) {
			// Trigger game over
			LK.effects.flashScreen(0xff0000, 1000);
			LK.showGameOver();
		}
	}
	// Check for collision between player and enemy planes
	for (var i = 0; i < enemyPlanes.length; i++) {
		if (plane1.x < enemyPlanes[i].x + 100 && plane1.x + 100 > enemyPlanes[i].x && plane1.y < enemyPlanes[i].y + 100 && plane1.y + 100 > enemyPlanes[i].y) {
			// Add a red flash screen effect
			LK.effects.flashScreen(0xff0000, 1000);
			// Trigger game over
			LK.showGameOver();
		}
	}
	// Delay the movement of the cannons by 4 seconds after the game starts
	LK.setTimeout(function () {
		if (cannon.x < 100) {
			cannon.x += 2;
		}
		if (cannon2.x > 1950) {
			cannon2.x -= 2;
		}
	}, 16000);
}); ===================================================================
--- original.js
+++ change.js
@@ -41,11 +41,9 @@
 		anchorX: 0.5,
 		anchorY: 0.5
 	});
 	self.speedX = -6;
-	// Randomly choose to move up or down, or stay in the same vertical position
-	var movementOptions = [-3, 0, 3];
-	self.speedY = movementOptions[Math.floor(Math.random() * movementOptions.length)];
+	self.speedY = 0;
 	// Update enemy plane position
 	self.update = function () {
 		self.x += self.speedX;
 		self.y -= self.speed;
@@ -58,11 +56,9 @@
 		anchorX: 0.5,
 		anchorY: 0.5
 	});
 	self.speedX = 6;
-	// Randomly choose to move up or down, or stay in the same vertical position
-	var movementOptions = [-3, 0, 3];
-	self.speedY = movementOptions[Math.floor(Math.random() * movementOptions.length)];
+	self.speedY = 0;
 	// Update enemy plane position
 	self.update = function () {
 		self.x += self.speedX;
 		self.y += self.speedY;
@@ -185,9 +181,9 @@
 		game.addChild(enemyPlaneLeft);
 		enemyPlanes.push(enemyPlaneLeft);
 	}, 1100);
 }, 5000);
-// After 14 seconds, change the enemy spawn interval to 1 every second
+// After 14 seconds, change the enemy spawn interval to 1 every second and move them randomly up and down every 3 seconds
 LK.setTimeout(function () {
 	LK.clearInterval(enemySpawnTimer);
 	enemySpawnTimer = LK.setInterval(function () {
 		enemyPlane = new EnemyPlane();
@@ -200,8 +196,15 @@
 		enemyPlaneLeft.y = 100 + Math.random() * (2732 - enemyPlaneLeft.height - 100); // Random y-coordinate between 100 and 2732 minus the height of the enemy plane
 		game.addChild(enemyPlaneLeft);
 		enemyPlanes.push(enemyPlaneLeft);
 	}, 900);
+	// Move enemy planes up and down randomly every 3 seconds
+	LK.setInterval(function () {
+		enemyPlanes.forEach(function (plane) {
+			var randomY = 100 + Math.random() * (2732 - plane.height - 100);
+			plane.y = randomY;
+		});
+	}, 3000);
 }, 11000);
 // Set up game tick
 LK.on('tick', function () {
 	plane1.update();
:quality(85)/https://cdn.frvr.ai/66000c0c9e8f228944f00ea8.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/66009c3c9e8f228944f00fe6.png%3F3) 
 снаряд от пушки. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6600a0cf9e8f228944f01072.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/6600a39a9e8f228944f0109b.png%3F3) 
 чистое голубое небо. задний фон. мультяшный. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6601649e28a7d159597f96f2.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/66055b99418bc75e5b9aad43.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/660951a495ca94ca0051665f.png%3F3) 
 Артиллерийское оружие, смотрит вверх. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/660b4443396ff09d7b91f5a7.png%3F3) 
 Нажатие по экрану. Палец. Мультяшный. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.