Code edit (10 edits merged)
Please save this source code
User prompt
make alive kitty gostly movement faster
User prompt
hop should start from the center positon up
User prompt
kitty start position for jumping should be its original position
User prompt
kitty hop movement should go up and down up and down
User prompt
kitty hops should start from the kitty position and up
User prompt
move alive kitty 50 pixels above the shadow
User prompt
instead of ghostly movement if kitty is not dead it should hop up and down
User prompt
kitty hop soudl start 100 pixels up
User prompt
change kitty movement when isdead is false. instead of gostly it should hop up and down.
Code edit (1 edits merged)
Please save this source code
User prompt
if kitty.isdead = false, then hide deadkitty.
Code edit (1 edits merged)
Please save this source code
User prompt
axe should be behind all the layers
Code edit (3 edits merged)
Please save this source code
User prompt
remove image from layer4 asset
User prompt
move axes starting position 200 pixels down and right
User prompt
Fix Bug: 'TypeError: Cannot read properties of undefined (reading 'worldTransform')' in this line: 'var currentY = obj.event.getLocalPosition(self.parent).y;' Line Number: 145
User prompt
Fix Bug: 'TypeError: Cannot read properties of undefined (reading 'worldTransform')' in this line: 'var currentPos = obj.event.getLocalPosition(self.parent);' Line Number: 171
User prompt
move the axe anchor to 1 1
User prompt
axe should rotate only for 45 degrees and theyn go back to center and keep doing tht
User prompt
make axe rotate the other way
User prompt
Fix Bug: 'TypeError: Cannot read properties of undefined (reading 'worldTransform')' in this line: 'var currentY = obj.event.getLocalPosition(self.parent).y;' Line Number: 25
Code edit (3 edits merged)
Please save this source code
User prompt
Fix Bug: 'Uncaught TypeError: Cannot read properties of undefined (reading 'x')' in this line: 'redbutton.x = deadoralivemessage.x;' Line Number: 288
var Shadow = Container.expand(function () {
	var self = Container.call(this);
	var shadowGraphics = self.createAsset('shadow', 'Shadow Graphics', 0.5, 0.5);
});
var BoxPiece = Container.expand(function () {
	var self = Container.call(this);
	var boxPieceGraphics = self.createAsset('boxPiece', 'Box Piece Graphics', 0.5, 0.5);
	self.velocityX = (Math.random() - 0.5) * 10;
	self.velocityY = (Math.random() - 0.5) * 10;
	LK.on('tick', function () {
		self.x += self.velocityX;
		self.y += self.velocityY;
		self.rotation += 0.1;
	});
});
var Cap = Container.expand(function () {
	var self = Container.call(this);
	var capGraphics = self.createAsset('cap', 'Cap Graphics', 0.5, 0.5);
	var startY;
	var isSwipingUp = false;
	self.on('down', function (obj) {
		startY = obj.event.getLocalPosition(self.parent).y;
	});
	self.on('move', function (obj) {
		var currentY = self.parent ? obj.event.getLocalPosition(self.parent).y : 0;
		if (startY - currentY > 50) {
			isSwipingUp = true;
		}
	});
	self.on('up', function (obj) {
		if (isSwipingUp && self.parent) {
			console.log('Cap swiped up');
			self.emit('swipeUp');
			self.moveUp = true;
			self.rotateAndMoveUp = true;
			isSwipingUp = false;
		}
	});
	LK.on('tick', function () {
		if (self.rotateAndMoveUp) {
			self.y -= 10;
			self.x -= 10;
			self.rotation -= 0.05;
			if (self.y <= self.startY - 400) {
				self.rotateAndMoveUp = false;
			}
		}
	});
});
var RedButton = Container.expand(function () {
	var self = Container.call(this);
	var buttonGraphics = self.createAsset('redbutton', 'Red Button Graphics', 0.5, 0.5);
});
var AxeLayers = Container.expand(function () {
	var self = Container.call(this);
	var lastTapTime = 0;
	self.on('down', function (obj) {
		var currentTime = Date.now();
		var tapLength = currentTime - lastTapTime;
		if (tapLength < 500 && tapLength > 0) {
			if (self.children.length > 0) {
				self.removeChildAt(self.children.length - 1);
			}
			if (self.children.length === 0) {
				self.destroy();
			}
		}
		lastTapTime = currentTime;
	});
	var layer1 = self.createAsset('layer1', 'Axe Layer 1 Graphics', 0.5, 0.5);
	var layer2 = self.createAsset('layer2', 'Axe Layer 2 Graphics', 0.5, 0.5);
	var layer3 = self.createAsset('layer3', 'Axe Layer 3 Graphics', 0.5, 0.5);
	var layer4 = self.createAsset('layer4', 'Axe Layer 4 Graphics', 0.5, 0.5);
});
var Box = Container.expand(function () {
	var self = Container.call(this);
	self.spinAndShrink = function () {
		var frames = 60;
		var frameCounter = 0;
		var animationTick = function () {
			self.scale.x -= 1 / frames;
			self.scale.y -= 1 / frames;
			self.rotation += 0.1;
			frameCounter++;
			if (frameCounter >= frames) {
				LK.off('tick', animationTick);
				self.destroy();
			}
		};
		LK.on('tick', animationTick);
	};
	self.explode = function () {
		for (var i = 0; i < 20; i++) {
			var piece = new BoxPiece();
			piece.x = self.x;
			piece.y = self.y;
			if (self.parent) {
				self.parent.addChild(piece);
			}
		}
		self.destroy();
	};
	LK.on('tick', function () {
		if (self.velocityY !== 0) {
			self.y += self.velocityY;
		}
	});
	self.velocityY = 0;
	var boxGraphics = self.createAsset('box', 'Box Graphics', 0.5, 0.5);
	self.enlargeBox = function () {
		var frames = 0;
		var animationTick = function () {
			self.scale.x += 0.01;
			self.scale.y += 0.01;
			frames++;
			if (self.width >= LK.stage.width || self.height >= LK.stage.height) {
				LK.off('tick', animationTick);
				self.destroy();
			}
		};
		LK.on('tick', animationTick);
	};
	var lastTapTime = 0;
	var tapCount = 0;
	self.isDoubleClicked = false;
	var startY;
	var isSwipingUp = false;
	self.on('down', function (obj) {
		var currentTime = Date.now();
		if (currentTime - lastTapTime < 300) {
			tapCount++;
			if (tapCount === 2) {
				console.log('Box double clicked');
				self.isDoubleClicked = true;
				tapCount = 0;
			}
		} else {
			tapCount = 1;
		}
		lastTapTime = currentTime;
		this.startPos = obj.event.getLocalPosition(self.parent);
		startY = this.startPos.y;
	});
	self.on('move', function (obj) {
		var currentY = obj.event.getLocalPosition(self.parent).y;
		if (startY - currentY > 50) {
			isSwipingUp = true;
		}
	});
	self.on('up', function (obj) {
		if (isSwipingUp) {
			console.log('Box swiped up');
			self.emit('swipeUp');
			self.velocityY = -30;
			isSwipingUp = false;
		}
	});
});
var Axe = Container.expand(function () {
	var self = Container.call(this);
	var axeGraphics = self.createAsset('axe', 'Axe Graphics', 1, 1);
	self.rotationSpeed = 0.05;
	var dragNode = null;
	var startDragPos = null;
	self.on('down', function (obj) {
		dragNode = self;
		startDragPos = obj.event.getLocalPosition(self.parent);
	});
	self.on('move', function (obj) {
		if (dragNode) {
			var currentPos = self.parent ? obj.event.getLocalPosition(self.parent) : {
				x: 0,
				y: 0
			};
			dragNode.x = currentPos.x - axeGraphics.width / 2;
			dragNode.y = currentPos.y - axeGraphics.height / 2;
		}
	});
	self.on('up', function (obj) {
		dragNode = null;
	});
	var maxRotation = Math.PI / 4;
	var rotationDirection = 1;
	LK.on('tick', function () {
		self.rotation += rotationDirection * self.rotationSpeed;
		if (Math.abs(self.rotation) >= maxRotation) {
			rotationDirection *= -1;
		}
	});
});
var DeadoraliveMessage = Container.expand(function () {
	var self = Container.call(this);
	var messageGraphics = self.createAsset('deadoralive', 'Deadoralive Graphics', 0.5, 0.5);
	var startY;
	var targetY;
	var isSwiping = false;
	self.on('down', function (obj) {
		startY = obj.event.getLocalPosition(self.parent).y;
		targetY = self.y - 300;
	});
	self.on('move', function (obj) {
		var currentY = obj.event.getLocalPosition(LK.stageContainer).y;
		if (startY - currentY > 20) {
			isSwiping = true;
		}
	});
	self.on('up', function (obj) {
		if (isSwiping) {
			LK.on('tick', function () {
				if (self.y > targetY) {
					self.y -= 5;
					if (self.y < targetY) {
						self.y = targetY;
						LK.off('tick');
					}
				}
			});
		}
		isSwiping = false;
	});
});
var DeadMessage = Container.expand(function () {
	var self = Container.call(this);
	var messageGraphics = self.createAsset('deadmessage', 'Dead Graphics', 0.5, 0.5);
});
var AliveMessage = Container.expand(function () {
	var self = Container.call(this);
	var messageGraphics = self.createAsset('alivemessage', 'Alive Graphics', 0.5, 0.5);
});
var Kitty = Container.expand(function () {
	var self = Container.call(this);
	self.isDead = false;
	self.alpha = 1;
	var ghostlyMovement = function () {
		self.y += Math.sin(LK.ticks / 10) * 1;
	};
	LK.on('tick', ghostlyMovement);
	var deadkitty = self.createAsset('dead', 'Dead Kitty Graphics', 0.5, 0.5);
	var kitty = self.createAsset('alive', 'Kitty Graphics', 0.5, 0.5);
});
var DeadKitty = Container.expand(function () {
	var self = Container.call(this);
	self.alpha = 0.5;
	var ghostlyMovement = function () {
		self.y += Math.sin(LK.ticks / 10) * 0.5;
	};
	LK.on('tick', ghostlyMovement);
	var deadkitty = self.createAsset('dead', 'Dead Kitty Graphics', 0.5, 0.5);
});
var Lid = Container.expand(function () {
	var self = Container.call(this);
	var lidGraphics = self.createAsset('lid', 'Lid Graphics', 0.5, 0.5);
	var dragNode = null;
	var startDragPos = null;
	self.on('down', function (obj) {
		dragNode = self;
		startDragPos = obj.event.getLocalPosition(self.parent);
	});
	self.on('move', function (obj) {
		if (dragNode) {
			if (self.parent) {
				var currentPos = obj.event.getLocalPosition(self.parent);
				dragNode.x = currentPos.x - lidGraphics.width / 2;
				dragNode.y = currentPos.y - lidGraphics.height / 2;
			}
		}
	});
	self.on('up', function (obj) {
		dragNode = null;
	});
});
var Game = Container.expand(function () {
	var self = Container.call(this);
	var messageText = new Text2('(Open the box)', {
		size: 40,
		fill: '#ffffff'
	});
	messageText.anchor.set(.5, .5);
	messageText.y += 1600;
	LK.gui.topCenter.addChild(messageText);
	var kitty = self.addChild(new Kitty());
	self.isDead = Math.random() < 0.5;
	kitty.x = LK.stage.width / 2;
	kitty.y = LK.stage.height / 2;
	var shadow = self.addChild(new Shadow());
	shadow.x = kitty.x;
	shadow.y = kitty.y + 200;
	var deadkitty = self.addChild(new DeadKitty());
	deadkitty.x = LK.stage.width / 2;
	deadkitty.y = LK.stage.height / 2;
	var cap = self.addChild(new Cap());
	cap.x = 300;
	cap.y = 2400;
	var lid = self.addChild(new Lid());
	lid.x = cap.x;
	lid.y = cap.y;
	var redbutton = self.addChild(new RedButton());
	redbutton.x = LK.stage.width / 2;
	redbutton.y = 600;
	redbutton.on('down', function () {
		redbutton.isTouched = true;
	});
	var deadoralivemessage = self.addChild(new DeadoraliveMessage());
	deadoralivemessage.x = LK.stage.width / 2;
	deadoralivemessage.y = 600;
	var deadMessage = self.addChild(new DeadMessage());
	deadMessage.x = LK.stage.width / 2;
	deadMessage.y = LK.stage.height - 700 - deadMessage.height / 2;
	deadMessage.visible = false;
	var aliveMessage = self.addChild(new AliveMessage());
	aliveMessage.x = LK.stage.width / 2;
	aliveMessage.y = LK.stage.height - 700 - aliveMessage.height / 2;
	aliveMessage.visible = false;
	var box = self.addChild(new Box());
	box.x = LK.stage.width / 2;
	box.y = LK.stage.height / 2;
	var axe = self.addChild(new Axe());
	var axeLayers = self.addChild(new AxeLayers());
	axeLayers.x = axe.x = LK.stage.width - axe.width / 2 - 100;
	axeLayers.y = axe.y = LK.stage.height - axe.height / 2 - 100;
	axeLayers.zIndex = axe.zIndex + 1;
	if (self.isDead) {
		kitty.visible = false;
	} else {
		deadkitty.visible = false;
	}
	LK.on('tick', function () {
		if (redbutton.isTouched) {
			messageText.setText('(BOOOM! Nice one...still more to find...)');
			if (box) {
				box.enlargeBox();
				box = null;
				LK.setTimeout(function () {
					if (self.isDead) {
						deadMessage.visible = true;
					} else {
						aliveMessage.visible = true;
					}
				}, 3000);
				LK.setTimeout(function () {
					LK.showGameOver();
				}, 7000);
			}
			redbutton.isTouched = false;
		}
		if (axe.intersects(box)) {
			messageText.setText('(Chop chop! Is there any other way left?)');
			box.explode();
			if (self.isDead) {
				deadMessage.visible = true;
			} else {
				aliveMessage.visible = true;
			}
			LK.setTimeout(function () {
				LK.showGameOver();
			}, 5000);
		}
		if (box && box.isDoubleClicked) {
			messageText.setText('(Double clicked...how original! You can do better...)');
			LK.setTimeout(function () {
				LK.showGameOver();
			}, 5000);
			box.destroy();
			box = null;
			if (self.isDead) {
				deadMessage.visible = true;
			} else {
				aliveMessage.visible = true;
			}
		}
		if (box && cap.x < 1) {
			box.spinAndShrink();
			messageText.setText('(Down the drain it goes! I bet you can find another way...)');
			box = null;
			if (self.isDead) {
				deadMessage.visible = true;
			} else {
				aliveMessage.visible = true;
			}
			LK.setTimeout(function () {
				LK.showGameOver();
			}, 5000);
		}
		if (box && (box.y + box.height < 0 || box.y > LK.stage.height || cap.y + cap.height < 0 || cap.y > LK.stage.height || cap.x < 1)) {
			messageText.setText('(Swipe up, classic...Any other ideas?)');
			box = null;
			if (self.isDead) {
				deadMessage.visible = true;
			} else {
				aliveMessage.visible = true;
			}
			LK.setTimeout(function () {
				LK.showGameOver();
			}, 5000);
		}
	});
});
 ===================================================================
