Code edit (4 edits merged)
Please save this source code
User prompt
Fix Bug: 'TypeError: Cannot read properties of undefined (reading 'row')' in this line: 'if (visited[card.row][card.col] || bends > 2) {' Line Number: 160
Code edit (1 edits merged)
Please save this source code
User prompt
Fix Bug: 'Uncaught TypeError: Cannot set properties of undefined (setting '1')' in this line: 'board[card.row + 1][card.col + 1] = card;' Line Number: 249
User prompt
Fix Bug: 'Uncaught TypeError: Cannot set properties of undefined (setting '1')' in this line: 'board[card.row + 1][card.col + 1] = card;' Line Number: 249
User prompt
Fix Bug: 'Uncaught TypeError: Cannot set properties of undefined (setting '1')' in this line: 'board[card.row + 1][card.col + 1] = card;' Line Number: 245
Code edit (2 edits merged)
Please save this source code
User prompt
add debuging console logs in each step of canBeLinked
Code edit (1 edits merged)
Please save this source code
User prompt
update canBeLinked to take Card objects in parameter instead of arrays
User prompt
update the cards array to be 2 dimensional [nbRows][nbCols]
Code edit (1 edits merged)
Please save this source code
User prompt
fill each card col and row
User prompt
calculate col and row properties from x and y of the card
User prompt
Add two properties row and col to Card class
Code edit (1 edits merged)
Please save this source code
Code edit (1 edits merged)
Please save this source code
User prompt
Fix Bug: 'TypeError: Cannot read properties of undefined (reading '256')' in this line: 'if (cards[card1[0]][card1[1]] !== cards[card2[0]][card2[1]]) {' Line Number: 148
User prompt
call canBeLinked in the down event
Code edit (2 edits merged)
Please save this source code
User prompt
in the tick event update matchDebugText with last matched value
User prompt
update lastMatched with the result of the match after 2nd card selection
User prompt
add a global bool variable lastMatched
User prompt
Add another debug text at top right and display "Match:"
Code edit (1 edits merged)
Please save this source code
var Line = Container.expand(function (startX, startY, endX, endY) {
	var self = Container.call(this);
	var lineGraphics = self.createAsset('line', 'Line Graphics', 0, 0);
	lineGraphics.width = Math.sqrt(Math.pow(endX - startX, 2) + Math.pow(endY - startY, 2));
	lineGraphics.rotation = Math.atan2(endY - startY, endX - startX);
	lineGraphics.x = startX;
	lineGraphics.y = startY;
	self.addChild(lineGraphics);
	return self;
});
var Picture = Container.expand(function (index) {
	var self = Container.call(this);
	self.index = index;
	var pictureGraphics = self.createAsset('picture' + self.index, 'Picture Graphics', .5, .5);
	return self;
});
var Card = Container.expand(function (index) {
	var self = Container.call(this);
	self.row = 0;
	self.col = 0;
	self.shakeAnimation = function (card) {
		if (!card) return;
		var shakeCount = 0;
		var shakeTimes = 7;
		var shakeStrength = 30;
		var originalX = card.x;
		var originalY = card.y;
		function shake() {
			if (shakeCount < shakeTimes) {
				card.x = originalX + (Math.random() - 0.5) * shakeStrength;
				card.y = originalY + (Math.random() - 0.5) * shakeStrength;
				shakeCount++;
				LK.setTimeout(shake, 50);
			} else {
				card.x = originalX;
				card.y = originalY;
				card.scale.x = 1;
				card.scale.y = 1;
				card.children[0].scale.x = 1;
				card.children[0].scale.y = 1;
				if (card === selectedCard1) selectedCard1 = null;
				if (card === selectedCard2) selectedCard2 = null;
				isAnimating = false;
			}
		}
		shake();
	};
	self.id = index;
	self.on('down', function (obj) {
		if (!self.isMatched && !isAnimating) {
			if (!selectedCard1 || selectedCard1 && selectedCard2) {
				if (selectedCard1) {
					selectedCard1.scale.x = 1;
					selectedCard1.scale.y = 1;
					if (selectedCard1 === self) {
						selectedCard1 = null;
						return;
					}
				}
				selectedCard1 = self;
				selectedCard2 = null;
				self.scale.x = 1.2;
				self.scale.y = 1.2;
			} else if (selectedCard1 && !selectedCard2 && selectedCard1 === self) {
				selectedCard1.scale.x = 1;
				selectedCard1.scale.y = 1;
				selectedCard1 = null;
			} else if (selectedCard1 && !selectedCard2 && selectedCard1 !== self) {
				selectedCard2 = self;
				console.log("canBeLinked(card1, card2)", selectedCard1, selectedCard2);
				self.scale.x = 1.2;
				self.scale.y = 1.2;
				if (selectedCard1.id == selectedCard2.id) {
					lastMatched = true;
					selectedCard1.match(selectedCard2);
					selectedCard2.match(selectedCard1);
					selectedCard1 = null;
					selectedCard2 = null;
				} else {
					lastMatched = false;
					isAnimating = true;
					LK.setTimeout(function () {
						self.shakeAnimation(selectedCard1);
						self.shakeAnimation(selectedCard2);
					}, 300);
				}
			}
		}
	});
	var cardGraphics = self.createAsset('card', 'Card Graphics', .5, .5);
	self.isMatched = false;
	self.match = function (otherCard) {
		var line = new Line(self.x, self.y, otherCard.x, otherCard.y);
		LK.stage.addChild(line);
		LK.setTimeout(function () {
			line.destroy();
		}, 1000);
		var tadaAnimationSteps = 10;
		var tadaAnimationCount = 0;
		var scaleDelta = 0.2;
		var tadaDelay = 0;
		var tadaDelayMax = 60;
		self.tadaAnimation = function () {
			if (tadaAnimationCount < tadaAnimationSteps) {
				self.scale.x += tadaAnimationCount % 2 === 0 ? scaleDelta : -scaleDelta;
				self.scale.y += tadaAnimationCount % 2 === 0 ? scaleDelta : -scaleDelta;
				tadaAnimationCount++;
			} else {
				LK.off('tick', self.tadaAnimation);
			}
		};
		self.shrinkAnimation = function () {
			if (self.scale.x > 0.1) {
				self.scale.x -= 0.01;
				self.scale.y -= 0.01;
			} else {
				self.visible = false;
				self.isMatched = true;
				LK.off('tick', self.tadaAnimation);
				LK.off('tick', self.shrinkAnimation);
			}
		};
		LK.on('tick', self.tadaAnimation);
		LK.setTimeout(function () {
			LK.on('tick', self.shrinkAnimation);
		}, tadaAnimationSteps * 100);
	};
	var picture = self.addChild(new Picture(index));
	picture.x = 0;
	picture.y = 0;
	return self;
});
console.log("Principle : A pair matching game is a type of puzzle game where the player has to find and connect two identical images on a board. The player can only connect the images with a straight line or a line that bends at most twice. The line cannot cross any other images on the board. ");
var debug = true;
var lastMatched = false;
var currentCol = 0;
var currentRow = 0;
var cardPairs = [];
var cards = [];
var selectedCard1 = null;
var selectedCard2 = null;
var isAnimating = false;
var nbRows = 2;
var nbCols = 3;
var nbCards = nbRows * nbCols;
var cardWidth = 200;
var cardHeight = 200;
var horizontalOffset = 320;
var verticalOffset = 256;
function canBeLinked(card1, card2) {
	if (card1 === card2 || card1.id !== card2.id) {
		return false;
	}
	var visited = Array.from({
		length: nbRows
	}, () => Array(nbCols).fill(false));
	function dfs(card, bends) {
		if (visited[card.row][card.col] || bends > 2) {
			return false;
		}
		if (card === card2) {
			return true;
		}
		visited[card.row][card.col] = true;
		var directions = [[-1, 0], [1, 0], [0, -1], [0, 1]];
		for (let [di, dj] of directions) {
			var ni = card.row + di, nj = card.col + dj;
			if (ni >= 0 && ni < nbRows && nj >= 0 && nj < nbCols) {
				var nextCard = cards[ni][nj];
				if (!nextCard || nextCard.isMatched || nextCard === card2) {
					if (di !== 0 && dfs(nextCard, bends + (dj !== 0)) || dj !== 0 && dfs(nextCard, bends + (di !== 0))) {
						return true;
					}
				}
			}
		}
		visited[card.row][card.col] = false;
		return false;
	}
	return dfs(card1, 0);
}
var Game = Container.expand(function () {
	var self = Container.call(this);
	self.initGame = function () {
		cardPairs = [];
		for (var i = 0; i < nbCards / 2; i++) {
			cardPairs.push(i, i);
		}
		cardPairs = shuffleArray(cardPairs);
		function shuffleArray(array) {
			for (var i = array.length - 1; i > 0; i--) {
				var j = Math.floor(Math.random() * (i + 1));
				var temp = array[i];
				array[i] = array[j];
				array[j] = temp;
			}
			return array;
		}
	};
	self.initGame();
	var debugText = new Text2('', {
		size: 50,
		fill: '#ffffff'
	});
	debugText.anchor.set(0.5, 0);
	LK.gui.topCenter.addChild(debugText);
	var matchDebugText = new Text2('Match:', {
		size: 50,
		fill: '#ffffff'
	});
	matchDebugText.anchor.set(1, 0);
	LK.gui.topRight.addChild(matchDebugText);
	self.on('move', function (obj) {
		var pos = obj.event.getLocalPosition(self);
		var col = 1 + Math.floor((pos.x - horizontalOffset + cardWidth / 2) / cardWidth);
		var row = 1 + Math.floor((pos.y - verticalOffset + cardHeight / 2) / cardHeight);
		currentCol = Math.max(1, Math.min(nbCols, col));
		currentRow = Math.max(1, Math.min(nbRows, row));
		if (debug) {
			debugText.setText('Row: ' + currentRow + ' Col: ' + currentCol);
		}
	});
	for (var i = 0; i < nbCards; i++) {
		var card = self.addChild(new Card(cardPairs[i]));
		card.col = i % nbCols;
		card.row = Math.floor(i / nbCols);
		card.x = horizontalOffset + card.col * cardWidth;
		card.y = verticalOffset + card.row * cardHeight;
		if (!cards[card.row]) {
			cards[card.row] = [];
		}
		cards[card.row][card.col] = card;
	}
	LK.on('tick', function () {
		if (cards.every(function (card) {
			return card.isMatched;
		})) {
			LK.showGameOver();
		}
		matchDebugText.setText('Match: ' + (lastMatched ? 'Yes' : 'No'));
	});
});
 ===================================================================
