Code edit (1 edits merged)
Please save this source code
User prompt
only event that should work on the screen are swipes. and swipes must be at least 50 pixels long. if not, touch of the screen should do nothing.
Code edit (3 edits merged)
Please save this source code
User prompt
increase the size of the value of the card top left and bottom right to 170
User prompt
double the size of the miniccard suit and move it 20 pixels down
User prompt
Fix Bug: 'TypeError: Cannot read properties of null (reading 'x')' in this line: 'if (currentCard && nextCard.x < 2048 / 2) {' Line Number: 318
User prompt
When nextcard stops moving, make sure it moves to the previous current card positiin
User prompt
move minicard suit 20 pixels down
Code edit (9 edits merged)
Please save this source code
User prompt
make sure nextcard is evenly aligned with current card before it moves left
Code edit (1 edits merged)
Please save this source code
User prompt
move card value 100 pixels closer to the suit
Code edit (1 edits merged)
Please save this source code
Code edit (1 edits merged)
Please save this source code
User prompt
double size of minicard suit
User prompt
Fix Bug: 'Timeout.tick error: Cannot read properties of undefined (reading 'suit')' in this line: 'previewNextCard.setSuit(deck[deck.length - 1].suit);' Line Number: 309
User prompt
wait 1 second before updating suit of previewnextcard
Code edit (3 edits merged)
Please save this source code
User prompt
set previewnextcard dim to 0.5 1 second after first swipe
User prompt
when previewnextcard suit property is updated, delete/hide the previous suit
User prompt
when a new previewnextcard is created (after the first one), hide or delete the previous previewnextcard
User prompt
on swipe, destroy the previous previewnextcard
User prompt
on game start set dim = 0 for previewnextcard. set to 0.5 after 1st swipe
User prompt
Fix Bug: 'Uncaught TypeError: Cannot read properties of undefined (reading 'height')' in this line: 'previewCounterText.y = -self.height / 2 - previewCounterText.height / 2 - 100;' Line Number: 414
User prompt
Fix Bug: 'Uncaught ReferenceError: cardGraphics is not defined' in this line: 'previewCounterText.y = -cardGraphics.height / 2 - previewCounterText.height / 2 - 100;' Line Number: 414
/**** 
* Classes
****/
var PreviewNextCard = Container.expand(function () {
	var self = Container.call(this);
	self.alpha = 0.5;
	self.setSuit = function (suit) {
		if (self.suitAsset) {
			self.suitAsset.destroy();
		}
		self.suit = suit;
		self.suitAsset = self.createAsset('suit_' + suit, 'Suit Asset', 0.5, 0.5);
		self.suitAsset.x = 0;
		self.suitAsset.y = 0;
		self.addChild(self.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;
	self.addChild(valueText);
	self.setValue = function (value) {
		self.value = value;
	};
	self.value = 0;
	// Add 'Next' text on top of the preview card
	var nextText = new Text2('Next', {
		size: 120,
		fill: '#0000000',
		anchor: {
			x: 0.5,
			y: 0
		}
	});
	nextText.y = -cardGraphics.height / 2 - nextText.height / 2 - 20 + 120;
	nextText.x = -120;
	self.addChild(nextText);
});
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 = 1266;
	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 = 800;
	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: 150,
		fill: '#ffffff',
		stroke: '#000000',
		strokeThickness: 16,
		anchor: {
			x: 0.5,
			y: 0
		}
	});
	self.addChild(messageText);
	messageText.y = 500 - messageText.height;
	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: 140,
		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.setSuit = function (suit) {
		self.suit = suit;
		var suitAsset = self.createAsset('suit_' + suit, 'Mini Suit Asset', 0.5, 0.5);
		suitAsset.scale.x = 0.20;
		suitAsset.scale.y = 0.20;
		suitAsset.x = 0;
		suitAsset.y = 20;
		self.addChild(suitAsset);
	};
	var cardGraphics = self.createAsset('card', 'Mini Card Graphics', 0.5, 0.5);
	cardGraphics.scale.x = 0.125;
	cardGraphics.scale.y = 0.125;
	cardGraphics.anchor.set(0.5, 0.5);
	var valueText = new Text2('', {
		size: 70,
		fill: '#000000',
		font: 'bold',
		anchor: {
			x: 0,
			y: 0
		}
	});
	valueText.anchor.set(0, 0);
	valueText.x = -cardGraphics.width / 16 + 6.25;
	valueText.y = -cardGraphics.height / 16 + 3.75;
	self.addChild(valueText);
	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());
	};
	self.value = 0;
});
/**** 
* 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 () {
		previewNextCard.alpha = 0.5;
	}, 1000);
	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 - 100 : -nextCard.height - 100;
	var speed = 50;
	var moveCard = function moveCard() {
		if (nextCard) {
			if (swipeDirection > 0 && nextCard.y > 2732 / 2 - 100) {
				nextCard.y -= speed;
			} else if (swipeDirection < 0 && nextCard.y < 2732 / 2 - 100) {
				nextCard.y += speed;
			}
			if (Math.abs(nextCard.y - 2732 / 2 + 100) <= 20) {
				LK.off('tick', moveCard);
			}
		}
	};
	LK.on('tick', moveCard);
	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);
	LK.setTimeout(function () {
		if (deck.length > 0) {
			previewNextCard.setSuit(deck[deck.length - 1].suit);
		}
	}, 1000);
	console.log('Current Card:', 'Value:', currentCard.value, 'Suit:', currentCard.suit);
	LK.on('tick', function moveCard() {
		if (Math.abs(nextCard.y - 2732 / 2 + 100) <= 20) {
			LK.setTimeout(function () {
				LK.on('tick', function moveCardLeft() {
					if (currentCard && currentCard.x > 2048 / 2 - 500) {
						currentCard.x -= 20;
					} else if (currentCard) {
						var miniCard = new MiniCard();
						miniCard.setValue(currentCard.value);
						miniCard.setSuit(currentCard.suit);
						miniCard.x = (game.miniCardX || 110) + miniCard.width / 6;
						miniCard.y = 2732 - miniCard.height - 550 - (game.miniCardYOffset || 0);
						game.addChild(miniCard);
						game.miniCardCount = (game.miniCardCount || 0) + 1;
						if (game.miniCardCount % 13 === 0) {
							game.miniCardX = 110;
							game.miniCardYOffset = (game.miniCardYOffset || 0) - 200;
						} else {
							game.miniCardX = miniCard.x + miniCard.width + 20;
						}
						LK.off('tick', moveCardLeft);
					}
				});
				currentCard = nextCard;
				nextCard = null;
				startY = null;
				if (currentCard) {
					currentCard.x = 2048 / 2;
					currentCard.y = 2732 / 2 - 100;
				}
			}, 500);
			LK.off('tick', moveCard);
		}
	});
});
var scoreTxt = new Text2('0', {
	size: 80,
	fill: "#ffffff",
	stroke: '#000000',
	strokeThickness: 14,
	anchor: {
		x: .5,
		y: .5
	}
});
var cardsLeftTxt = new Text2('Left: 51', {
	size: 80,
	fill: "#ffffff",
	stroke: '#000000',
	strokeThickness: 14,
	anchor: {
		x: 0,
		y: .5
	}
});
scoreTxt.y = 50;
scoreTxt.x = -1340;
cardsLeftTxt.x = scoreTxt.x + scoreTxt.width + 870;
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 - 100;
var previewNextCard = new PreviewNextCard();
previewNextCard.alpha = 0;
previewNextCard.setValue(deck[deck.length - 1].value);
previewNextCard.setSuit(deck[deck.length - 1].suit);
previewNextCard.x = 2048 / 2 + 500;
previewNextCard.y = 2732 / 2 - 100;
game.addChild(previewNextCard);
console.log('PreviewNextCard Value:', previewNextCard.value);
// Spawn the miniCard for the current card
var miniCard = new MiniCard();
miniCard.setValue(currentCard.value);
miniCard.setSuit(currentCard.suit);
miniCard.x = 110 + miniCard.width / 6;
miniCard.y = 2732 - miniCard.height - 550;
game.addChild(miniCard);
// Initialize miniCard positioning variables
game.miniCardX = miniCard.x + miniCard.width + 20;
game.miniCardCount = 1;
game.miniCardYOffset = 0;
// 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
@@ -118,21 +118,21 @@
 			y: 0
 		}
 	});
 	valueText.anchor.set(0, 0);
-	valueText.x = -cardGraphics.width / 2 + 150;
+	valueText.x = -cardGraphics.width / 2 + 50;
 	valueText.y = -cardGraphics.height / 2 + 30;
 	var valueText2 = new Text2('', {
-		size: 120,
+		size: 140,
 		fill: '#000000',
 		font: 'bold',
 		anchor: {
 			x: 1,
 			y: 1
 		}
 	});
 	valueText2.anchor.set(0, 0);
-	valueText2.x = cardGraphics.width / 2 - 150;
+	valueText2.x = cardGraphics.width / 2 - 50;
 	valueText2.y = cardGraphics.height / 2 - 30;
 	valueText2.scale.y = -1;
 	valueText2.scale.x = -1;
 	self.addChild(valueText2);
@@ -202,9 +202,9 @@
 			y: 0
 		}
 	});
 	valueText.anchor.set(0, 0);
-	valueText.x = -cardGraphics.width / 16 + 106.25;
+	valueText.x = -cardGraphics.width / 16 + 6.25;
 	valueText.y = -cardGraphics.height / 16 + 3.75;
 	self.addChild(valueText);
 	self.setValue = function (value) {
 		self.value = value;
: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)