/**** * Classes ****/ // The assets will be automatically created and loaded by the LK engine based on their usage in the code. // For this game, we will use a bird and pole shapes, and a background image for the forest. // Bird class to represent the player-controlled bird var Bird = Container.expand(function () { var self = Container.call(this); var birdGraphics = self.attachAsset('bird', { anchorX: 0.5, anchorY: 0.5 }); self.velocity = 0; self.gravity = 0.5; self.flapStrength = -8; // Update function to apply gravity and move the bird self.update = function () { self.velocity += self.gravity; self.y += self.velocity; }; // Function to make the bird flap self.flap = function () { self.velocity = self.flapStrength; }; }); // Pole class to represent the obstacles var Pole = Container.expand(function () { var self = Container.call(this); var poleGraphics = self.attachAsset('pole', { anchorX: 0.5, anchorY: 0.5 }); self.speed = -5; // Update function to move the pole self.update = function () { self.x += self.speed; }; }); /**** * Initialize Game ****/ var game = new LK.Game({ backgroundColor: 0x87CEEB // Set a sky blue background color }); /**** * Game Code ****/ // Add the background image to the game var background = game.attachAsset('background', { anchorX: 0.0, anchorY: 0.0, x: 0, y: 0 }); // Initialize game variables var bird = game.addChild(new Bird()); bird.x = 2048 / 4; bird.y = 2732 / 2; var poles = []; var score = 0; var scoreTxt = new Text2('0', { size: 150, fill: "#ffffff" }); scoreTxt.anchor.set(0.5, 0); LK.gui.top.addChild(scoreTxt); // Function to create a new pair of poles function createPoles() { var gap = 400; var poleHeight = Math.random() * 800 + 400; var topPole = new Pole(); topPole.x = 2048; topPole.y = poleHeight - 2732; poles.push(topPole); game.addChild(topPole); var bottomPole = new Pole(); bottomPole.x = 2048; bottomPole.y = poleHeight + gap; poles.push(bottomPole); game.addChild(bottomPole); } // Handle screen tap to make the bird flap game.down = function (x, y, obj) { bird.flap(); }; // Update game logic game.update = function () { bird.update(); // Check for collision with ground or ceiling if (bird.y > 2732 || bird.y < 0) { LK.showGameOver(); } // Update poles and check for collisions for (var i = poles.length - 1; i >= 0; i--) { poles[i].update(); // Check for collision with bird if (bird.intersects(poles[i])) { LK.showGameOver(); } // Remove poles that have moved off screen if (poles[i].x < -100) { poles[i].destroy(); poles.splice(i, 1); score++; scoreTxt.setText(score); } } // Create new poles periodically if (LK.ticks % 120 == 0) { createPoles(); } };
===================================================================
--- original.js
+++ change.js
@@ -1,107 +1,114 @@
-/****
+/****
* Classes
-****/
+****/
// The assets will be automatically created and loaded by the LK engine based on their usage in the code.
// For this game, we will use a bird and pole shapes, and a background image for the forest.
// Bird class to represent the player-controlled bird
var Bird = Container.expand(function () {
- var self = Container.call(this);
- var birdGraphics = self.attachAsset('bird', {
- anchorX: 0.5,
- anchorY: 0.5
- });
- self.velocity = 0;
- self.gravity = 0.5;
- self.flapStrength = -8;
- // Update function to apply gravity and move the bird
- self.update = function () {
- self.velocity += self.gravity;
- self.y += self.velocity;
- };
- // Function to make the bird flap
- self.flap = function () {
- self.velocity = self.flapStrength;
- };
+ var self = Container.call(this);
+ var birdGraphics = self.attachAsset('bird', {
+ anchorX: 0.5,
+ anchorY: 0.5
+ });
+ self.velocity = 0;
+ self.gravity = 0.5;
+ self.flapStrength = -8;
+ // Update function to apply gravity and move the bird
+ self.update = function () {
+ self.velocity += self.gravity;
+ self.y += self.velocity;
+ };
+ // Function to make the bird flap
+ self.flap = function () {
+ self.velocity = self.flapStrength;
+ };
});
// Pole class to represent the obstacles
var Pole = Container.expand(function () {
- var self = Container.call(this);
- var poleGraphics = self.attachAsset('pole', {
- anchorX: 0.5,
- anchorY: 0.5
- });
- self.speed = -5;
- // Update function to move the pole
- self.update = function () {
- self.x += self.speed;
- };
+ var self = Container.call(this);
+ var poleGraphics = self.attachAsset('pole', {
+ anchorX: 0.5,
+ anchorY: 0.5
+ });
+ self.speed = -5;
+ // Update function to move the pole
+ self.update = function () {
+ self.x += self.speed;
+ };
});
-/****
+/****
* Initialize Game
-****/
+****/
var game = new LK.Game({
- backgroundColor: 0x87CEEB // Set a sky blue background color
+ backgroundColor: 0x87CEEB // Set a sky blue background color
});
-/****
+/****
* Game Code
-****/
+****/
+// Add the background image to the game
+var background = game.attachAsset('background', {
+ anchorX: 0.0,
+ anchorY: 0.0,
+ x: 0,
+ y: 0
+});
// Initialize game variables
var bird = game.addChild(new Bird());
bird.x = 2048 / 4;
bird.y = 2732 / 2;
var poles = [];
var score = 0;
var scoreTxt = new Text2('0', {
- size: 150,
- fill: "#ffffff"
+ size: 150,
+ fill: "#ffffff"
});
scoreTxt.anchor.set(0.5, 0);
LK.gui.top.addChild(scoreTxt);
// Function to create a new pair of poles
function createPoles() {
- var gap = 400;
- var poleHeight = Math.random() * 800 + 400;
- var topPole = new Pole();
- topPole.x = 2048;
- topPole.y = poleHeight - 2732;
- poles.push(topPole);
- game.addChild(topPole);
- var bottomPole = new Pole();
- bottomPole.x = 2048;
- bottomPole.y = poleHeight + gap;
- poles.push(bottomPole);
- game.addChild(bottomPole);
+ var gap = 400;
+ var poleHeight = Math.random() * 800 + 400;
+ var topPole = new Pole();
+ topPole.x = 2048;
+ topPole.y = poleHeight - 2732;
+ poles.push(topPole);
+ game.addChild(topPole);
+ var bottomPole = new Pole();
+ bottomPole.x = 2048;
+ bottomPole.y = poleHeight + gap;
+ poles.push(bottomPole);
+ game.addChild(bottomPole);
}
// Handle screen tap to make the bird flap
game.down = function (x, y, obj) {
- bird.flap();
+ bird.flap();
};
// Update game logic
game.update = function () {
- bird.update();
- // Check for collision with ground or ceiling
- if (bird.y > 2732 || bird.y < 0) {
- LK.showGameOver();
- }
- // Update poles and check for collisions
- for (var i = poles.length - 1; i >= 0; i--) {
- poles[i].update();
- // Check for collision with bird
- if (bird.intersects(poles[i])) {
- LK.showGameOver();
- }
- // Remove poles that have moved off screen
- if (poles[i].x < -100) {
- poles[i].destroy();
- poles.splice(i, 1);
- score++;
- scoreTxt.setText(score);
- }
- }
- // Create new poles periodically
- if (LK.ticks % 120 == 0) {
- createPoles();
- }
+ bird.update();
+ // Check for collision with ground or ceiling
+ if (bird.y > 2732 || bird.y < 0) {
+ LK.showGameOver();
+ }
+ // Update poles and check for collisions
+ for (var i = poles.length - 1; i >= 0; i--) {
+ poles[i].update();
+ // Check for collision with bird
+ if (bird.intersects(poles[i])) {
+ LK.showGameOver();
+ }
+ // Remove poles that have moved off screen
+ if (poles[i].x < -100) {
+ poles[i].destroy();
+ poles.splice(i, 1);
+ score++;
+ scoreTxt.setText(score);
+ }
+ }
+ // Create new poles periodically
+ if (LK.ticks % 120 == 0) {
+ createPoles();
+ }
};
\ No newline at end of file