User prompt
Separate the line from player
Code edit (1 edits merged)
Please save this source code
User prompt
Make line smaller then player
User prompt
Make line asset smaller then player. Set line asset behind player and constrain it to it. If player moves draw a line.
User prompt
Add function to move player anywhere on the screen but like lines vertically or horizontally by click in any direction left right up or down.
Code edit (1 edits merged)
Please save this source code
User prompt
Scale player
User prompt
Make player do a color line when move on the background
User prompt
Add player class and logic
User prompt
Add @upit/tween.v1 to the game code if that help player go to cursor than add it. ↪💡 Consider importing and using the following plugins: @upit/tween.v1
User prompt
Make player go to the cursor by lage distance and moving smoothly to it. ↪💡 Consider importing and using the following plugins: @upit/tween.v1
User prompt
remove what's holding player from moving small distance to the cursor when clicked
User prompt
Make vertical and horizontal movement for the player to move by small distance to the cursor on the screen.
User prompt
Add player to the game add line to the game make it small
User prompt
Remove player and its movments from game
User prompt
Remove player from game
User prompt
change plqyer position to the right
User prompt
If cursor on the screen move player to the clicked point if not clicked don't move it.
User prompt
Make player teleport to cursor
User prompt
If player clicked by cursor make it follow it to any of the 4 directions movments
User prompt
Add movement to the player right left up down
User prompt
Remove all movments of player
User prompt
If the button of the mouse clicked on the player constrain player with it
User prompt
Hold cursor on the player to drag it
User prompt
Make player move by drage
/**** 
* Classes
****/ 
var Line = Container.expand(function () {
	var self = Container.call(this);
	var lineGraphics = self.attachAsset('line', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.update = function () {
		lineGraphics.clear();
		self.x = player.x;
		self.y = player.y;
		// There is no lineTo method in LK engine. We can set the width and height of the shape directly when initializing it.
		lineGraphics.width = player.x - player.lastX;
		lineGraphics.height = player.y - player.lastY;
	};
});
var Player = Container.expand(function () {
	var self = Container.call(this);
	var playerGraphics = self.attachAsset('player', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	self.dragging = false;
	self.data = null;
	self.interactive = true;
	self.on('mousedown', onDragStart).on('touchstart', onDragStart).on('mouseup', onDragEnd).on('mouseupoutside', onDragEnd).on('touchend', onDragEnd).on('touchendoutside', onDragEnd).on('mousemove', onDragMove).on('touchmove', onDragMove);
	function onDragStart(event) {
		self.data = event.data;
		var newPosition = self.data.getLocalPosition(self.parent);
		self.x = newPosition.x;
		self.y = newPosition.y;
		self.lastX = self.x;
		self.lastY = self.y;
	}
	function onDragEnd() {
		self.dragging = false;
		self.data = null;
	}
	function onDragMove(event) {
		// No action needed
	}
});
/**** 
* Initialize Game
****/ 
var game = new LK.Game({
	backgroundColor: 0x000000
});
/**** 
* Game Code
****/ 
var background = game.addChild(LK.getAsset('maze1', {
	anchorX: 0.5,
	anchorY: 0.5,
	x: 2048 / 2,
	y: 2732 / 2
}));
background.scale.x = game.width / background.width;
background.scale.y = game.height / background.height;
var player = game.addChild(new Player());
player.x = 2048 / 2;
player.y = 2732 - 115;
player.scaleX = 1.5;
player.scaleY = 1.5;
var line = game.addChild(new Line());
; ===================================================================
--- original.js
+++ change.js
@@ -27,22 +27,20 @@
 	self.interactive = true;
 	self.on('mousedown', onDragStart).on('touchstart', onDragStart).on('mouseup', onDragEnd).on('mouseupoutside', onDragEnd).on('touchend', onDragEnd).on('touchendoutside', onDragEnd).on('mousemove', onDragMove).on('touchmove', onDragMove);
 	function onDragStart(event) {
 		self.data = event.data;
-		self.dragging = true;
+		var newPosition = self.data.getLocalPosition(self.parent);
+		self.x = newPosition.x;
+		self.y = newPosition.y;
 		self.lastX = self.x;
 		self.lastY = self.y;
 	}
 	function onDragEnd() {
 		self.dragging = false;
 		self.data = null;
 	}
 	function onDragMove(event) {
-		if (self.dragging) {
-			var newPosition = event.data.getLocalPosition(self.parent);
-			self.x = newPosition.x;
-			self.y = newPosition.y;
-		}
+		// No action needed
 	}
 });
 
 /****