Code edit (1 edits merged)
Please save this source code
User prompt
Move value 400 pixela.up
User prompt
Fix value anchor toe be displayed in the upper lwft corner of the card
User prompt
Move value to the upper left corner of the vard
User prompt
Fix message display anchor to be displayed in the bottom centwr
User prompt
Correcr or wrong should be in the bottom centwr
User prompt
Nextcard should also be in the center
User prompt
Card should be in the center of the screen. Fiz its anchor
User prompt
Set card anchor to .5 .5
User prompt
Card should be in the center of the screen
User prompt
Move card 300 pixels down
User prompt
Center suit asset in the center of the card
User prompt
Use assets to represent suits
User prompt
We are guessing the value of the mext card compared to the current one
User prompt
Instead of showing rhe text of the suit, we will show an asset that represents each auit
User prompt
Value and suit color should be black
User prompt
Value should be displayed in the top left and bottom right of rhe card
User prompt
Suit should be in the center of the card
User prompt
Invert higher or lowe logic
User prompt
Player is guessing if the next card is higher or lower than the current card
User prompt
If player guesses correctly add meesage in the bottom of the screen that says Correct! And Wrong! If the do not guess
User prompt
Fix Bug: 'TypeError: Cannot read properties of null (reading 'value')' in this line: 'if (guess === 'higher' && nextCard.value > currentCard.value || guess === 'lower' && nextCard.value < currentCard.value) {' Line Number: 107
User prompt
Fix Bug: 'TypeError: Cannot set properties of null (setting 'x')' in this line: 'nextCard.x = 2048 / 2;' Line Number: 103
User prompt
Every time the player guesses correctly add 1 point to the score
User prompt
Game will not be over if player does not guess correctly
var MessageDisplay = Container.expand(function () {
	var self = Container.call(this);
	var messageText = new Text2('', {
		size: 100,
		fill: '#ffffff',
		anchor: {
			x: 0.5,
			y: 0
		}
	});
	self.addChild(messageText);
	messageText.y = 2732 - 100;
	self.showMessage = function (message) {
		messageText.setText(message);
		messageText.x = 2048 / 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', .5, .5);
	var valueText = new Text2('', {
		size: 100,
		fill: '#000000',
		anchor: {
			x: 0.5,
			y: 0
		}
	});
	valueText.anchor.set(0.5, 0.5);
	valueText.x = 0;
	valueText.y = 0;
	var valueTextBottomRight = new Text2('', {
		size: 100,
		fill: '#000000',
		anchor: {
			x: 1,
			y: 1
		}
	});
	valueTextBottomRight.anchor.set(0.5, 0.5);
	valueTextBottomRight.x = 0;
	valueTextBottomRight.y = 0;
	self.addChild(valueTextBottomRight);
	self.setValue = function (value) {
		self.value = value;
		valueText.setText(value.toString());
		valueTextBottomRight.setText(value.toString());
	};
	self.addChild(valueText);
	var suitText = new Text2('', {
		size: 100,
		fill: '#000000',
		anchor: {
			x: 0.5,
			y: 1
		}
	});
	suitText.y = 0;
	self.addChild(suitText);
	self.setValue = function (value) {
		self.value = value;
		valueText.setText(value.toString());
	};
	self.value = 0;
	self.setValue = function (value) {
		self.value = value;
		valueText.setText(value.toString());
	};
});
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 Game = Container.expand(function () {
	var self = Container.call(this);
	stage.on('up', function (obj) {
		var endY = obj.event.getLocalPosition(self).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;
		self.addChild(nextCard);
		nextCard.x = 2048 / 2 - nextCard.width / 2;
		nextCard.y = 2732 / 2 - nextCard.height / 2;
		var messageDisplay = self.addChild(new MessageDisplay());
		var correctGuess = guess === 'higher' && nextCard.value > currentCard.value || guess === 'lower' && nextCard.value < currentCard.value;
		if (correctGuess) {
			player.updateScore(player.score + 1);
			self.updateScoreDisplay(player.score);
			LK.setScore(player.score);
			messageDisplay.showMessage('Correct!');
		} else {
			messageDisplay.showMessage('Wrong!');
		}
		currentCard.destroy();
		currentCard = nextCard;
		nextCard = null;
		startY = null;
	});
	var scoreTxt = new Text2('0', {
		size: 150,
		fill: "#ffffff",
		anchor: {
			x: .5,
			y: 0
		}
	});
	scoreTxt.y = 50;
	LK.gui.topCenter.addChild(scoreTxt);
	self.updateScoreDisplay = function (score) {
		scoreTxt.setText(score.toString());
	};
	self.updateScoreDisplay(0);
	var deck = [];
	var player = self.addChild(new Player());
	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)];
	var index = deck.indexOf(currentCard);
	deck.splice(index, 1);
	self.addChild(currentCard);
	currentCard.x = 2048 / 2 - currentCard.width / 2;
	currentCard.y = 2732 / 2 - currentCard.height / 2;
	player.x = 2048 / 2;
	player.y = 2732 / 2 + 200;
	var startY = null;
	stage.on('down', function (obj) {
		startY = obj.event.getLocalPosition(self).y;
	});
});
 ===================================================================
--- original.js
+++ change.js
@@ -36,21 +36,22 @@
 			x: 0.5,
 			y: 0
 		}
 	});
-	valueText.anchor.set(0, 0);
-	valueText.x = -cardGraphics.width / 2 + valueText.width / 2;
-	valueText.y = -cardGraphics.height / 2 + valueText.height / 2;
+	valueText.anchor.set(0.5, 0.5);
+	valueText.x = 0;
+	valueText.y = 0;
 	var valueTextBottomRight = new Text2('', {
 		size: 100,
 		fill: '#000000',
 		anchor: {
 			x: 1,
 			y: 1
 		}
 	});
-	valueTextBottomRight.x = cardGraphics.width / 2 - valueTextBottomRight.width / 2;
-	valueTextBottomRight.y = cardGraphics.height / 2 - valueTextBottomRight.height / 2;
+	valueTextBottomRight.anchor.set(0.5, 0.5);
+	valueTextBottomRight.x = 0;
+	valueTextBottomRight.y = 0;
 	self.addChild(valueTextBottomRight);
 	self.setValue = function (value) {
 		self.value = value;
 		valueText.setText(value.toString());
: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)