User prompt
reduce size of minicad in half
User prompt
suit of minicard should have the proportional size of the minicard
User prompt
reduce size of minicard in half
User prompt
when a card is destroyed, create a miniversion of it, withe same asset and the same value and suit. This will be shown in the bottom of the screen. every time a new card is destroyed, a new minicard will be displayed 20 pixels right from the last one.
User prompt
make sure minicard suit and value show on top of the minicard in its current positon
User prompt
Fix Bug: 'Timeout.tick error: Cannot set properties of null (setting 'x')' in this line: 'LK.off('tick', moveCard);' Line Number: 262
User prompt
make sure minicard also shows the suit and the value
User prompt
show minicard in the center of the screen
Code edit (3 edits merged)
Please save this source code
User prompt
when the card is destroyed show a copy of the asset of that card with the value and the suit below the current card. it should be one tenth of the size of the original asset.
Code edit (3 edits merged)
Please save this source code
User prompt
add a one second cooldown for any type of swipe in the game
User prompt
add a 1 second cooldown for swiping
User prompt
player should be able to swipe up or down only once every second.
User prompt
Fix Bug: 'TypeError: Cannot read properties of null (reading 'y')' in this line: 'LK.on('tick', function moveCardLeft() {' Line Number: 205
User prompt
Fix Bug: 'TypeError: Cannot read properties of null (reading 'y')' in this line: 'LK.on('tick', function moveCardLeft() {' Line Number: 205
User prompt
Fix Bug: 'Timeout.tick error: Cannot set properties of null (setting 'x')' in this line: 'LK.off('tick', moveCard);' Line Number: 217
User prompt
player should be able to swipe once per second only
Code edit (1 edits merged)
Please save this source code
User prompt
if the new card is the same value as current card, it should count as correct and add 1 to the score
User prompt
destroy startmessage displaye after the left counter is reduced by 1
User prompt
remove startmessagedisplay after the first card is updated
Code edit (2 edits merged)
Please save this source code
User prompt
move start message background 500 pixels to the right
User prompt
move start message background 500 pixels to the right
/**** 
* Classes
****/
var StartMessageDisplay = Container.expand(function () {
	var self = Container.call(this);
	var background = self.createAsset('start_message_background', 'Start Message Background', 0.5, 0.5);
	background.x = 1024 + 500;
	background.y = 1366;
	self.addChildAt(background, 0);
	var messageText = new Text2('     Swipe Up\n    for Higher!\n\n           or\n\n    Swipe Down\n     for Lower!', {
		size: 100,
		fill: '#0000000',
		stroke: '#000000',
		strokeThickness: 0,
		anchor: {
			x: 0.5,
			y: 0
		}
	});
	self.addChild(messageText);
	messageText.y = 900;
	messageText.x = 1150;
	self.showMessage = function (message) {
		messageText.setText(message);
		messageText.x = 2000;
		self.addChild(messageText);
		LK.setTimeout(function () {
			messageText.setText('');
		}, 2000);
	};
});
var MessageDisplay = Container.expand(function () {
	var self = Container.call(this);
	var messageText = new Text2('', {
		size: 200,
		fill: '#ffffff',
		stroke: '#000000',
		strokeThickness: 8,
		anchor: {
			x: 0.5,
			y: 0
		}
	});
	self.addChild(messageText);
	messageText.y = 2732 - messageText.height - 200;
	self.showMessage = function (message) {
		messageText.setText(message);
		messageText.x = 2048 / 2 - messageText.width / 2;
		self.addChild(messageText);
		LK.setTimeout(function () {
			messageText.setText('');
		}, 2000);
	};
});
var Card = Container.expand(function () {
	var self = Container.call(this);
	self.setSuit = function (suit) {
		self.suit = suit;
		var suitAsset = self.createAsset('suit_' + suit, 'Suit Asset', 0.5, 0.5);
		suitAsset.x = 0;
		suitAsset.y = 0;
		self.addChild(suitAsset);
	};
	var cardGraphics = self.createAsset('card', 'Card Graphics', 0.5, 0.5);
	cardGraphics.anchor.set(0.5, 0.5);
	var valueText = new Text2('', {
		size: 120,
		fill: '#000000',
		font: 'bold',
		anchor: {
			x: 0,
			y: 0
		}
	});
	valueText.anchor.set(0, 0);
	valueText.x = -cardGraphics.width / 2 + 50;
	valueText.y = -cardGraphics.height / 2 + 30;
	var valueText2 = new Text2('', {
		size: 120,
		fill: '#000000',
		font: 'bold',
		anchor: {
			x: 1,
			y: 1
		}
	});
	valueText2.anchor.set(0, 0);
	valueText2.x = cardGraphics.width / 2 - 50;
	valueText2.y = cardGraphics.height / 2 - 30;
	valueText2.scale.y = -1;
	valueText2.scale.x = -1;
	self.addChild(valueText2);
	self.setValue = function (value) {
		self.value = value;
		valueText.setText(value.toString());
		valueText2.setText(value.toString());
	};
	self.addChild(valueText);
	self.addChild(valueText2);
	var suitText = new Text2('', {
		size: 120,
		fill: '#000000',
		anchor: {
			x: 0.5,
			y: 1
		}
	});
	suitText.y = 0;
	self.addChild(suitText);
	self.setValue = function (value) {
		self.value = value;
		var displayValue = value;
		if (value === 11) {
			displayValue = 'J';
		} else if (value === 12) {
			displayValue = 'Q';
		} else if (value === 13) {
			displayValue = 'K';
		} else if (value === 1) {
			displayValue = 'A';
		}
		valueText.setText(displayValue.toString());
		valueText2.setText(displayValue.toString());
	};
	self.value = 0;
});
var Player = Container.expand(function () {
	var self = Container.call(this);
	var playerGraphics = self.createAsset('player', 'Player Graphics', .5, .5);
	self.score = 0;
	self.updateScore = function (score) {
		self.score = score;
	};
});
var MiniCard = Container.expand(function () {
	var self = Container.call(this);
	self.createMiniCard = function (card) {
		var miniCardGraphics = self.createAsset('card', 'Mini Card Graphics', 0.5, 0.5);
		miniCardGraphics.scale.x = 0.1;
		miniCardGraphics.scale.y = 0.1;
		var displayValue = card.value;
		if (card.value === 11) {
			displayValue = 'J';
		} else if (card.value === 12) {
			displayValue = 'Q';
		} else if (card.value === 13) {
			displayValue = 'K';
		} else if (card.value === 1) {
			displayValue = 'A';
		}
		var miniValueText = new Text2(displayValue.toString(), {
			size: 12,
			fill: '#000000',
			font: 'bold',
			anchor: {
				x: 0,
				y: 0
			}
		});
		miniValueText.x = -miniCardGraphics.width / 2 + 5;
		miniValueText.y = -miniCardGraphics.height / 2 + 3;
		var miniSuitAsset = self.createAsset('suit_' + card.suit, 'Mini Suit Asset', 0.5, 0.5);
		miniSuitAsset.scale.x = 0.1;
		miniSuitAsset.scale.y = 0.1;
		miniSuitAsset.x = -miniCardGraphics.width / 2 + 5;
		miniSuitAsset.y = miniCardGraphics.height / 2 - 15;
		self.addChild(miniCardGraphics);
		self.addChild(miniSuitAsset);
		self.addChild(miniValueText);
	};
});
/**** 
* Initialize Game
****/
var game = new LK.Game({
	backgroundColor: 0x000000
});
/**** 
* Game Code
****/
var player = new Player();
var background = game.createAsset('background', 'Background Asset', 0.5, 0.5);
background.x = 2048 / 2;
background.y = 2732 / 2;
game.addChild(background);
var canSwipe = true;
game.on('up', function (obj) {
	if (!canSwipe) {
		return;
	}
	canSwipe = false;
	LK.setTimeout(function () {
		canSwipe = true;
	}, 1500);
	var endY = obj.event.getLocalPosition(game).y;
	if (startY === null || endY === null) {
		return;
	}
	var swipeDirection = startY - endY;
	var guess = swipeDirection > 0 ? 'higher' : 'lower';
	if (deck.length === 0) {
		LK.showGameOver();
		return;
	}
	nextCard = deck.pop();
	if (!nextCard) {
		return;
	}
	// Decrease the cards left counter
	cardsLeftTxt.setText('Left: ' + deck.length);
	if (startMessageDisplay) {
		startMessageDisplay.destroy();
		startMessageDisplay = null;
	}
	console.log('Next Card:', 'Value:', nextCard.value, 'Suit:', nextCard.suit);
	game.addChild(nextCard);
	nextCard.x = 2048 / 2 + 500;
	nextCard.y = swipeDirection > 0 ? 2732 + nextCard.height : -nextCard.height;
	var speed = 50;
	LK.on('tick', function () {
		if (nextCard) {
			if (swipeDirection > 0 && nextCard.y > 2732 / 2) {
				nextCard.y -= speed;
			} else if (swipeDirection < 0 && nextCard.y < 2732 / 2) {
				nextCard.y += speed;
			}
		}
	});
	if (game.messageDisplay) {
		game.messageDisplay.destroy();
	}
	game.messageDisplay = game.addChild(new MessageDisplay());
	var correctGuess = guess === 'higher' && nextCard.value >= currentCard.value || guess === 'lower' && nextCard.value <= currentCard.value;
	LK.setTimeout(function () {
		if (correctGuess) {
			player.updateScore(player.score + 1);
			game.updateScoreDisplay(player.score);
			LK.setScore(player.score);
			game.messageDisplay.showMessage('Correct!');
		} else {
			game.messageDisplay.showMessage('Wrong!');
		}
	}, 1000);
	console.log('Current Card:', 'Value:', currentCard.value, 'Suit:', currentCard.suit);
	LK.on('tick', function moveCard() {
		if (Math.abs(nextCard.y - 2732 / 2) <= 20) {
			LK.setTimeout(function () {
				if (currentCard) {
					LK.on('tick', function moveCardLeft() {
						if (currentCard.x > 2048 / 2 - 500) {
							currentCard.x -= 20;
						} else {
							LK.off('tick', moveCardLeft);
						}
					});
				}
				currentCard = nextCard;
				nextCard = null;
				startY = null;
				currentCard.x = 2048 / 2;
			}, 500);
			LK.off('tick', moveCard);
			var miniCard = new MiniCard();
			miniCard.createMiniCard(currentCard);
			miniCard.x = 2048 / 2;
			miniCard.y = 2732 / 2;
			game.addChild(miniCard);
		}
	});
});
var scoreTxt = new Text2('0', {
	size: 112,
	fill: "#ffffff",
	stroke: '#000000',
	strokeThickness: 8,
	anchor: {
		x: .5,
		y: .5
	}
});
var cardsLeftTxt = new Text2('Left: 51', {
	size: 112,
	fill: "#ffffff",
	stroke: '#000000',
	strokeThickness: 8,
	anchor: {
		x: 0,
		y: .5
	}
});
scoreTxt.y = 50;
scoreTxt.x = -1340;
cardsLeftTxt.x = scoreTxt.x + scoreTxt.width + 800;
cardsLeftTxt.y = 50;
LK.gui.topRight.addChild(scoreTxt);
LK.gui.topRight.addChild(cardsLeftTxt);
game.updateScoreDisplay = function (score) {
	scoreTxt.setText('Score: ' + score.toString());
};
game.updateScoreDisplay(0);
var startMessageDisplay = new StartMessageDisplay();
game.addChild(startMessageDisplay);
var deck = [];
var currentCard = null;
var nextCard = null;
var suits = ['hearts', 'diamonds', 'clubs', 'spades'];
for (var s = 0; s < suits.length; s++) {
	for (var i = 1; i <= 13; i++) {
		var card = new Card();
		card.setValue(i);
		card.setSuit(suits[s]);
		deck.push(card);
	}
}
deck.sort(function () {
	return 0.5 - Math.random();
});
currentCard = deck[Math.floor(Math.random() * deck.length)];
console.log('First Card:', 'Value:', currentCard.value, 'Suit:', currentCard.suit);
var index = deck.indexOf(currentCard);
deck.splice(index, 1);
game.addChild(currentCard);
currentCard.x = 2048 / 2 - 500;
currentCard.y = 2732 / 2;
// Update the cards left counter
cardsLeftTxt.setText('Left: ' + deck.length);
var startY = null;
game.on('down', function (obj) {
	startY = obj.event.getLocalPosition(game).y;
}); ===================================================================
--- original.js
+++ change.js
@@ -164,10 +164,10 @@
 		miniSuitAsset.scale.y = 0.1;
 		miniSuitAsset.x = -miniCardGraphics.width / 2 + 5;
 		miniSuitAsset.y = miniCardGraphics.height / 2 - 15;
 		self.addChild(miniCardGraphics);
-		self.addChild(miniValueText);
 		self.addChild(miniSuitAsset);
+		self.addChild(miniValueText);
 	};
 });
 
 /**** 
:quality(85)/https://cdn.frvr.ai/6597536621cfde5f91984776.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/6597536d21cfde5f91984779.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/6597538621cfde5f9198477c.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/6597f9097aea181bcbf76e13.png%3F3) 
 :quality(85)/https://cdn.frvr.ai/6597fe5f7aea181bcbf76e51.png%3F3) 
 Green casino baize. To be used as background. No shade. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/659f1f55fd3289ab738790f5.png%3F3) 
 white rectangle flat. rounded corners. no background. no shadow. card shape.. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/659f1fe5fd3289ab738790fa.png%3F3)