Added correct cursor to move tool

Added _move.js to handle the selection movement, added cursor managemente for that tool. Found a bug in the imagedata part, it is currently blank.
This commit is contained in:
unsettledgames 2020-03-05 13:34:29 +01:00
parent 7ec24fc046
commit b81e3f36a9
4 changed files with 71 additions and 9 deletions

View File

@ -1,6 +1,9 @@
var currentMouseEvent;
//mousedown - start drawing //mousedown - start drawing
window.addEventListener("mousedown", function (mouseEvent) { window.addEventListener("mousedown", function (mouseEvent) {
// Saving the event in case something else needs it
currentMouseEvent = mouseEvent;
//if no document has been created yet, or this is a dialog open //if no document has been created yet, or this is a dialog open
if (!documentCreated || dialogueOpen) return; if (!documentCreated || dialogueOpen) return;
@ -44,7 +47,9 @@ window.addEventListener("mousedown", function (mouseEvent) {
//mouseup - end drawing //mouseup - end drawing
window.addEventListener("mouseup", function (mouseEvent) { window.addEventListener("mouseup", function (mouseEvent) {
// Saving the event in case something else needs it
currentMouseEvent = mouseEvent;
closeMenu(); closeMenu();
if (!documentCreated || dialogueOpen) return; if (!documentCreated || dialogueOpen) return;
@ -125,6 +130,9 @@ window.addEventListener("mouseup", function (mouseEvent) {
//mouse is moving on canvas //mouse is moving on canvas
window.addEventListener("mousemove", draw, false); window.addEventListener("mousemove", draw, false);
function draw (mouseEvent) { function draw (mouseEvent) {
// Saving the event in case something else needs it
currentMouseEvent = mouseEvent;
var cursorLocation = getCursorPosition(mouseEvent); var cursorLocation = getCursorPosition(mouseEvent);
//if a document hasnt yet been created, exit this function //if a document hasnt yet been created, exit this function
@ -247,6 +255,11 @@ function draw (mouseEvent) {
updateRectSelection(mouseEvent); updateRectSelection(mouseEvent);
} }
} }
else if (currentTool == 'moveselection') {
console.log("Aggiorno il cursore");
updateCursor();
updateMovePreview();
}
} }
//mousewheel scrroll //mousewheel scrroll

View File

@ -1 +1,5 @@
var imageDataToMove; var imageDataToMove;
function updateMovePreview() {
}

View File

@ -1,6 +1,8 @@
var isRectSelecting = false; var isRectSelecting = false;
let startX; let startX;
let startY; let startY;
let endX;
let endY;
let workingLayer; let workingLayer;
let imageData; let imageData;
@ -29,13 +31,24 @@ function updateRectSelection(mouseEvent) {
function endRectSelection(mouseEvent) { function endRectSelection(mouseEvent) {
// Getting the end position // Getting the end position
let currentPos = getCursorPosition(mouseEvent); let currentPos = getCursorPosition(mouseEvent);
let x = currentPos[0] / zoom; endX = currentPos[0] / zoom;
let y = currentPos[1] / zoom; endY = currentPos[1] / zoom;
// Putting the vfx layer behind everything // Putting the vfx layer behind everything
isRectSelecting = false; isRectSelecting = false;
// Getting the selected pixels // Getting the selected pixels
imageData = currentLayer.context.createImageData(x - startX, y - startY); imageData = currentLayer.context.createImageData(endX - startX, endY - startY);
// Selecting the move tool
currentTool = 'moveselection';
currentToolTemp = currentTool;
// Updating the cursor
updateCursor();
// TODO: find out why the imagedata is blank
for (i=0; i<imageData.data.length; i++) {
console.log("rgba(" + imageData.data[i] + ',' + imageData.data[i + 1] + ',' + imageData.data[i + 2] + ',' + imageData.data[i + 3] + ')');
}
// NOW // NOW
// Select the move tool // Select the move tool
@ -48,7 +61,7 @@ function endRectSelection(mouseEvent) {
// the image data must be copied to a temporary layer // the image data must be copied to a temporary layer
// the image data is added to the original layer when the move tool is disabled // the image data is added to the original layer when the move tool is disabled
workingLayer.context.putImageData(imageData, startX, startY); currentLayer.context.putImageData(imageData, startX, startY);
} }
function drawRect(x, y) { function drawRect(x, y) {
@ -72,4 +85,27 @@ function drawRect(x, y) {
function applyChanges() { function applyChanges() {
VFXCanvas.style.zIndex = MIN_Z_INDEX; VFXCanvas.style.zIndex = MIN_Z_INDEX;
}
// Checks whether the pointer is inside the selected area or not
function cursorInSelectedArea() {
let cursorPos = getCursorPosition(currentMouseEvent);
let x = cursorPos[0] / zoom;
let y = cursorPos[1] / zoom;
let leftX = Math.min(startX, endX);
let rightX = Math.max(startX, endX);
let topY = Math.max(startY, endY);
let bottomY = Math.min(startY, endY);
// ISSUE: is it <= or <? test it
if (leftX <= x && x <= rightX) {
if (bottomY <= y && y <= topY) {
return true;
}
return false;
}
return false;
} }

View File

@ -11,7 +11,18 @@ function updateCursor () {
brushPreview.style.display = 'block'; brushPreview.style.display = 'block';
brushPreview.style.width = eraserSize * zoom + 'px'; brushPreview.style.width = eraserSize * zoom + 'px';
brushPreview.style.height = eraserSize * zoom + 'px'; brushPreview.style.height = eraserSize * zoom + 'px';
} else } else if (currentTool == 'moveselection') {
if (cursorInSelectedArea()) {
canvasView.style.cursor = 'move';
brushPreview.style.display = 'none';
}
else {
canvasView.style.cursor = 'crosshair';
}
}
else if (currentTool == 'rectselect')
canvasView.style.cursor = 'crosshair';
else
brushPreview.style.display = 'none'; brushPreview.style.display = 'none';
if (currentTool == 'eyedropper') { if (currentTool == 'eyedropper') {
@ -33,6 +44,4 @@ function updateCursor () {
if (currentTool == 'resize-brush' || currentTool == 'resize-eraser') if (currentTool == 'resize-brush' || currentTool == 'resize-eraser')
canvasView.style.cursor = 'default'; canvasView.style.cursor = 'default';
if (currentTool == 'rectselect')
canvasView.style.cursor = 'crosshair';
} }