Code edit (9 edits merged)
Please save this source code
User prompt
Add a little randomness to the ocsillation but after a full sinusoid
Code edit (1 edits merged)
Please save this source code
Code edit (1 edits merged)
Please save this source code
Code edit (10 edits merged)
Please save this source code
User prompt
Speed up the oscillation
Code edit (1 edits merged)
Please save this source code
Code edit (21 edits merged)
Please save this source code
User prompt
add also a movement to the legs
User prompt
in gamePlaying, ad a continuous balancing movement to the arms to simulate running
Code edit (1 edits merged)
Please save this source code
Code edit (17 edits merged)
Please save this source code
User prompt
Please fix the bug: 'ReferenceError: T is not defined' in or related to this line: 'T; // EMP DEBUG !!!' Line Number: 301
Code edit (1 edits merged)
Please save this source code
Code edit (10 edits merged)
Please save this source code
User prompt
Please fix the bug: 'TypeError: Cannot read properties of undefined (reading 'x')' in or related to this line: 'self.leftFoot.x += (self.targetPosture.leftFoot.x - self.leftFoot.x) * speed;' Line Number: 116
User prompt
Please fix the bug: 'TypeError: Cannot read properties of undefined (reading 'x')' in or related to this line: 'self.rightFoot.x += (self.targetPosture.rightFoot.x - self.rightFoot.x) * speed;' Line Number: 113
User prompt
Please fix the bug: 'TypeError: Cannot read properties of undefined (reading 'x')' in or related to this line: 'self.leftHand.x += (self.targetPosture.leftHand.x - self.leftHand.x) * speed;' Line Number: 108
User prompt
Please fix the bug: 'TypeError: Cannot read properties of undefined (reading 'x')' in or related to this line: 'self.rightHand.x += (self.targetPosture.rightHand.x - self.rightHand.x) * speed;' Line Number: 104
User prompt
Please fix the bug: 'TypeError: Cannot read properties of undefined (reading 'x')' in or related to this line: 'var handsAndLegsReached = Math.abs(self.rightHand.x - self.targetPosture.rightHand.x) < 1 && Math.abs(self.rightHand.y - self.targetPosture.rightHand.y) < 1 && Math.abs(self.leftHand.x - self.targetPosture.leftHand.x) < 1 && Math.abs(self.leftHand.y - self.targetPosture.leftHand.y) < 1 && Math.abs(self.rightLeg.x - self.targetPosture.rightLeg.x) < 1 && Math.abs(self.rightLeg.y - self.targetPosture.rightLeg.y) < 1 && Math.abs(self.leftLeg.x - self.targetPosture.leftLeg.x) < 1 && Math.abs(self.leftLeg.y - self.targetPosture.leftLeg.y) < 1 && Math.abs(self.head.x - self.targetPosture.head.x) < 1 && Math.abs(self.head.y - self.targetPosture.head.y) < 1 && Math.abs(self.rightFoot.x - self.targetPosture.rightFoot.x) < 1 && Math.abs(self.rightFoot.y - self.targetPosture.rightFoot.y) < 1 && Math.abs(self.leftFoot.x - self.targetPosture.leftFoot.x) < 1 && Math.abs(self.leftFoot.y - self.targetPosture.leftFoot.y) < 1;' Line Number: 83
User prompt
we will simplify the athlete : remove hands and foots
Code edit (1 edits merged)
Please save this source code
Code edit (1 edits merged)
Please save this source code
Code edit (1 edits merged)
Please save this source code
Code edit (1 edits merged)
Please save this source code
/**** 
* Classes
****/ 
/****************************************************************************************** */ 
/**************************************** CLASSES ***************************************** */
/****************************************************************************************** */ 
/****************************************************************************************** */ 
/************************************* ATHLETE CLASS ************************************** */
/****************************************************************************************** */ 
var Athlete = Container.expand(function () {
	var self = Container.call(this);
	self.speedX = 5;
	self.jumpSpeed = -15;
	self.gravity = 0.5;
	self.isOnGround = true;
	self.currentPosture = ""; // Store the name of the current posture
	self.isChangingPosture = false; // 0 when idle or moving down, 1 when moving up
	self.nextPosture = null;
	self.tint = 0xc0d4FF;
	// BODY PARTS
	self.trunk = self.attachAsset('bodyPart', {
		anchorX: 0.5,
		anchorY: 0.5,
		scaleX: 1,
		scaleY: 1,
		// Increased scale to make trunk longer
		tint: 0x000000 //self.tint // TEMP DEBUG
	});
	self.head = self.trunk.attachAsset('head', {
		anchorX: 0.5,
		anchorY: 2,
		scaleX: 1,
		scaleY: 1,
		tint: 0x000000 // self.tint
	});
	self.rightArm = self.trunk.attachAsset('bodyPart', {
		anchorX: 0.5,
		anchorY: 0,
		scaleX: 1,
		scaleY: 1,
		tint: self.tint
	});
	// Right hand asset attachment removed
	self.leftArm = self.trunk.attachAsset('bodyPart', {
		anchorX: 0.5,
		anchorY: 0,
		scaleX: 1,
		scaleY: 1,
		tint: self.tint
	});
	// Left hand asset attachment removed
	self.rightLeg = self.trunk.attachAsset('bodyPart', {
		anchorX: 0.5,
		anchorY: 0,
		scaleX: 1,
		scaleY: 1.2,
		tint: self.tint
	});
	// Right foot asset attachment removed
	self.leftLeg = self.trunk.attachAsset('bodyPart', {
		anchorX: 0.5,
		anchorY: 0,
		scaleX: 1,
		scaleY: 1.2,
		tint: self.tint
	});
	// Left foot asset attachment removed
	// FUNCTIONS
	self.updatePosture = function () {
		var speed = 0.2; //0.1; // Speed of transition
		if (!self.targetPosture) {
			return;
		}
		// Check if the target posture for hands and legs is reached
		//log("self.targetPosture: " + self.targetPosture.name + " :  self.rightHand.x: " + self.rightHand.x, " self.targetPosture.rightHand.x: " + self.targetPosture.rightHand.x);
		var handsAndLegsReached = Math.abs(self.rightLeg.x - self.targetPosture.rightLeg.x) < 1 && Math.abs(self.rightLeg.y - self.targetPosture.rightLeg.y) < 1 && Math.abs(self.leftLeg.x - self.targetPosture.leftLeg.x) < 1 && Math.abs(self.leftLeg.y - self.targetPosture.leftLeg.y) < 1 && Math.abs(self.head.x - self.targetPosture.head.x) < 1 && Math.abs(self.head.y - self.targetPosture.head.y) < 1;
		if (handsAndLegsReached) {
			//log("handsAndLegsReached !");
			// Update currentPosture to the name of the targetPosture when hands and legs posture is reached
			self.currentPosture = self.targetPosture.name;
			self.targetPosture = null;
			self.isChangingPosture = false;
			if (self.nextPosture) {
				self.setPosture(self.nextPosture);
			}
			return;
		} else {
			self.isChangingPosture = true;
		}
		if (self.targetPosture && self.targetPosture.head) {
			self.head.x += (self.targetPosture.head.x - self.head.x) * speed;
		}
		self.head.y += (self.targetPosture.head.y - self.head.y) * speed;
		self.rightArm.x += (self.targetPosture.rightArm.x - self.rightArm.x) * speed;
		self.rightArm.y += (self.targetPosture.rightArm.y - self.rightArm.y) * speed;
		self.rightArm.rotation += (self.targetPosture.rightArm.r - self.rightArm.rotation) * speed;
		// Right hand updates removed due to hand assets being removed
		self.leftArm.x += (self.targetPosture.leftArm.x - self.leftArm.x) * speed;
		self.leftArm.y += (self.targetPosture.leftArm.y - self.leftArm.y) * speed;
		self.leftArm.rotation += (self.targetPosture.leftArm.r - self.leftArm.rotation) * speed;
		// Left hand updates removed due to hand assets being removed
		self.trunk.x += (self.targetPosture.trunk.x - self.trunk.x) * speed;
		self.trunk.y += (self.targetPosture.trunk.y - self.trunk.y) * speed;
		self.rightLeg.x += (self.targetPosture.rightLeg.x - self.rightLeg.x) * speed;
		self.rightLeg.y += (self.targetPosture.rightLeg.y - self.rightLeg.y) * speed;
		// Right foot updates removed due to foot assets being removed
		self.leftLeg.x += (self.targetPosture.leftLeg.x - self.leftLeg.x) * speed;
		self.leftLeg.y += (self.targetPosture.leftLeg.y - self.leftLeg.y) * speed;
	};
	self.moveRight = function () {
		self.x += self.speedX;
	};
	self.jump = function () {
		if (self.isOnGround) {
			self.isOnGround = false;
			self.speedY = self.jumpSpeed;
		}
	};
	self.update = function () {
		if (!self.isOnGround) {
			self.y += self.speedY;
			self.speedY += self.gravity;
			if (self.y >= game.groundLevel) {
				self.y = game.groundLevel;
				self.isOnGround = true;
			}
		}
	};
	self.setPosture = function (newPosture) {
		log("Set posture: " + newPosture.name);
		if (self.isChangingPosture) {
			// Store next posture for when target one is reached
			self.nextPosture = newPosture;
			return;
		}
		if (self.nextPosture) {
			// If a next posture is set, use it as target
			newPosture = self.nextPosture;
			self.nextPosture = null;
		}
		if (newPosture && self.currentPosture != newPosture.name) {
			// Set new posture
			self.targetPosture = newPosture;
		}
	};
});
/****************************************************************************************** */ 
/************************************** OBSTACLE CLASS ************************************ */
/****************************************************************************************** */ 
// Obstacle class
var Obstacle = Container.expand(function () {
	var self = Container.call(this);
	var obstacleGraphics = self.attachAsset('obstacle', {
		anchorX: 0.5,
		anchorY: 1.0 // Anchor at the bottom for collision detection
	});
	self.speedX = -5;
	self.move = function () {
		self.x += self.speedX * 0; // TEMP DEBUG !!!
	};
});
/**** 
* Initialize Game
****/ 
var game = new LK.Game({
	backgroundColor: 0x87CEEB // Light blue background to represent the sky
});
/**** 
* Game Code
****/ 
/****************************************************************************************** */ 
/************************************** GLOBAL VARIABLES ********************************** */
/****************************************************************************************** */ 
// Enumeration for game states
var GAME_STATE = {
	INIT: 'INIT',
	MENU: 'MENU',
	HELP: 'HELP',
	STARTING: 'STARTING',
	NEW_ROUND: 'NEW_ROUND',
	PLAYING: 'PLAYING',
	SCORE: 'SCORE'
};
var gameState = GAME_STATE.INIT;
var athlete;
var obstacles = [];
var groundLevel = 2732 - 200; // Ground level set 200px from the bottom
var obstacleSpawnTicker = 0;
var obstacleSpawnRate = 120; // Spawn an obstacle every 2 seconds
var isDebug = true;
/****************************************************************************************** */ 
/************************************** POSTURES ****************************************** */
/****************************************************************************************** */ 
var idlePosture = {
	name: "idlePosture",
	trunk: {
		x: 0,
		y: 0
	},
	head: {
		x: 0,
		y: 0
	},
	rightArm: {
		x: 20,
		y: -80,
		r: Math.PI * 2 * 0.925
	},
	leftArm: {
		x: -20,
		y: -80,
		r: Math.PI * 2 * 0.125
	},
	rightLeg: {
		x: 5,
		y: 100
	},
	leftLeg: {
		x: -5,
		y: 100
	}
};
/****************************************************************************************** */ 
/*********************************** UTILITY FUNCTIONS ************************************ */
/****************************************************************************************** */ 
function log() {
	if (isDebug) {
		var _console;
		(_console = console).log.apply(_console, arguments);
	}
}
/****************************************************************************************** */ 
/************************************** INPUT HANDLERS ************************************ */
/****************************************************************************************** */ 
// Touch event to make the athlete jump
game.on('down', function () {
	athlete.jump();
});
/****************************************************************************************** */ 
/************************************* AI FUNCTIONS *************************************** */
/****************************************************************************************** */ 
/****************************************************************************************** */ 
/************************************* GAME STATES **************************************** */
/****************************************************************************************** */ 
function gameInitialize() {
	log("Game initialize...");
	// Initialize athlete
	athlete = game.addChild(new Athlete());
	athlete.x = 400;
	athlete.y = groundLevel - 200;
	athlete.setPosture(idlePosture);
	// Set the ground level globally accessible within the game instance
	game.groundLevel = groundLevel;
	gameState = GAME_STATE.PLAYING;
}
function gamePlaying() {
	log("Game playing...");
	athlete.update();
	athlete.updatePosture();
	// Move obstacles and check for off-screen
	for (var i = obstacles.length - 1; i >= 0; i--) {
		obstacles[i].move();
		// Remove obstacle if it moves off-screen
		if (obstacles[i].x < -100) {
			// Assuming obstacle width is less than 100px
			obstacles[i].destroy();
			obstacles.splice(i, 1);
		}
	}
	// Spawn obstacles
	obstacleSpawnTicker++;
	if (obstacleSpawnTicker >= obstacleSpawnRate) {
		obstacleSpawnTicker = 0;
		var newObstacle = new Obstacle();
		newObstacle.x = 2048; // Start from the right edge
		newObstacle.y = groundLevel;
		obstacles.push(newObstacle);
		game.addChild(newObstacle);
	}
	// Check for collisions
	obstacles.forEach(function (obstacle) {
		if (athlete.intersects(obstacle)) {
			LK.effects.flashScreen(0xff0000, 500); // Flash screen red for half a second
			LK.showGameOver(); // Show game over screen
		}
	});
	// Simulate running by continuously balancing the arms and legs
	var cycleComplete = Math.floor(LK.ticks / (Math.PI * 10)) % 2 == 0; // Check if a full sinusoid cycle is complete
	var randomFactor = cycleComplete ? 0.5 + Math.random() * 0.5 : 1; // Add randomness after a full cycle
	var runningArmAngle = Math.sin(LK.ticks / 5) * 0.5 * randomFactor; // Oscillate arm angle to simulate running faster with randomness
	var runningLegAngle = Math.sin(LK.ticks / 5) * 0.3 * randomFactor; // Oscillate leg angle to simulate running faster with randomness
	athlete.rightArm.rotation = runningArmAngle;
	athlete.leftArm.rotation = -runningArmAngle;
	athlete.rightLeg.rotation = -runningLegAngle;
	athlete.leftLeg.rotation = runningLegAngle;
	athlete.rightArm.height = 180 * (0.5 + Math.abs(runningArmAngle));
	athlete.leftArm.height = 160 * (0.7 + Math.abs(runningArmAngle));
}
/****************************************************************************************** */ 
/************************************** MAIN GAME LOOP ************************************ */
/****************************************************************************************** */ 
LK.on('tick', function () {
	switch (gameState) {
		case GAME_STATE.MENU:
			// Handle menu logic here
			break;
		case GAME_STATE.STARTING:
			// Handle game starting logic here
			break;
		case GAME_STATE.PLAYING:
			gamePlaying();
			break;
		case GAME_STATE.SCORE:
			// Handle score display logic here
			break;
	}
});
gameInitialize(); ===================================================================
--- original.js
+++ change.js
@@ -15,24 +15,24 @@
 	self.isOnGround = true;
 	self.currentPosture = ""; // Store the name of the current posture
 	self.isChangingPosture = false; // 0 when idle or moving down, 1 when moving up
 	self.nextPosture = null;