--- original.js
+++ change.js
@@ -66,9 +66,9 @@
 				selectedCard1.scale.y = 1;
 				selectedCard1 = null;
 			} else if (selectedCard1 && !selectedCard2 && selectedCard1 !== self) {
 				selectedCard2 = self;
-				console.log("canBeLinked(card1, card2)", [selectedCard1.row, selectedCard1.col], [selectedCard2.row, selectedCard2.col]);
+				console.log("canBeLinked(card1, card2)", selectedCard1, selectedCard2);
 				self.scale.x = 1.2;
 				self.scale.y = 1.2;
 				if (selectedCard1.id == selectedCard2.id) {
 					lastMatched = true;
:quality(85)/https://cdn.frvr.ai/6580d2b410540a438e8dd9b8.png%3F3) 
 a photo realistic top view of empty flat beige plastic square. Single Game Texture. In-Game asset. 2d. No background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6580de3210540a438e8ddab0.png%3F3) 
 a christmas tree. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6580dee910540a438e8ddac4.png%3F3) 
 a christmas gift. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6580dfb110540a438e8ddae9.png%3F3) 
 a christmas ball. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e0ba9462c57d7f008f07.png%3F3) 
 a golden christmas tree star. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e1229462c57d7f008f14.png%3F3) 
 a christmas hat. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e1ad9462c57d7f008f1d.png%3F3) 
 a christmas leaf. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e2329462c57d7f008f28.png%3F3) 
 a christmas holly leaf. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e28a9462c57d7f008f34.png%3F3) 
 a christmas snow flake. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e3709462c57d7f008f4c.png%3F3) 
 a christmas snow man. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e41f9462c57d7f008f57.png%3F3) 
 a christmas reindeer. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e4999462c57d7f008f62.png%3F3) 
 a christmas candy cane. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e4ec9462c57d7f008f6a.png%3F3) 
 a christmas green ball . plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e5459462c57d7f008f78.png%3F3) 
 a christmas gingerbrean man. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e5a39462c57d7f008f81.png%3F3) 
 a christmas pine cone. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e6389462c57d7f008f8d.png%3F3) 
 a christmas present green. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e6bd9462c57d7f008f96.png%3F3) 
 a christmas boe tie. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e73b9462c57d7f008fa4.png%3F3) 
 a christmas socks. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e7a69462c57d7f008fad.png%3F3) 
 a christmas penguin. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e82a9462c57d7f008fb9.png%3F3) 
 a christmas decorated blue present. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e8db9462c57d7f008fc4.png%3F3) 
 a christmas scarf. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e9359462c57d7f008fce.png%3F3) 
 a christmas gloves. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e9a49462c57d7f008fdb.png%3F3) 
 a christmas blue decorated ball. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584e9f89462c57d7f008fe4.png%3F3) 
 a christmas candle. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6584ea669462c57d7f008fee.png%3F3) 
 a christmas snow globe. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/65860951f23651199cf54620.png%3F3) 
 an christmas elongated cuboid present. plastic style. No shadow. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586b60ea00dc4f8c07886e1.png%3F3) 
 a round christmas gift.plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586b715a00dc4f8c07886ff.png%3F3) 
 a round christmas gift.plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586b848a00dc4f8c0788715.png%3F3) 
 one cute christmas elf. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586b8f8a00dc4f8c0788728.png%3F3) 
 one cute christmas elf. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586b9c1a00dc4f8c078873a.png%3F3) 
 one cute christmas reindeer head. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586bb7ba00dc4f8c0788752.png%3F3) 
 one cute christmas reindeer head with a red nose. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586bc88a00dc4f8c0788768.png%3F3) 
 one christmas bell. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586bdc9a00dc4f8c0788774.png%3F3) 
 a couple of christmas bells. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586bf5fa00dc4f8c07887a0.png%3F3) 
 a christmas gifts bag. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586c062a00dc4f8c07887aa.png%3F3) 
 a christmas candle. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586c384a00dc4f8c07887c0.png%3F3) 
 a cute santa clauss. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586d778a00dc4f8c0788830.png%3F3) 
 Santa's sleigh. Side view. Plastic style Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586df0da00dc4f8c07888a2.png%3F3) 
 Reimagine the cute teddy bear sitting without background. Plastic style Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586e0b4a00dc4f8c07888d0.png%3F3) 
 Christmas Rocking Horse. Plastic style Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586e1f0a00dc4f8c07888f4.png%3F3) 
 One Christmas Matryoshka Doll. Plastic style Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586e328a00dc4f8c0788917.png%3F3) 
 A christmas Miniature Train. Plastic style Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586e3b7a00dc4f8c0788921.png%3F3) 
 A christmas Toy Soldier. Plastic style Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6586e6bea00dc4f8c0788950.png%3F3) 
 A christmas Music Box . Plastic style Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/658709c3b24cc6a24782a41c.png%3F3) 
 a cute polar bear cub. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/65870aabb24cc6a24782a439.png%3F3) 
 a sled plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/65870b35b24cc6a24782a44f.png%3F3) 
 a christmas gingerbread girl. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/65870be6b24cc6a24782a45f.png%3F3) 
 a christmas gingerbread house. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/65870eb1b24cc6a24782a49a.png%3F3) 
 a cute christmas jack in the box. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/65870f5eb24cc6a24782a4a5.png%3F3) 
 a cute christmas cookie. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/658710a4b24cc6a24782a4ba.png%3F3) 
 a christmas log cacke. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/65871146b24cc6a24782a4c6.png%3F3) 
 a christmas donut. plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/65871bed9174864ac4926dcc.png%3F3) 
 a cute christmas owl. Plastic style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6589e6919204943e08999f1a.png%3F3) 
 a feeric christmas landscape at night with decorated trees Background image
