User prompt
Add a parameter fishType to Fish class, store it and use it for the asset : 1 => fish1, 2=>fish2,…
User prompt
Play crunch sound when eat a fish
User prompt
Ok so they are similar…add a new similar class named “Fish”
Code edit (1 edits merged)
Please save this source code
User prompt
Add a global nbFishTypes = 5
User prompt
Now use checkCollision instead of intersects
User prompt
In checkCollision, assume objects have x and y and a circle collisionBody with relative x and y. Return true if circles collide
User prompt
Create a new empty checkCollision function that takes two objects
User prompt
Place collisionBody of fishes at x: -0.25*fish.width
User prompt
CollisionBody are circles, use self.fish.width * 0.5 for both width and height
User prompt
Fix fishGraphics to self.fish
User prompt
In Fishes classes, change var fishGraphics to a public property fish
User prompt
Now add a collisionBody to fishes
User prompt
There is fish1 and fish2, now add fish3
Code edit (6 edits merged)
Please save this source code
User prompt
Use a different lastCollisionCheckTime global for updateFish1Collisions and updateFish2Collisions
User prompt
Use an offset in updateFish2Collisions too
User prompt
In updateFish1Collisions offset should depend on baby shark’s .shark.width
Code edit (1 edits merged)
Please save this source code
User prompt
Use collisionBody for collisions check
User prompt
Optimize updateFish2Collisions
Code edit (1 edits merged)
Please save this source code
User prompt
In baby shark update, write self.y and self.shark.height in debug txt
User prompt
Add a new text2 : debugTxt at center bottom for debugging
Code edit (1 edits merged)
Please save this source code
/**** 
* Classes
****/ 
//<Assets used in the game will automatically appear here>
// Baby Shark class
var BabyShark = Container.expand(function () {
	var self = Container.call(this);
	self.currentWidth = 200; // Initialize currentSize property
	self.heightRatio = 124.0 / 200; // Define height ratio property
	self.speed = 10;
	self.velocityY = 0;
	self.shark = self.attachAsset('babyShark', {
		anchorX: 0.5,
		anchorY: 0.5,
		width: self.currentWidth,
		height: self.currentWidth * self.heightRatio
	});
	self.collisionBody = self.attachAsset('collisionBody', {
		anchorX: 0.5,
		anchorY: 0.5,
		alpha: 0.7,
		x: self.currentWidth * 0.25,
		y: 10,
		width: self.shark.width * 0.5,
		height: self.shark.width * 0.5
	});
	self.update = function () {
		self.velocityY += 0.4; // Further reduced gravity effect
		self.y += self.velocityY;
		if (self.y >= 2732 - self.shark.height * 0.5) {
			self.y = 2732 - self.shark.height * 0.5;
			self.velocityY = 0;
		}
		if (self.y <= self.shark.height * 0.5) {
			self.y = self.shark.height * 0.5;
			self.velocityY = 0;
		}
		// Update logic for Baby Shark
		if (isDebug) {
			debugTxt.setText("Y: ".concat(self.y.toFixed(0), ", Height: ").concat(self.shark.height));
		}
	};
	self.grow = function () {
		self.currentWidth += 50;
		self.shark.width = self.currentWidth;
		self.shark.height = self.currentWidth * self.heightRatio;
		//self.collisionBody.width = self.height / 2;
		//self.collisionBody.height = self.height / 2;
		self.collisionBody.width = self.currentWidth * 0.45;
		self.collisionBody.height = self.currentWidth * 0.45;
		self.collisionBody.x = self.shark.width * 0.25;
		self.collisionBody.y = self.height * 0.05;
	};
});
// Fish class
var Fish = Container.expand(function (fishType) {
	var self = Container.call(this);
	self.fishType = fishType;
	self.fish = self.attachAsset('fish' + fishType, {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.collisionBody = self.attachAsset('collisionBody', {
		anchorX: 0.5,
		anchorY: 0.5,
		alpha: 0.7,
		x: -self.fish.width * 0.25,
		width: self.fish.width * 0.5,
		height: self.fish.width * 0.5
	});
	self.speed = 5;
	self.update = function () {
		self.x -= self.speed;
		if (self.x < -self.width) {
			self.destroy();
		}
	};
});
// Fish1 class
var Fish1 = Container.expand(function () {
	var self = Container.call(this);
	self.fish = self.attachAsset('fish1', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.collisionBody = self.attachAsset('collisionBody', {
		anchorX: 0.5,
		anchorY: 0.5,
		alpha: 0.7,
		x: -self.fish.width * 0.25,
		width: self.fish.width * 0.5,
		height: self.fish.width * 0.5
	});
	self.speed = 5;
	self.collided = false;
	self.update = function () {
		self.x -= self.speed;
		if (self.x < -self.width) {
			self.destroy();
		}
	};
});
// Fish2 class
var Fish2 = Container.expand(function () {
	var self = Container.call(this);
	self.fish = self.attachAsset('fish2', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.collisionBody = self.attachAsset('collisionBody', {
		anchorX: 0.5,
		anchorY: 0.5,
		alpha: 0.7,
		x: -self.fish.width * 0.25,
		width: self.fish.width * 0.5,
		height: self.fish.width * 0.5
	});
	self.speed = 5;
	self.update = function () {
		self.x -= self.speed;
		if (self.x < -self.width) {
			self.destroy();
		}
	};
});
// Fish3 class
var Fish3 = Container.expand(function () {
	var self = Container.call(this);
	self.fish = self.attachAsset('fish3', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.collisionBody = self.attachAsset('collisionBody', {
		anchorX: 0.5,
		anchorY: 0.5,
		alpha: 0.7,
		x: -self.fish.width * 0.25,
		width: self.fish.width * 0.5,
		height: self.fish.width * 0.5
	});
	self.speed = 5;
	self.update = function () {
		self.x -= self.speed;
		if (self.x < -self.width) {
			self.destroy();
		}
	};
});
/**** 
* Initialize Game
****/ 
var game = new LK.Game({
	backgroundColor: 0x0000ff // Init game with blue background
});
/**** 
* Game Code
****/ 
var nbFishTypes = 6;
function checkCollision(obj1, obj2) {
	// Calculate the center positions of the collision bodies
	var obj1CenterX = obj1.x + obj1.collisionBody.x;
	var obj1CenterY = obj1.y + obj1.collisionBody.y;
	var obj2CenterX = obj2.x + obj2.collisionBody.x;
	var obj2CenterY = obj2.y + obj2.collisionBody.y;
	// Calculate the distance between the centers
	var dx = obj1CenterX - obj2CenterX;
	var dy = obj1CenterY - obj2CenterY;
	var distance = Math.sqrt(dx * dx + dy * dy);
	// Calculate the sum of the radii
	var obj1Radius = obj1.collisionBody.width / 2;
	var obj2Radius = obj2.collisionBody.width / 2;
	var sumRadii = obj1Radius + obj2Radius;
	// Return true if the distance is less than the sum of the radii
	return distance < sumRadii;
}
function updateFish3Collisions() {
	var currentTime = Date.now();
	if (currentTime - lastCollisionCheckTimeFish3 < collisionCheckDelay) {
		return;
	}
	lastCollisionCheckTimeFish3 = currentTime;
	var offset = babyShark.shark.width * 1.5; // Define the x offset range based on baby shark's width
	for (var k = fish3s.length - 1; k >= 0; k--) {
		if (Math.abs(babyShark.x - fish3s[k].x) > offset) {
			continue; // Skip fishes outside the x offset range
		}
		if (checkCollision(babyShark, fish3s[k])) {
			// Play crunch sound
			LK.getSound('crunch').play();
			if (fish3s[k].x - fish3s[k].width / 3 < babyShark.x) {
				// Bounce baby shark off the bigger fish
				babyShark.velocityY = -10;
			} else {
				// Lose a life
				LK.effects.flashScreen(0xff0000, 1000);
				LK.showGameOver();
			}
		}
	}
}
function spawnFish3() {
	var fish3 = new Fish3();
	fish3.x = 2048 + 50;
	fish3.y = Math.random() * (2732 - fish3.height) + fish3.height / 2;
	fish3s.push(fish3);
	game.addChild(fish3);
}
var isDebug = true; // Global variable for debugging mode
var sharkLevel = 1;
var currentProgress = 0;
var lastCollisionCheckTimeFish1 = 0; // Global variable to track the last collision check time for Fish1
var lastCollisionCheckTimeFish2 = 0; // Global variable to track the last collision check time for Fish2
var collisionCheckDelay = 128; // Global variable for collision check delay in milliseconds
var lastCollisionCheckTimeFish3 = 0; // Global variable to track the last collision check time for Fish3
var fish3s = []; // Array to store Fish3 instances
function spawnFish() {
	if (LK.ticks % 60 == 0) {
		spawnSmallFish();
	}
	if (LK.ticks % 300 == 0) {
		spawnFish3();
	}
	if (LK.ticks % 180 == 0) {
		spawnFish2();
	}
}
function updateFish2Collisions() {
	var currentTime = Date.now();
	if (currentTime - lastCollisionCheckTimeFish2 < collisionCheckDelay) {
		return;
	}
	lastCollisionCheckTimeFish2 = currentTime;
	var offset = babyShark.shark.width * 1.5; // Define the x offset range based on baby shark's width
	for (var j = fish2s.length - 1; j >= 0; j--) {
		if (Math.abs(babyShark.x - fish2s[j].x) > offset) {
			continue; // Skip fishes outside the x offset range
		}
		if (checkCollision(babyShark, fish2s[j])) {
			// Play crunch sound
			LK.getSound('crunch').play();
			if (fish2s[j].x - fish2s[j].width / 3 < babyShark.x) {
				// Bounce baby shark off the bigger fish
				babyShark.velocityY = -10;
				//babyShark.x -= 50; // Move baby shark back a bit
			} else {
				// Lose a life
				LK.effects.flashScreen(0xff0000, 1000);
				LK.showGameOver();
			}
		}
	}
}
function updateFish1Collisions() {
	var currentTime = Date.now();
	if (currentTime - lastCollisionCheckTimeFish1 < collisionCheckDelay) {
		return;
	}
	lastCollisionCheckTimeFish1 = currentTime;
	var offset = babyShark.shark.width * 1.5; // Define the x offset range based on baby shark's width
	for (var i = fish1s.length - 1; i >= 0; i--) {
		if (Math.abs(babyShark.x - fish1s[i].x) > offset) {
			continue; // Skip fishes outside the x offset range
		}
		if (checkCollision(babyShark, fish1s[i])) {
			// Play crunch sound
			LK.getSound('crunch').play();
			score += 10;
			scoreTxt.setText(score);
			currentProgress += 1;
			currentProgressTxt.setText(currentProgress + "/10");
			if (currentProgress > 1) {
				sharkLevel += 1;
				currentProgress = 0;
				babyShark.grow();
			}
			fish1s[i].destroy();
			fish1s.splice(i, 1);
			return;
		}
	}
}
function updateBackgrounds() {
	background1.x -= 2;
	background2.x -= 2;
	if (background1.x <= -2732 / 2) {
		background1.x = 2732 + 2732 / 2;
	}
	if (background2.x <= -2732 / 2) {
		background2.x = 2732 + 2732 / 2;
	}
}
var background1;
function gameInitialize() {
	background1 = LK.getAsset('background', {
		anchorX: 0.5,
		anchorY: 0.5,
		x: 2732 / 2,
		y: 2732 / 2
	});
	background2 = LK.getAsset('background2', {
		anchorX: 0.5,
		anchorY: 0.5,
		x: 2732 + 2732 / 2,
		y: 2732 / 2
	});
	game.addChild(background1);
	game.addChild(background2);
	babyShark = game.addChild(new BabyShark());
	babyShark.x = 150;
	babyShark.y = 2732 / 2;
	babyShark.velocityY = 0;
	babyShark.collisionBody.visible = isDebug; // Show collision body if debugging
	fish1s = [];
	fish2s = [];
	score = 0;
	scoreTxt = new Text2('0', {
		size: 100,
		fill: "#ffffff",
		dropShadow: true,
		dropShadowColor: "#000000",
		dropShadowBlur: 4,
		dropShadowDistance: 6
	});
	scoreTxt.anchor.set(0.5, 0);
	LK.gui.top.addChild(scoreTxt);
	currentProgress = 0;
	currentProgressTxt = new Text2('0/10', {
		size: 100,
		fill: "#ffffff",
		dropShadow: true,
		dropShadowColor: "#000000",
		dropShadowBlur: 4,
		dropShadowDistance: 6
	});
	currentProgressTxt.anchor.set(1, 0);
	LK.gui.topRight.addChild(currentProgressTxt);
	debugTxt = new Text2('Debug Mode', {
		size: 50,
		fill: "#ff0000",
		dropShadow: true,
		dropShadowColor: "#000000",
		dropShadowBlur: 4,
		dropShadowDistance: 6
	});
	debugTxt.anchor.set(0.5, 1);
	LK.gui.bottom.addChild(debugTxt);
}
//background2.scale.x = -1;
var babyShark;
var fish1s;
var fish2s;
var score;
var scoreTxt;
var currentProgressTxt;
var debugTxt;
function spawnSmallFish() {
	var smallFish = new Fish1();
	smallFish.x = 2048 + 50;
	smallFish.y = Math.random() * (2732 - smallFish.height) + smallFish.height / 2;
	fish1s.push(smallFish);
	game.addChild(smallFish);
}
function spawnFish2() {
	var fish2 = new Fish2();
	fish2.x = 2048 + 50;
	fish2.y = Math.random() * (2732 - fish2.height) + fish2.height / 2;
	fish2s.push(fish2);
	game.addChild(fish2);
}
game.down = function (x, y, obj) {
	babyShark.velocityY = -20;
};
game.update = function () {
	updateBackgrounds();
	updateFish1Collisions();
	updateFish2Collisions();
	spawnFish();
	updateFish3Collisions();
};
gameInitialize(); ===================================================================
--- original.js
+++ change.js
@@ -52,11 +52,12 @@
 		self.collisionBody.y = self.height * 0.05;
 	};
 });
 // Fish class
-var Fish = Container.expand(function () {
+var Fish = Container.expand(function (fishType) {
 	var self = Container.call(this);
-	self.fish = self.attachAsset('fish1', {
+	self.fishType = fishType;
+	self.fish = self.attachAsset('fish' + fishType, {
 		anchorX: 0.5,
 		anchorY: 0.5
 	});
 	self.collisionBody = self.attachAsset('collisionBody', {
:quality(85)/https://cdn.frvr.ai/66859396def1c8edfaaea38f.png%3F3) 
 Orange Baby fish lateral view. 2024 game style
:quality(85)/https://cdn.frvr.ai/668593fcdef1c8edfaaea399.png%3F3) 
 Pink Baby fish lateral view. 2024 game style
:quality(85)/https://cdn.frvr.ai/6687d4bc7dad67f9857aeb3b.png%3F3) 
 Empty Under water. water only. 2024 game style
:quality(85)/https://cdn.frvr.ai/6689c97e7dad67f9857aecc1.png%3F3) 
 Cute Baby shark.. . 2024 game style. Side view. Photorealistic
:quality(85)/https://cdn.frvr.ai/668bc12872715dcfc88d890d.png%3F3) 
 Classic fish lateral view.. 2024 game style
:quality(85)/https://cdn.frvr.ai/668bc32172715dcfc88d8930.png%3F3) 
 Classic fish with fangs lateral view.. 2024 game style. Photorealistic
:quality(85)/https://cdn.frvr.ai/668bc37c72715dcfc88d893b.png%3F3) 
 Classic fish with fangs mouth closed lateral view.. 2024 game style. Photorealistic. Full side view.
:quality(85)/https://cdn.frvr.ai/668da39fb7c8eed252dc5a84.png%3F3) 
 Cachalot. Horizontal closed lateral view.... 2024 game style. Photorealistic. Full side view.
:quality(85)/https://cdn.frvr.ai/668db0e8b7c8eed252dc5b1e.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/668e979853e046179cac3abb.png%3F3) 
 Straight horizontal Orca. Mouth open. 2024 game style. Photorealistic. Full side view
:quality(85)/https://cdn.frvr.ai/668f05f9b7c8eed252dc5bd4.png%3F3) 
 Start button in the shape of a shark mouth.
:quality(85)/https://cdn.frvr.ai/66912dc3b7c8eed252dc5d76.png%3F3) 
 beluga swimming mouth open. 2024 game style. Photorealistic. Entire lateral profile view, perfectly horizontal.
:quality(85)/https://cdn.frvr.ai/66914094b7c8eed252dc5d8f.png%3F3) 
 North Pacific right whale. Horizontal complete lateral view..... 2024 game style. Photorealistic. Full side view.
:quality(85)/https://cdn.frvr.ai/669266e60c84e939219922fa.png%3F3) 
 Decomposition of Horizontal Swimming movement of a woman with a snorkel.. 2024 game style. 2 frames sprite sheet. Photorealistic
:quality(85)/https://cdn.frvr.ai/6693a3ed650bf6b3f3eb6e46.png%3F3) 
 Very minimalist skeleton of a fish with a fin and cute shark head... 2d. Black background. High contrast. No shadows.