--- original.js
+++ change.js
@@ -257,11 +257,13 @@
 		startDragPos = obj.event.getLocalPosition(self.parent);
 	});
 	self.on('move', function (obj) {
 		if (dragNode) {
-			var currentPos = obj.event.getLocalPosition(self.parent);
-			dragNode.x = currentPos.x - lidGraphics.width / 2;
-			dragNode.y = currentPos.y - lidGraphics.height / 2;
+			if (self.parent) {
+				var currentPos = obj.event.getLocalPosition(self.parent);
+				dragNode.x = currentPos.x - lidGraphics.width / 2;
+				dragNode.y = currentPos.y - lidGraphics.height / 2;
+			}
 		}
 	});
 	self.on('up', function (obj) {
 		dragNode = null;
:quality(85)/https://cdn.frvr.ai/658b2869882b7a9800c9c0a2.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658b44cf8af59fdd6a28a108.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658b52b88af59fdd6a28a1b0.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658b52c68af59fdd6a28a1b3.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658b52d18af59fdd6a28a1b6.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658b52db8af59fdd6a28a1b9.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658b5ed28af59fdd6a28a20e.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658b5ee78af59fdd6a28a211.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658bf7bfe482b6aad66f9935.png%3F3) 
 8-bit. cartoon. red button. do not touch! Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/658c0058e482b6aad66f9971.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658c1221e482b6aad66f99e2.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658c122ae482b6aad66f99e5.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/658ffcf372d5ea3d9b52ea3a.png%3F3) 
 8-bit. cartoon. black tub stopper with chain. in game asset.. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6590266272d5ea3d9b52ea60.png%3F3) 
 8-bit. cartoon. axe. in game asset. no shadow.. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/65904e659802d1b888c1e492.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/659051b59802d1b888c1e4d1.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/6590576a9802d1b888c1e574.png%3F3) 
 Break in case of emergency square. Ax drawing inside. simple. 8-bit. cartoon. blackand white.. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/65906afc9802d1b888c1e5f2.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/65906b899802d1b888c1e5f7.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/65914e3aec42d46d1580df13.png%3F3) 
 Delete
:quality(85)/https://cdn.frvr.ai/65915613ec42d46d1580e089.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/6591cfbfa0750c7c9b32eabe.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/6591cfd1a0750c7c9b32eac1.png%3F3)