:quality(85)/https://cdn.frvr.ai/6589e79a9204943e08999f2a.png%3F3) 
 a feeric christmas landscape at night with snow men and snow flakes Background image
:quality(85)/https://cdn.frvr.ai/6589e86d9204943e08999f36.png%3F3) 
 a feeric christmas landscape at night with a snow man , candy canes ,holly leafs and snow flakes, Background image
:quality(85)/https://cdn.frvr.ai/6589ea2b9204943e08999f4b.png%3F3) 
 a feeric christmas landscape at night with a snow man , candy canes ,holly leafs and snow flakes, Santa's reindeers, green, red and blue presents Background image
:quality(85)/https://cdn.frvr.ai/6589ebac9204943e08999f59.png%3F3) 
 a feeric christmas landscape at night with a snow man , candy canes ,holly leafs and snow flakes, cute penguin, Santa's reindeers, green, red and blue presents and a lot of toys, a sled, gingerbread boy and girl, snow globes, a cute polar bear cub. a gingerbread house Background image
:quality(85)/https://cdn.frvr.ai/6589f1b19204943e08999fa7.png%3F3) 
 A Magical feeric starry christmas landscape at night with a snow man , candy canes ,holly leafs and snow flakes, cute penguin, Santa's reindeers, green, red and blue presents and a lot of toys, a sled, gingerbread boy and girl, snow globes, cute polar bears cub and a gingerbread house. Realistic. Plastic style. Background image