-	self.tint = 0xFFFFFF;
+	self.tint = 0xc0d4FF;
 	// BODY PARTS
 	self.trunk = self.attachAsset('bodyPart', {
 		anchorX: 0.5,
 		anchorY: 0.5,
 		scaleX: 1,
 		scaleY: 1,
 		// Increased scale to make trunk longer
-		tint: self.tint // TEMP DEBUG
+		tint: 0x000000 //self.tint // TEMP DEBUG
 	});
 	self.head = self.trunk.attachAsset('head', {
 		anchorX: 0.5,
 		anchorY: 2,
 		scaleX: 1,
 		scaleY: 1,
-		tint: self.tint
+		tint: 0x000000 // self.tint
 	});
 	self.rightArm = self.trunk.attachAsset('bodyPart', {
 		anchorX: 0.5,
 		anchorY: 0,
@@ -286,10 +286,12 @@
 			LK.showGameOver(); // Show game over screen
 		}
 	});
 	// Simulate running by continuously balancing the arms and legs
-	var runningArmAngle = Math.sin(LK.ticks / 5) * 0.5; // Oscillate arm angle to simulate running faster
-	var runningLegAngle = Math.sin(LK.ticks / 5) * 0.3; // Oscillate leg angle to simulate running faster
+	var cycleComplete = Math.floor(LK.ticks / (Math.PI * 10)) % 2 == 0; // Check if a full sinusoid cycle is complete
+	var randomFactor = cycleComplete ? 0.5 + Math.random() * 0.5 : 1; // Add randomness after a full cycle
+	var runningArmAngle = Math.sin(LK.ticks / 5) * 0.5 * randomFactor; // Oscillate arm angle to simulate running faster with randomness
+	var runningLegAngle = Math.sin(LK.ticks / 5) * 0.3 * randomFactor; // Oscillate leg angle to simulate running faster with randomness
 	athlete.rightArm.rotation = runningArmAngle;
 	athlete.leftArm.rotation = -runningArmAngle;
 	athlete.rightLeg.rotation = -runningLegAngle;
 	athlete.leftLeg.rotation = runningLegAngle;
