User prompt
eliminar el boton de reproduccion y en su lugar coloca el boton de play en medio de la pantalla arriba de el boton de play coloca la seleccion de personajes y añade una interfaz a la seleccion de personajes
User prompt
no se requiere eljir un personaje para empezar a jugar
User prompt
la musica suena despues de presionar al boton de play
User prompt
agrega un boton de play
User prompt
agrega nuevas instrucciones
User prompt
elimina las frases
User prompt
coloca un boton para empezar a jugar
User prompt
el sonido de muerte suena al haber perdido el sonido de victoria suena al ganar el juego la musica suena justo al empezar a jugar
User prompt
condicion de victoria sera de 10000
User prompt
el boton se mirara por encima de el suelo
User prompt
en la esquina inferior izquierda
User prompt
coloca un boton de disparo en la esquina inferior derecha de la pantalla
User prompt
el jugador va a tner el arma un poco mas arriba y recta mirando hacia enfrente
User prompt
el jugador va a tener el arma en la mano
User prompt
el arma el jugador la va a tener en todo momento
User prompt
un arma que tengan los jugadores
User prompt
agrega un objeto con el que el jugador pueda disparar a los enemigos y desaparecerlos agrega otro enemigo que este en el aire
User prompt
agrega otro personaje
User prompt
eliminar el bloque rompible
User prompt
la duracion de la invencibilidad de el bloque rompible sera de solo 5 segundos
User prompt
reduce la probabilidad de que aparezcan los potenciadores un poco mas
User prompt
puntuacion para la victoria 100,000
User prompt
un menos de posibilidad de que aparezcan los bloques rompibles
User prompt
los bloques rompibles estan en el aire y al romperlos te dan un potenciador de invencibilidad con una duracion de 5 segundos y mayor distancia entre obstaculos y enemigos ↪💡 Consider importing and using the following plugins: @upit/tween.v1
User prompt
mayor probabilidad de que aparezcan los bloques rompibles
/**** * Plugins ****/ var tween = LK.import("@upit/tween.v1"); var storage = LK.import("@upit/storage.v1"); /**** * Classes ****/ var Bullet = Container.expand(function () { var self = Container.call(this); var bulletGraphics = self.attachAsset('bullet', { anchorX: 0.5, anchorY: 0.5 }); self.speed = 15; self.update = function () { self.x += self.speed; }; return self; }); var Enemy = Container.expand(function () { var self = Container.call(this); var enemyGraphics = self.attachAsset('enemy', { anchorX: 0.5, anchorY: 1.0 }); self.speed = -8; self.update = function () { self.x += self.speed; }; return self; }); var FlyingEnemy = Container.expand(function () { var self = Container.call(this); var flyingEnemyGraphics = self.attachAsset('flyingEnemy', { anchorX: 0.5, anchorY: 0.5 }); self.speed = -10; self.update = function () { self.x += self.speed; }; return self; }); var GroundSegment = Container.expand(function () { var self = Container.call(this); var groundGraphics = self.attachAsset('ground', { anchorX: 0, anchorY: 0 }); self.speed = -8; self.update = function () { self.x += self.speed; }; return self; }); var Hole = Container.expand(function () { var self = Container.call(this); var holeGraphics = self.attachAsset('hole', { anchorX: 0, anchorY: 0 }); self.speed = -8; self.update = function () { self.x += self.speed; }; return self; }); var Obstacle = Container.expand(function () { var self = Container.call(this); var obstacleGraphics = self.attachAsset('obstacle', { anchorX: 0.5, anchorY: 1.0 }); self.speed = -8; self.update = function () { self.x += self.speed; }; return self; }); var Player = Container.expand(function () { var self = Container.call(this); var playerGraphics = self.attachAsset('player', { anchorX: 0.5, anchorY: 1.0 }); self.isJumping = false; self.jumpSpeed = 0; self.gravity = 0.8; self.jumpPower = -25; self.groundY = 0; self.customColor = 0x4CAF50; self.jumpCount = 0; self.maxJumps = 2; self.characterType = 'player'; self.isInvincible = false; self.invincibilityTimer = 0; self.hasWeapon = false; self.weaponGraphics = null; self.jump = function () { if (self.jumpCount < self.maxJumps) { if (!self.isJumping) { self.isJumping = true; } self.jumpSpeed = self.jumpPower; self.jumpCount++; LK.getSound('jump').play(); } }; self.setColor = function (color) { self.customColor = color; playerGraphics.tint = color; }; self.setCharacter = function (characterType) { self.characterType = characterType; playerGraphics.destroy(); playerGraphics = self.attachAsset(characterType, { anchorX: 0.5, anchorY: 1.0 }); }; self.activateInvincibility = function () { self.isInvincible = true; self.invincibilityTimer = 300; // 5 seconds at 60fps // Flash effect tween(playerGraphics, { alpha: 0.3 }, { duration: 200, easing: tween.easeInOut, onFinish: function onFinish() { if (self.isInvincible) { tween(playerGraphics, { alpha: 1 }, { duration: 200, easing: tween.easeInOut, onFinish: function onFinish() { if (self.isInvincible) { self.activateInvincibility(); } } }); } } }); }; self.pickupWeapon = function () { self.hasWeapon = true; // Create weapon graphics attached to player if (self.weaponGraphics) { self.weaponGraphics.destroy(); } self.weaponGraphics = self.attachAsset('weapon', { anchorX: 0.5, anchorY: 0.5 }); // Position weapon higher and straight in player's hand pointing forward self.weaponGraphics.x = 40; self.weaponGraphics.y = -200; self.weaponGraphics.scaleX = 3; self.weaponGraphics.scaleY = 3; self.weaponGraphics.rotation = 0; // Straight forward }; self.update = function () { if (self.isJumping) { self.jumpSpeed += self.gravity; self.y += self.jumpSpeed; var landingY = self.groundY; if (self.y >= landingY) { self.y = landingY; self.isJumping = false; self.jumpSpeed = 0; self.jumpCount = 0; } } // Handle invincibility timer if (self.isInvincible) { self.invincibilityTimer--; if (self.invincibilityTimer <= 0) { self.isInvincible = false; tween.stop(playerGraphics); playerGraphics.alpha = 1; } } }; return self; }); var Weapon = Container.expand(function () { var self = Container.call(this); var weaponGraphics = self.attachAsset('weapon', { anchorX: 0.5, anchorY: 0.5 }); self.speed = -8; self.update = function () { self.x += self.speed; self.y += Math.sin(LK.ticks * 0.1) * 2; // Floating animation }; return self; }); /**** * Initialize Game ****/ var game = new LK.Game({ backgroundColor: 0x87CEEB }); /**** * Game Code ****/ var gameState = 'ready'; // 'customization', 'ready', 'playing', 'gameOver' var selectedCharacter = 'player'; var player; var groundSegments = []; var holes = []; var enemies = []; var obstacles = []; var bullets = []; var flyingEnemies = []; var weapons = []; var gameSpeed = 8; var spawnTimer = 0; var shootTimer = 0; var distance = 0; var groundY = 2400; var invincibilitySpacing = 1; var lastInvincibilityTime = 0; // UI Elements var character1Button = LK.getAsset('player', { anchorX: 0.5, anchorY: 0.5 }); character1Button.x = 800; character1Button.y = 1200; character1Button.scaleX = 0.8; character1Button.scaleY = 0.8; character1Button.visible = true; var character2Button = LK.getAsset('player2', { anchorX: 0.5, anchorY: 0.5 }); character2Button.x = 1024; character2Button.y = 1200; character2Button.scaleX = 0.8; character2Button.scaleY = 0.8; character2Button.visible = true; var character3Button = LK.getAsset('player3', { anchorX: 0.5, anchorY: 0.5 }); character3Button.x = 1248; character3Button.y = 1200; character3Button.scaleX = 0.8; character3Button.scaleY = 0.8; character3Button.visible = true; var playButton = LK.getAsset('startButton', { anchorX: 0.5, anchorY: 0.5 }); playButton.x = 1024; playButton.y = 1600; playButton.scaleX = 1.5; playButton.scaleY = 1.5; playButton.visible = true; // Character selection border var selectionBorder = LK.getAsset('jumpButton', { anchorX: 0.5, anchorY: 0.5 }); selectionBorder.x = 1024; selectionBorder.y = 1200; selectionBorder.scaleX = 2.5; selectionBorder.scaleY = 2.5; selectionBorder.alpha = 0.3; selectionBorder.visible = true; var distanceText = new Text2('0m', { size: 60, fill: 0xFFFFFF }); distanceText.anchor.set(0.5, 0); LK.gui.top.addChild(distanceText); var fireButton = LK.getAsset('fireButton', { anchorX: 0.5, anchorY: 0.5 }); fireButton.x = 150; fireButton.y = 2200; game.addChild(fireButton); // Initialize player player = new Player(); player.x = 400; player.y = groundY; player.groundY = groundY; game.addChild(player); // Initialize ground segments for (var i = 0; i < 15; i++) { var ground = new GroundSegment(); ground.x = i * 200; ground.y = groundY; groundSegments.push(ground); game.addChild(ground); } function initializeGame() { gameState = 'playing'; distance = 0; gameSpeed = 8; spawnTimer = 0; // Hide character selection and play button character1Button.visible = false; character2Button.visible = false; character3Button.visible = false; selectionBorder.visible = false; playButton.visible = false; // Clear existing obstacles clearAllObstacles(); // Reset player position player.x = 400; player.y = groundY; player.isJumping = false; player.jumpSpeed = 0; player.jumpCount = 0; player.isInvincible = false; player.invincibilityTimer = 0; // Give player weapon at start player.pickupWeapon(); invincibilitySpacing = 1; lastInvincibilityTime = 0; // Reset ground segments for (var i = 0; i < groundSegments.length; i++) { groundSegments[i].x = i * 200; groundSegments[i].speed = -gameSpeed; } } function clearAllObstacles() { for (var i = holes.length - 1; i >= 0; i--) { holes[i].destroy(); holes.splice(i, 1); } for (var i = enemies.length - 1; i >= 0; i--) { enemies[i].destroy(); enemies.splice(i, 1); } for (var i = obstacles.length - 1; i >= 0; i--) { obstacles[i].destroy(); obstacles.splice(i, 1); } for (var i = bullets.length - 1; i >= 0; i--) { bullets[i].destroy(); bullets.splice(i, 1); } for (var i = flyingEnemies.length - 1; i >= 0; i--) { flyingEnemies[i].destroy(); flyingEnemies.splice(i, 1); } } function spawnObstacle() { var rand = Math.random(); var spawnX = 2200; if (rand < 0.15) { // Spawn hole var hole = new Hole(); hole.x = spawnX; hole.y = groundY; hole.speed = -gameSpeed; holes.push(hole); game.addChild(hole); } else if (rand < 0.25) { // Spawn enemy var enemy = new Enemy(); enemy.x = spawnX; enemy.y = groundY; enemy.speed = -gameSpeed; enemies.push(enemy); game.addChild(enemy); } else if (rand < 0.35) { // Spawn obstacle var obstacle = new Obstacle(); obstacle.x = spawnX; obstacle.y = groundY; obstacle.speed = -gameSpeed; obstacles.push(obstacle); game.addChild(obstacle); } else if (rand < 0.45) { // Spawn flying enemy var flyingEnemy = new FlyingEnemy(); flyingEnemy.x = spawnX; flyingEnemy.y = groundY - 300 - Math.random() * 200; flyingEnemy.speed = -gameSpeed; flyingEnemies.push(flyingEnemy); game.addChild(flyingEnemy); } } function checkCollisions() { // Check bullet vs enemy collisions for (var i = bullets.length - 1; i >= 0; i--) { var bullet = bullets[i]; var bulletHit = false; // Check bullet vs ground enemies for (var j = enemies.length - 1; j >= 0; j--) { var enemy = enemies[j]; if (bullet.intersects(enemy)) { // Remove bullet and enemy bullet.destroy(); bullets.splice(i, 1); enemy.destroy(); enemies.splice(j, 1); bulletHit = true; break; } } // Check bullet vs flying enemies if (!bulletHit) { for (var j = flyingEnemies.length - 1; j >= 0; j--) { var flyingEnemy = flyingEnemies[j]; if (bullet.intersects(flyingEnemy)) { // Remove bullet and flying enemy bullet.destroy(); bullets.splice(i, 1); flyingEnemy.destroy(); flyingEnemies.splice(j, 1); break; } } } } // Skip damage collisions if invincible if (!player.isInvincible) { // Check hole collisions for (var i = 0; i < holes.length; i++) { var hole = holes[i]; if (player.x > hole.x && player.x < hole.x + 150 && !player.isJumping) { gameOver(); return; } } // Check enemy collisions for (var i = 0; i < enemies.length; i++) { var enemy = enemies[i]; if (player.intersects(enemy)) { gameOver(); return; } } // Check flying enemy collisions for (var i = 0; i < flyingEnemies.length; i++) { var flyingEnemy = flyingEnemies[i]; if (player.intersects(flyingEnemy)) { gameOver(); return; } } // Check obstacle collisions for (var i = 0; i < obstacles.length; i++) { var obstacle = obstacles[i]; if (player.intersects(obstacle)) { gameOver(); return; } } } } function gameOver() { gameState = 'gameOver'; LK.getSound('hit').play(); LK.getSound('muerte').play(); LK.showGameOver(); } function updateSpeed() { gameSpeed = 8 + distance / 100; for (var i = 0; i < groundSegments.length; i++) { groundSegments[i].speed = -gameSpeed; } for (var i = 0; i < holes.length; i++) { holes[i].speed = -gameSpeed; } for (var i = 0; i < enemies.length; i++) { enemies[i].speed = -gameSpeed; } for (var i = 0; i < obstacles.length; i++) { obstacles[i].speed = -gameSpeed; } for (var i = 0; i < flyingEnemies.length; i++) { flyingEnemies[i].speed = -gameSpeed; } } game.down = function (x, y, obj) { if (gameState === 'ready') { // Check character selection clicks if (x > 720 && x < 880 && y > 1120 && y < 1280) { // Character 1 selected selectedCharacter = 'player'; selectionBorder.x = 800; player.setCharacter('player'); return; } else if (x > 944 && x < 1104 && y > 1120 && y < 1280) { // Character 2 selected selectedCharacter = 'player2'; selectionBorder.x = 1024; player.setCharacter('player2'); return; } else if (x > 1168 && x < 1328 && y > 1120 && y < 1280) { // Character 3 selected selectedCharacter = 'player3'; selectionBorder.x = 1248; player.setCharacter('player3'); return; } // Check play button click if (x > 774 && x < 1274 && y > 1350 && y < 1850) { LK.playMusic('musica'); initializeGame(); return; } } else if (gameState === 'playing') { // Check fire button click (bottom left corner) if (x > 90 && x < 210 && y > 2140 && y < 2260) { // Fire button pressed - shoot bullet if (shootTimer <= 0) { var bullet = new Bullet(); bullet.x = player.x + 50; bullet.y = player.y - 100; // Player always has weapon so bullets are always enhanced bullet.speed = 20; bullet.scaleX = 1.2; bullet.scaleY = 1.2; bullets.push(bullet); game.addChild(bullet); LK.getSound('shoot').play(); shootTimer = 5; // Fast shooting since player always has weapon } } else { // Regular screen tap - jump player.jump(); } } }; game.update = function () { if (gameState === 'playing') { distance += gameSpeed / 10; distanceText.setText(Math.floor(distance) + 'm'); // Update speed based on distance updateSpeed(); // Spawn obstacles spawnTimer++; var spawnRate = (120 - Math.min(distance / 15, 50)) * invincibilitySpacing; if (spawnTimer >= spawnRate) { spawnObstacle(); spawnTimer = 0; } // Reset invincibility spacing after effect wears off if (distance - lastInvincibilityTime > 300 && invincibilitySpacing > 1) { invincibilitySpacing = 1; } // Update ground segments - make continuous for (var i = 0; i < groundSegments.length; i++) { var ground = groundSegments[i]; if (ground.x < -200) { // Find the rightmost ground segment var maxX = -1000; for (var j = 0; j < groundSegments.length; j++) { if (groundSegments[j].x > maxX) { maxX = groundSegments[j].x; } } ground.x = maxX + 200; } } // Update and clean up holes for (var i = holes.length - 1; i >= 0; i--) { var hole = holes[i]; if (hole.x < -200) { hole.destroy(); holes.splice(i, 1); } } // Update and clean up enemies for (var i = enemies.length - 1; i >= 0; i--) { var enemy = enemies[i]; if (enemy.x < -100) { enemy.destroy(); enemies.splice(i, 1); } } // Update and clean up obstacles for (var i = obstacles.length - 1; i >= 0; i--) { var obstacle = obstacles[i]; if (obstacle.x < -100) { obstacle.destroy(); obstacles.splice(i, 1); } } // Update and clean up bullets for (var i = bullets.length - 1; i >= 0; i--) { var bullet = bullets[i]; if (bullet.x > 2200) { bullet.destroy(); bullets.splice(i, 1); } } // Update and clean up flying enemies for (var i = flyingEnemies.length - 1; i >= 0; i--) { var flyingEnemy = flyingEnemies[i]; if (flyingEnemy.x < -100) { flyingEnemy.destroy(); flyingEnemies.splice(i, 1); } } // Update shoot timer if (shootTimer > 0) { shootTimer--; } // Check collisions checkCollisions(); // Update score LK.setScore(Math.floor(distance)); // Check win condition if (distance >= 10000) { gameState = 'won'; LK.getSound('victoria').play(); LK.showYouWin(); return; } } }; // Show character selection and play button initially game.addChild(character1Button); game.addChild(character2Button); game.addChild(character3Button); game.addChild(selectionBorder); game.addChild(playButton); ;
===================================================================
--- original.js
+++ change.js
@@ -228,15 +228,55 @@
var groundY = 2400;
var invincibilitySpacing = 1;
var lastInvincibilityTime = 0;
// UI Elements
-var playButton = LK.getAsset('playButton', {
+var character1Button = LK.getAsset('player', {
anchorX: 0.5,
anchorY: 0.5
});
+character1Button.x = 800;
+character1Button.y = 1200;
+character1Button.scaleX = 0.8;
+character1Button.scaleY = 0.8;
+character1Button.visible = true;
+var character2Button = LK.getAsset('player2', {
+ anchorX: 0.5,
+ anchorY: 0.5
+});
+character2Button.x = 1024;
+character2Button.y = 1200;
+character2Button.scaleX = 0.8;
+character2Button.scaleY = 0.8;
+character2Button.visible = true;
+var character3Button = LK.getAsset('player3', {
+ anchorX: 0.5,
+ anchorY: 0.5
+});
+character3Button.x = 1248;
+character3Button.y = 1200;
+character3Button.scaleX = 0.8;
+character3Button.scaleY = 0.8;
+character3Button.visible = true;
+var playButton = LK.getAsset('startButton', {
+ anchorX: 0.5,
+ anchorY: 0.5
+});
playButton.x = 1024;
playButton.y = 1600;
+playButton.scaleX = 1.5;
+playButton.scaleY = 1.5;
playButton.visible = true;
+// Character selection border
+var selectionBorder = LK.getAsset('jumpButton', {
+ anchorX: 0.5,
+ anchorY: 0.5
+});
+selectionBorder.x = 1024;
+selectionBorder.y = 1200;
+selectionBorder.scaleX = 2.5;
+selectionBorder.scaleY = 2.5;
+selectionBorder.alpha = 0.3;
+selectionBorder.visible = true;
var distanceText = new Text2('0m', {
size: 60,
fill: 0xFFFFFF
});
@@ -267,9 +307,13 @@
gameState = 'playing';
distance = 0;
gameSpeed = 8;
spawnTimer = 0;
- // Hide play button
+ // Hide character selection and play button
+ character1Button.visible = false;
+ character2Button.visible = false;
+ character3Button.visible = false;
+ selectionBorder.visible = false;
playButton.visible = false;
// Clear existing obstacles
clearAllObstacles();
// Reset player position
@@ -443,10 +487,30 @@
}
}
game.down = function (x, y, obj) {
if (gameState === 'ready') {
+ // Check character selection clicks
+ if (x > 720 && x < 880 && y > 1120 && y < 1280) {
+ // Character 1 selected
+ selectedCharacter = 'player';
+ selectionBorder.x = 800;
+ player.setCharacter('player');
+ return;
+ } else if (x > 944 && x < 1104 && y > 1120 && y < 1280) {
+ // Character 2 selected
+ selectedCharacter = 'player2';
+ selectionBorder.x = 1024;
+ player.setCharacter('player2');
+ return;
+ } else if (x > 1168 && x < 1328 && y > 1120 && y < 1280) {
+ // Character 3 selected
+ selectedCharacter = 'player3';
+ selectionBorder.x = 1248;
+ player.setCharacter('player3');
+ return;
+ }
// Check play button click
- if (x > 874 && x < 1174 && y > 1450 && y < 1750) {
+ if (x > 774 && x < 1274 && y > 1350 && y < 1850) {
LK.playMusic('musica');
initializeGame();
return;
}
@@ -560,7 +624,11 @@
return;
}
}
};
-// Show play button initially
+// Show character selection and play button initially
+game.addChild(character1Button);
+game.addChild(character2Button);
+game.addChild(character3Button);
+game.addChild(selectionBorder);
game.addChild(playButton);
;
\ No newline at end of file
un agujero hecho con pixeles. In-Game asset. 2d. High contrast. No shadows
un mounstro grande hecho con pixeles con perspectiva de lado y mas aterrador In-Game asset. 2d. High contrast. No shadows
un suelo de pasto y tierra hecho con pixeles. In-Game asset. 2d. High contrast. No shadows
una pincho grande hecho con pixeles In-Game asset. 2d. High contrast. No shadows
una bala de pistola 9 milimetros hecha con pixeles con perspectiva lateral. In-Game asset. 2d. High contrast. No shadows
un mounstro con alas hecho con pixeles. In-Game asset. 2d. High contrast. No shadows
un puño agarrando un arma hecho con pixeles y de perspectiva lateral. In-Game asset. 2d. High contrast. No shadows
un boton rojo que en medio dice shot hecho con pixeles. In-Game asset. 2d. High contrast. No shadows
un boton cuadrado hecho con pixeles que dice play. In-Game asset. 2d. High contrast. No shadows
un hombre obrero hecho con pixeles de cuerpo completo sosteniendo un arma
un policia de cuerpo completo hecho con pixeles con persepectiva lateral apuntando con un arma I
un hombre de traje hecho con pixeles de cuerpo completo apuntando con un rifle de asalto m4
goku de dragon ball hecho con pixeles de cuepo completo con perspectiva lateral apuntando don un rifle de asalto m4 In-Game asset. 2d. High contrast. No shadows
homero simpson hecho con pixeles de cuerpo completo con perspectiva lateral apuntando con rifle de asalto m4 I
letras hechas con pixeles que dicen shot and jump las letras shot tendran un estilo medieval y tendran un color gris,las letras and color blanco con contorno negro y las letras jump de color amarillo con contorno naranja