2019-03-27 02:20:54 +03:00
|
|
|
var undoStates = [];
|
|
|
|
var redoStates = [];
|
|
|
|
|
|
|
|
const undoLogStyle = 'background: #87ff1c; color: black; padding: 5px;';
|
|
|
|
|
|
|
|
//prototype for undoing canvas changes
|
|
|
|
function HistoryStateEditCanvas () {
|
2020-04-04 10:41:56 +03:00
|
|
|
this.canvas = currentLayer.context.getImageData(0, 0, canvasSize[0], canvasSize[1]);
|
|
|
|
|
|
|
|
this.undo = function () {
|
|
|
|
var currentCanvas = currentLayer.context.getImageData(0, 0, canvasSize[0], canvasSize[1]);
|
|
|
|
currentLayer.context.putImageData(this.canvas, 0, 0);
|
|
|
|
|
|
|
|
this.canvas = currentCanvas;
|
|
|
|
redoStates.push(this);
|
|
|
|
};
|
|
|
|
|
|
|
|
this.redo = function () {
|
|
|
|
var currentCanvas = currentLayer.context.getImageData(0, 0, canvasSize[0], canvasSize[1]);
|
|
|
|
currentLayer.context.putImageData(this.canvas, 0, 0);
|
|
|
|
|
|
|
|
this.canvas = currentCanvas;
|
|
|
|
undoStates.push(this);
|
|
|
|
};
|
|
|
|
|
|
|
|
//add self to undo array
|
|
|
|
saveHistoryState(this);
|
2019-03-27 02:20:54 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
//prototype for undoing added colors
|
|
|
|
function HistoryStateAddColor (colorValue) {
|
2020-04-04 10:41:56 +03:00
|
|
|
this.colorValue = colorValue;
|
|
|
|
|
|
|
|
this.undo = function () {
|
|
|
|
redoStates.push(this);
|
|
|
|
deleteColor(this.colorValue);
|
|
|
|
};
|
|
|
|
|
|
|
|
this.redo = function () {
|
|
|
|
addColor(this.colorValue);
|
|
|
|
undoStates.push(this);
|
|
|
|
};
|
|
|
|
|
|
|
|
//add self to undo array
|
|
|
|
saveHistoryState(this);
|
2019-03-27 02:20:54 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
//prototype for undoing deleted colors
|
|
|
|
function HistoryStateDeleteColor (colorValue) {
|
2020-04-04 10:41:56 +03:00
|
|
|
this.colorValue = colorValue;
|
|
|
|
this.canvas = currentLayer.context.getImageData(0, 0, canvasSize[0], canvasSize[1]);
|
|
|
|
|
|
|
|
this.undo = function () {
|
|
|
|
var currentCanvas = currentLayer.context.getImageData(0, 0, canvasSize[0], canvasSize[1]);
|
|
|
|
currentLayer.context.putImageData(this.canvas, 0, 0);
|
|
|
|
|
|
|
|
addColor(this.colorValue);
|
|
|
|
|
|
|
|
this.canvas = currentCanvas;
|
|
|
|
redoStates.push(this);
|
|
|
|
};
|
|
|
|
|
|
|
|
this.redo = function () {
|
|
|
|
var currentCanvas = currentLayer.context.getImageData(0, 0, canvasSize[0], canvasSize[1]);
|
|
|
|
currentLayer.context.putImageData(this.canvas, 0, 0);
|
|
|
|
|
|
|
|
deleteColor(this.colorValue);
|
|
|
|
|
|
|
|
this.canvas = currentCanvas;
|
|
|
|
undoStates.push(this);
|
|
|
|
};
|
|
|
|
|
|
|
|
//add self to undo array
|
|
|
|
saveHistoryState(this);
|
2019-03-27 02:20:54 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
//prototype for undoing colors edits
|
|
|
|
function HistoryStateEditColor (newColorValue, oldColorValue) {
|
2020-04-04 10:41:56 +03:00
|
|
|
this.newColorValue = newColorValue;
|
|
|
|
this.oldColorValue = oldColorValue;
|
|
|
|
this.canvas = currentLayer.context.getImageData(0, 0, canvasSize[0], canvasSize[1]);
|
|
|
|
|
|
|
|
this.undo = function () {
|
|
|
|
var currentCanvas = currentLayer.context.getImageData(0, 0, canvasSize[0], canvasSize[1]);
|
|
|
|
currentLayer.context.putImageData(this.canvas, 0, 0);
|
|
|
|
|
|
|
|
//find new color in palette and change it back to old color
|
|
|
|
var colors = document.getElementsByClassName('color-button');
|
|
|
|
for (var i = 0; i < colors.length; i++) {
|
2020-06-06 22:44:52 +03:00
|
|
|
//console.log(newColorValue, '==', colors[i].jscolor.toString());
|
2020-04-04 10:41:56 +03:00
|
|
|
if (newColorValue == colors[i].jscolor.toString()) {
|
|
|
|
colors[i].jscolor.fromString(oldColorValue);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
this.canvas = currentCanvas;
|
|
|
|
redoStates.push(this);
|
|
|
|
};
|
|
|
|
|
|
|
|
this.redo = function () {
|
|
|
|
var currentCanvas = currentLayer.context.getImageData(0, 0, canvasSize[0], canvasSize[1]);
|
|
|
|
currentLayer.context.putImageData(this.canvas, 0, 0);
|
|
|
|
|
|
|
|
//find old color in palette and change it back to new color
|
|
|
|
var colors = document.getElementsByClassName('color-button');
|
|
|
|
for (var i = 0; i < colors.length; i++) {
|
2020-06-06 22:44:52 +03:00
|
|
|
//console.log(oldColorValue, '==', colors[i].jscolor.toString());
|
2020-04-04 10:41:56 +03:00
|
|
|
if (oldColorValue == colors[i].jscolor.toString()) {
|
|
|
|
colors[i].jscolor.fromString(newColorValue);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
this.canvas = currentCanvas;
|
|
|
|
undoStates.push(this);
|
|
|
|
};
|
|
|
|
|
|
|
|
//add self to undo array
|
|
|
|
saveHistoryState(this);
|
2019-03-27 02:20:54 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//rename to add undo state
|
|
|
|
function saveHistoryState (state) {
|
2020-06-06 22:44:52 +03:00
|
|
|
//console.log('%csaving history state', undoLogStyle);
|
|
|
|
//console.log(state);
|
2020-04-04 10:41:56 +03:00
|
|
|
|
|
|
|
//get current canvas data and save to undoStates array
|
|
|
|
undoStates.push(state);
|
|
|
|
|
|
|
|
//limit the number of states to settings.numberOfHistoryStates
|
|
|
|
if (undoStates.length > settings.numberOfHistoryStates) {
|
|
|
|
undoStates = undoStates.splice(-settings.numberOfHistoryStates, settings.numberOfHistoryStates);
|
|
|
|
}
|
|
|
|
|
|
|
|
//there is now definitely at least 1 undo state, so the button shouldnt be disabled
|
|
|
|
document.getElementById('undo-button').classList.remove('disabled');
|
|
|
|
|
|
|
|
//there should be no redoStates after an undoState is saved
|
|
|
|
redoStates = [];
|
|
|
|
|
2020-06-06 22:44:52 +03:00
|
|
|
//console.log(undoStates);
|
|
|
|
//console.log(redoStates);
|
2019-03-27 02:20:54 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function undo () {
|
2020-06-06 22:44:52 +03:00
|
|
|
//console.log('%cundo', undoLogStyle);
|
2020-04-04 10:41:56 +03:00
|
|
|
|
|
|
|
//if there are any states saved to undo
|
|
|
|
if (undoStates.length > 0) {
|
|
|
|
|
|
|
|
document.getElementById('redo-button').classList.remove('disabled');
|
|
|
|
|
|
|
|
//get state
|
|
|
|
var undoState = undoStates[undoStates.length-1];
|
2020-06-06 22:44:52 +03:00
|
|
|
//console.log(undoState);
|
2020-04-04 10:41:56 +03:00
|
|
|
|
|
|
|
//restore the state
|
|
|
|
undoState.undo();
|
|
|
|
|
|
|
|
//remove from the undo list
|
|
|
|
undoStates.splice(undoStates.length-1,1);
|
|
|
|
|
|
|
|
//if theres none left to undo, disable the option
|
|
|
|
if (undoStates.length == 0)
|
|
|
|
document.getElementById('undo-button').classList.add('disabled');
|
|
|
|
}
|
|
|
|
|
2020-06-06 22:44:52 +03:00
|
|
|
//console.log(undoStates);
|
|
|
|
//console.log(redoStates);
|
2019-03-27 02:20:54 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function redo () {
|
2020-06-06 22:44:52 +03:00
|
|
|
//console.log('%credo', undoLogStyle);
|
2019-03-27 02:20:54 +03:00
|
|
|
|
2020-04-04 10:41:56 +03:00
|
|
|
if (redoStates.length > 0) {
|
2019-03-27 02:20:54 +03:00
|
|
|
|
2020-04-04 10:41:56 +03:00
|
|
|
//enable undo button
|
|
|
|
document.getElementById('undo-button').classList.remove('disabled');
|
|
|
|
|
|
|
|
//get state
|
|
|
|
var redoState = redoStates[redoStates.length-1];
|
2020-06-06 22:44:52 +03:00
|
|
|
//console.log(redoState);
|
2020-04-04 10:41:56 +03:00
|
|
|
|
|
|
|
//restore the state
|
|
|
|
redoState.redo();
|
|
|
|
|
|
|
|
//remove from redo array
|
|
|
|
redoStates.splice(redoStates.length-1,1);
|
|
|
|
|
|
|
|
//if theres none left to redo, disable the option
|
|
|
|
if (redoStates.length == 0)
|
|
|
|
document.getElementById('redo-button').classList.add('disabled');
|
|
|
|
}
|
2020-06-06 22:44:52 +03:00
|
|
|
//console.log(undoStates);
|
|
|
|
//console.log(redoStates);
|
2020-04-04 10:41:56 +03:00
|
|
|
}
|