:quality(85)/https://cdn.frvr.ai/661848ad3c9c5fe61a4c3f8e.png%3F3) 
 Elongated elipse with black top half and white bottom half.
:quality(85)/https://cdn.frvr.ai/661bdc7a58043b89d4ba9e89.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/661bdd1d58043b89d4ba9e8e.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/661be25558043b89d4ba9f0d.png%3F3) 
 full close and front view of empty stands. retro gaming style
:quality(85)/https://cdn.frvr.ai/661f4f57266989b7f2ed94f1.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/661f526b266989b7f2ed954f.png%3F3) 
 delete
:quality(85)/https://cdn.frvr.ai/661f5287266989b7f2ed9554.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/66226cbbf46305276d9e4de1.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/6622735cf46305276d9e4e30.png%3F3) 
 delete
:quality(85)/https://cdn.frvr.ai/66228a13eff7d73bc2d1d4a9.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/66228a2eeff7d73bc2d1d4ad.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/662384d91d31755ac753860d.png%3F3) 
 Basquettes à ressort futuriste. vue de profile. Retro gaming style
:quality(85)/https://cdn.frvr.ai/6623cf0f1d31755ac75387a8.png%3F3) 
 a blue iron man style armor flying. Retro gaming style
:quality(85)/https://cdn.frvr.ai/6623cf581d31755ac75387b3.png%3F3) 
 a blue iron man style armor flying horizontally. Retro gaming style
:quality(85)/https://cdn.frvr.ai/6623db441d31755ac753884e.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/6623dde21d31755ac753889e.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/662493106b90388bb0195cd3.png%3F3) 
 round button with a big "up" arrow icon and a small line under it. UI
:quality(85)/https://cdn.frvr.ai/6625589e6b90388bb0195eb5.png%3F3) 
 A big black horizontal arrow pointing left with centred text 'YOU' in capital letters, painted on an orange floor.. horizontal and pointing left
:quality(85)/https://cdn.frvr.ai/6625f7dfaefb923f60ced44a.png%3F3) 
 remove
:quality(85)/https://cdn.frvr.ai/66280aa325092f9d66ecfd6b.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/66289a7225092f9d66ecfe81.png%3F3) 
 gold athletics medal with ribbon. retro gaming style
:quality(85)/https://cdn.frvr.ai/66294f1a777dbb646cb323ba.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/66294f97777dbb646cb323d0.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/66295338777dbb646cb32447.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/6629533f777dbb646cb3244b.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/6629546e777dbb646cb32460.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/66295506777dbb646cb32474.png%3F3) 
 a black oval with a crying smiley face.
:quality(85)/https://cdn.frvr.ai/66295a3a777dbb646cb324d9.png%3F3)