Added functions for canvas management in order to create multiple underlying canvases for implementing layers.

Signed-off-by: npalomba <nicola.palomba@studenti.galileilivorno.gov.it>
This commit is contained in:
npalomba 2019-03-31 15:55:08 +02:00
parent f229c14d91
commit e68f495d50
4 changed files with 49 additions and 4 deletions

View File

@ -35,7 +35,7 @@ svg {
outline: 0 !important; outline: 0 !important;
} }
#pixel-canvas { canvas {
cursor: url('/pixel-art-where-to-start/pencil-tool-cursor.png'); cursor: url('/pixel-art-where-to-start/pencil-tool-cursor.png');
border: solid 1px #fff; border: solid 1px #fff;
@ -49,11 +49,19 @@ svg {
-ms-interpolation-mode:nearest-neighbor; /* IE8+ */ -ms-interpolation-mode:nearest-neighbor; /* IE8+ */
width: 400px; width: 400px;
height: 400px; height: 400px;
display: none;
position: fixed; position: fixed;
box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.64); box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.64);
} }
#checkerboard {
z-index:1000;
}
#pixel-canvas {
z-index:1;
background:transparent;
}
#eyedropper-preview { #eyedropper-preview {
position: absolute; position: absolute;
width: 45px; width: 45px;
@ -83,7 +91,6 @@ svg {
} }
#canvas-view { #canvas-view {
background: color(indent-dark);
bottom: 0px; bottom: 0px;
left: 64px; left: 64px;
right: 48px; right: 48px;

34
js/_canvas.js Normal file
View File

@ -0,0 +1,34 @@
function Canvas(height, width, canvas) {
this.canvasSize = [width, height],
this.canvas = canvas,
this.initialize = function() {
var maxHorizontalZoom = Math.floor(window.innerWidth/canvasSize[0]*0.75);
var maxVerticalZoom = Math.floor(window.innerHeight/canvasSize[1]*0.75);
zoom = Math.min(maxHorizontalZoom,maxVerticalZoom);
if (zoom < 1) zoom = 1;
//resize canvas
this.canvas.width = canvasSize[0];
this.canvas.height = canvasSize[1];
this.canvas.style.width = (this.canvas.width*zoom)+'px';
this.canvas.style.height = (this.canvas.height*zoom)+'px';
//unhide canvas
this.canvas.style.display = 'block';
//center canvas in window
this.canvas.style.left = 64+canvasView.clientWidth/2-(canvasSize[0]*zoom/2)+'px';
this.canvas.style.top = 48+canvasView.clientHeight/2-(canvasSize[1]*zoom/2)+'px';
},
this.resize = function() {
let newWidth = (this.canvas.width*zoom)+'px';
let newHeight = (this.canvas.height*zoom)+'px';
this.canvas.style.width = newWidth;
this.canvas.style.height = newHeight;
this.width = newWidth;
this.height = newHeight;
}
}

View File

@ -12,9 +12,12 @@ var prevEraserSize = 1;
var menuOpen = false; var menuOpen = false;
var dialogueOpen = false; var dialogueOpen = false;
var documentCreated = false; var documentCreated = false;
// Checkerboard management
var firstCheckerBoardColor = 'rgba(139, 139, 139, 1)'; var firstCheckerBoardColor = 'rgba(139, 139, 139, 1)';
var secondCheckerBoardColor = 'rgba(105, 105, 105, 1)'; var secondCheckerBoardColor = 'rgba(105, 105, 105, 1)';
var checkerBoardSquareSize = 16; var checkerBoardSquareSize = 16;
//var checkerBoard = document.getElementById("checkerboard").getContext("2d");
//common elements //common elements
var brushPreview = document.getElementById("brush-preview"); var brushPreview = document.getElementById("brush-preview");

View File

@ -42,6 +42,7 @@
//=include _deleteColor.js //=include _deleteColor.js
//=include _replaceAllOfColor.js //=include _replaceAllOfColor.js
//=include _checkerboard.js //=include _checkerboard.js
//=include _canvas.js
/**load file**/ /**load file**/