Code edit (1 edits merged)
Please save this source code
User prompt
Don't use tween for interpolating the movement of the dragon to left or right. Use just dragon.x and an increment
User prompt
Please fix the bug: 'Cannot read properties of undefined (reading 'lastX')' in or related to this line: 'if (dragon.lastX !== undefined && dragon.x !== dragon.lastX) {' Line Number: 105
User prompt
Please fix the bug: 'Cannot read properties of undefined (reading 'lastX')' in or related to this line: 'if (dragon.lastX !== undefined && dragon.x !== dragon.lastX) {' Line Number: 105
User prompt
Please fix the bug: 'Cannot read properties of undefined (reading 'lastX')' in or related to this line: 'if (dragon.lastX !== undefined && dragon.x !== dragon.lastX) {' Line Number: 105
User prompt
Please fix the bug: 'Cannot read properties of undefined (reading 'lastX')' in or related to this line: 'if (dragon.lastX !== undefined && dragon.x !== dragon.lastX) {' Line Number: 105
User prompt
Please fix the bug: 'Cannot read properties of undefined (reading 'lastX')' in or related to this line: 'if (dragon.lastX !== undefined && dragon.x !== dragon.lastX) {' Line Number: 105
User prompt
Please fix the bug: 'Cannot read properties of undefined (reading 'lastX')' in or related to this line: 'if (dragon.lastX !== undefined && dragon.x !== dragon.lastX) {' Line Number: 105
User prompt
I've just told you onUpdate does not exist for tween. Please find an alternative ↪💡 Consider importing and using the following plugins: @upit/tween.v1
User prompt
onUpdate does not exist for tween unfortunately. You may need to check cconstantly the dragon position and do tween.stop(dragon, x) or something like that. Figure it yourself. ↪💡 Consider importing and using the following plugins: @upit/tween.v1
User prompt
Ok. Now, as you calculate the trajectory of the dragon on the x, you may find that at some point in time the dragon intersects with a floor. In that case, you need to stop immediately the dragon movement to go any further that point.
Code edit (2 edits merged)
Please save this source code
User prompt
Ok change the movement of the dragon logic. This is what you need to do. First, register if a game.move event has happened. If so, check the x of the mouse cursor and interpolate the trajectory of the dragon from the dragon.x to the targetx in 0.5 sec.
User prompt
Please fix the bug: 'Cannot read properties of undefined (reading 'x')' in or related to this line: 'var targetX = dragon.x; // Initialize targetX with the dragon's current position' Line Number: 106
User prompt
It's not right. You are checking the game.move and only moving everytime there is game.move. No. You should registered a game.move has happened. Save the targetx. And move the dragon to targetx, some pixels at a time, during 0.5 sec
Code edit (1 edits merged)
Please save this source code
User prompt
Change a little the way you move the dragon. You are just setting the position to the mouse position on click, but you need to calculate the trajectory from the current X position of the dragon to the mouse X position and move the dragon one pixel at a time to the target destination
User prompt
Ok when you move the dragon to the left or to the right, it will follow the trajeectory from its current place to that final mouse pointer place. However, you need to make sure it never crosses a place that has a floor object, as they are box colliders / blocking obiects which should stop the dragon from continuing the trajectory.
User prompt
If two bubble intersect, destory the bubbles, show a poppedbubble for each of them and then remove them after 0.5 sec
User prompt
Please fix the bug: 'TypeError: Cannot read properties of undefined (reading 'y')' in or related to this line: 'bubble.lastY = bubble.y;' Line Number: 136
User prompt
Please fix the bug: 'TypeError: Cannot read properties of undefined (reading 'y')' in or related to this line: 'bubble.lastY = bubble.y;' Line Number: 136
User prompt
Please fix the bug: 'TypeError: Cannot read properties of undefined (reading 'y')' in or related to this line: 'bubble.lastY = bubble.y;' Line Number: 133
User prompt
Please fix the bug: 'TypeError: Cannot read properties of undefined (reading 'y')' in or related to this line: 'if (bubble.y < -50) {' Line Number: 128
User prompt
Please fix the bug: 'TypeError: Cannot read properties of undefined (reading 'update')' in or related to this line: 'bubble.update();' Line Number: 125
User prompt
Please fix the bug: 'TypeError: Cannot read properties of undefined (reading 'update')' in or related to this line: 'bubble.update();' Line Number: 125
/**** 
* Plugins
****/ 
var tween = LK.import("@upit/tween.v1");
/**** 
* Classes
****/ 
// Class for Bubbles
var Bubble = Container.expand(function () {
	var self = Container.call(this);
	var bubbleGraphics = self.attachAsset('bubble', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.speed = -5;
	self.update = function () {
		self.x += self.speed;
		// Check for intersection with any floor
		for (var i = 0; i < floors.length; i++) {
			if (self.intersects(floors[i])) {
				// Create a PoppedBubble at the bubble's position
				var pop = game.addChild(new PoppedBubble());
				pop.x = self.x;
				pop.y = self.y;
				// Destroy the bubble
				self.destroy();
				bubbles.splice(bubbles.indexOf(self), 1);
				// Destroy the PoppedBubble after 0.5 seconds
				LK.setTimeout(function () {
					pop.destroy();
				}, 500);
				break;
			}
		}
		// Update last known positions
		self.lastX = self.x;
		self.lastY = self.y;
	};
});
//<Assets used in the game will automatically appear here>
// Class for the Dragon character
var Dragon = Container.expand(function () {
	var self = Container.call(this);
	var dragonGraphics = self.attachAsset('dragon', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.isIntersectingBubble = false; // Add a variable to track if the dragon is intersecting a bubble
	self.shootBubble = function () {
		var bubble = game.addChild(new Bubble());
		bubble.x = self.x + 200 * self.scaleX;
		bubble.y = self.y + 10;
		// If the dragon is looking right, the bubble should move to the right
		if (self.scale.x == 1) {
			bubble.speed = 5;
		} else {
			// If the dragon is looking left, the bubble should move to the left
			bubble.speed = -5;
		}
		game.addChild(bubble);
		bubbles.push(bubble);
	};
});
// Class for Enemies
var Enemy = Container.expand(function () {
	var self = Container.call(this);
	var enemyGraphics = self.attachAsset('enemy', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.update = function () {
		// Enemy movement logic
	};
});
// Class for Pop
var PoppedBubble = Container.expand(function () {
	var self = Container.call(this);
	var popGraphics = self.attachAsset('poppedBubble', {
		anchorX: 0.5,
		anchorY: 0.5
	});
});
/**** 
* Initialize Game
****/ 
var game = new LK.Game({
	backgroundColor: 0x000000 //Init game with black background 
});
/**** 
* Game Code
****/ 
// Handle mouse move events to move the dragon
//<Assets used in the game will automatically appear here>
game.move = function (x, y, obj) {
	dragon.x = x;
	if (dragon.x > 1024) {
		dragon.scale.x = -1;
	} else {
		dragon.scale.x = 1;
	}
};
var dragon = game.addChild(new Dragon());
dragon.x = 1024; // Center horizontally
dragon.y = 2732 - 70 - dragon.height / 2; // Position the dragon on top of the floor
var bubbles = [];
var enemies = [];
var floors = [];
// Handle game updates
game.update = function () {
	// Update bubbles
	for (var i = bubbles.length - 1; i >= 0; i--) {
		var bubble = bubbles[i];
		if (bubble && typeof bubble.update === 'function') {
			bubble.update();
		}
		if (bubble.y < -50) {
			bubble.destroy();
			bubbles.splice(i, 1);
			continue;
		}
		// Check for bubble-bubble collisions
		for (var j = i - 1; j >= 0; j--) {
			var otherBubble = bubbles[j];
			if (bubble.intersects(otherBubble)) {
				// Create PoppedBubble for both bubbles
				var pop1 = game.addChild(new PoppedBubble());
				pop1.x = bubble.x;
				pop1.y = bubble.y;
				var pop2 = game.addChild(new PoppedBubble());
				pop2.x = otherBubble.x;
				pop2.y = otherBubble.y;
				// Destroy both bubbles
				bubble.destroy();
				otherBubble.destroy();
				bubbles.splice(i, 1);
				bubbles.splice(j, 1);
				// Destroy the PoppedBubbles after 0.5 seconds
				LK.setTimeout(function () {
					pop1.destroy();
					pop2.destroy();
				}, 500);
				break;
			}
		}
	}
	// Check for bubble-enemy collisions
	for (var i = enemies.length - 1; i >= 0; i--) {
		var enemy = enemies[i];
		for (var j = bubbles.length - 1; j >= 0; j--) {
			var bubble = bubbles[j];
			if (bubble.intersects(enemy)) {
				// Capture enemy
				enemy.destroy();
				enemies.splice(i, 1);
				bubble.destroy();
				bubbles.splice(j, 1);
				break;
			}
		}
	}
	// Check if the dragon is intersecting a bubble
	for (var i = 0; i < bubbles.length; i++) {
		if (dragon.intersects(bubbles[i])) {
			dragon.isIntersectingBubble = true;
			break;
		} else {
			dragon.isIntersectingBubble = false;
		}
	}
};
// Handle touch events for shooting bubbles
var lastShot = 0;
var lastClick = 0;
var isJumping = false; // Add a variable to track if the dragon is jumping
game.down = function (x, y, obj) {
	var now = Date.now();
	if (now - lastShot > 500) {
		dragon.shootBubble();
		lastShot = now;
	}
	if (now - lastClick < 200 && (!isJumping || dragon.isIntersectingBubble)) {
		// Only allow the dragon to jump if it is not already jumping or if it is intersecting a bubble
		isJumping = true; // Set isJumping to true when the dragon starts jumping
		// Make the dragon jump using a smooth animation
		tween(dragon, {
			y: dragon.y - 200
		}, {
			duration: 300,
			easing: tween.easeOut,
			onFinish: function onFinish() {
				// After the jump, make the dragon fall down until it intersects a floor
				var fallInterval = LK.setInterval(function () {
					dragon.y += 12; // Apply a downward speed
					for (var i = 0; i < floors.length; i++) {
						if (dragon.intersects(floors[i])) {
							isJumping = false; // Stop falling when intersecting a floor
							LK.clearInterval(fallInterval); // Clear the interval to stop the dragon from falling
							break;
						}
					}
				}, 16); // Run the interval at approximately 60 FPS
			}
		});
		// If the dragon is intersecting a bubble, show the pop asset before destroying the bubble
		if (dragon.isIntersectingBubble) {
			for (var i = 0; i < bubbles.length; i++) {
				if (dragon.intersects(bubbles[i])) {
					var pop = game.addChild(new PoppedBubble());
					pop.x = bubbles[i].x;
					pop.y = bubbles[i].y;
					bubbles[i].destroy();
					bubbles.splice(i, 1);
					LK.setTimeout(function () {
						pop.destroy();
					}, 500);
					break;
				}
			}
		}
	}
	lastClick = now;
};
// Add a floor to the bottom of the screen
for (var i = 0; i < 21; i++) {
	var floor = LK.getAsset('floor', {
		anchorX: 0.5,
		anchorY: 0.5,
		x: i * 100,
		y: 2732 - 30
	});
	game.addChild(floor);
	floors.push(floor);
}
// Add continuous floor on the left margin of the screen
for (var j = 0; j < 28; j++) {
	var leftFloor = LK.getAsset('floor', {
		anchorX: 0.5,
		anchorY: 0.5,
		x: 0,
		y: j * 100
	});
	game.addChild(leftFloor);
	floors.push(leftFloor);
}
// Add continuous floor on the right margin of the screen
for (var k = 0; k < 28; k++) {
	var rightFloor = LK.getAsset('floor', {
		anchorX: 0.5,
		anchorY: 0.5,
		x: 2048 - 50,
		y: k * 100
	});
	game.addChild(rightFloor);
	floors.push(rightFloor);
} ===================================================================
--- original.js
+++ change.js
@@ -112,9 +112,11 @@
 game.update = function () {
 	// Update bubbles
 	for (var i = bubbles.length - 1; i >= 0; i--) {
 		var bubble = bubbles[i];
-		bubble.update();
+		if (bubble && typeof bubble.update === 'function') {
+			bubble.update();
+		}
 		if (bubble.y < -50) {
 			bubble.destroy();
 			bubbles.splice(i, 1);
 			continue;
:quality(85)/https://cdn.frvr.ai/67a61cab5b0cdca0d4ccbe82.png%3F3) 
 A version of this bubble but exploded
:quality(85)/https://cdn.frvr.ai/67acc949bc1947d717737393.png%3F3) 
 brick, brown color, pixel style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/67acdd30bc1947d717737436.png%3F3) 
 better wings, pixel style, more contrasted, more visible, blue color
:quality(85)/https://cdn.frvr.ai/67b6596bcabb2b0ec1c98396.png%3F3) 
 a pixel clouds background. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/67b7abd93df41e8913428143.png%3F3) 
 a pixel clouds background, with mountains, full height full width Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/67b7acfe3df41e8913428166.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/67b7ae463df41e891342818d.png%3F3) 
 a similar image. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/67b7ae753df41e8913428195.png%3F3) 
 a pixel clouds background, with mountains, full height full width Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/680a872e33abcc7e69b34850.png%3F3) 
 A popped blue bobble, pixel style, bubble booble arcade game inspired. In-Game asset. 2d. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/680a884333abcc7e69b34865.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/680abe04b54cc7f0ed85d056.png%3F3) 
 A bubble popping, pixel style, retro. In-Game asset. 2d. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/680ac038b54cc7f0ed85d08f.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/680ac05cb54cc7f0ed85d095.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/680ac073b54cc7f0ed85d09b.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/680ac095b54cc7f0ed85d0ab.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/680ac0b0b54cc7f0ed85d0b1.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/680ac432690f1fa624b197d9.png%3F3)