2017-10-12 18:35:30 -04:00
|
|
|
import paper from '@scratch/paper';
|
2017-11-02 17:19:42 -04:00
|
|
|
import log from '../log/log';
|
2017-09-11 14:23:30 -04:00
|
|
|
|
2017-11-02 17:19:42 -04:00
|
|
|
const _getLayer = function (layerString) {
|
|
|
|
for (const layer of paper.project.layers) {
|
|
|
|
if (layer.data && layer.data[layerString]) {
|
2017-09-11 14:23:30 -04:00
|
|
|
return layer;
|
|
|
|
}
|
|
|
|
}
|
2017-11-02 17:19:42 -04:00
|
|
|
log.error(`Didn't find layer ${layerString}`);
|
|
|
|
};
|
2017-09-11 14:23:30 -04:00
|
|
|
|
2017-11-02 17:19:42 -04:00
|
|
|
const _getPaintingLayer = function () {
|
|
|
|
return _getLayer('isPaintingLayer');
|
2017-09-11 14:23:30 -04:00
|
|
|
};
|
|
|
|
|
2017-11-02 17:19:42 -04:00
|
|
|
const _getBackgroundGuideLayer = function () {
|
|
|
|
return _getLayer('isBackgroundGuideLayer');
|
|
|
|
};
|
|
|
|
|
|
|
|
const getGuideLayer = function () {
|
|
|
|
return _getLayer('isGuideLayer');
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes the guide layers, e.g. for purposes of exporting the image. Must call showGuideLayers to re-add them.
|
|
|
|
* @return {object} an object of the removed layers, which should be passed to showGuideLayers to re-add them.
|
|
|
|
*/
|
|
|
|
const hideGuideLayers = function () {
|
|
|
|
const backgroundGuideLayer = _getBackgroundGuideLayer();
|
|
|
|
const guideLayer = getGuideLayer();
|
|
|
|
guideLayer.remove();
|
|
|
|
backgroundGuideLayer.remove();
|
|
|
|
return {
|
|
|
|
guideLayer: guideLayer,
|
|
|
|
backgroundGuideLayer: backgroundGuideLayer
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add back the guide layers removed by calling hideGuideLayers. This must be done before any editing operations are
|
|
|
|
* taken in the paint editor.
|
|
|
|
* @param {!object} guideLayers object of the removed layers, which was returned by hideGuideLayers
|
|
|
|
*/
|
|
|
|
const showGuideLayers = function (guideLayers) {
|
|
|
|
const backgroundGuideLayer = guideLayers.backgroundGuideLayer;
|
|
|
|
const guideLayer = guideLayers.guideLayer;
|
|
|
|
if (!backgroundGuideLayer.index) {
|
|
|
|
paper.project.addLayer(backgroundGuideLayer);
|
|
|
|
backgroundGuideLayer.sendToBack();
|
|
|
|
}
|
|
|
|
if (!guideLayer.index) {
|
|
|
|
paper.project.addLayer(guideLayer);
|
|
|
|
guideLayer.bringToFront();
|
|
|
|
}
|
|
|
|
if (paper.project.activeLayer !== _getPaintingLayer()) {
|
|
|
|
log.error(`Wrong active layer`);
|
|
|
|
log.error(paper.project.activeLayer.data);
|
2017-10-24 13:21:57 -04:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2017-11-02 17:19:42 -04:00
|
|
|
const _makeGuideLayer = function () {
|
|
|
|
const guideLayer = new paper.Layer();
|
|
|
|
guideLayer.data.isGuideLayer = true;
|
|
|
|
return guideLayer;
|
|
|
|
};
|
|
|
|
|
2017-10-24 13:21:57 -04:00
|
|
|
const _makePaintingLayer = function () {
|
|
|
|
const paintingLayer = new paper.Layer();
|
|
|
|
paintingLayer.data.isPaintingLayer = true;
|
|
|
|
return paintingLayer;
|
|
|
|
};
|
|
|
|
|
2018-04-07 01:59:52 -04:00
|
|
|
const _makeBackgroundPaper = function (width, height, color) {
|
|
|
|
var x = 0;
|
|
|
|
var y = 0;
|
|
|
|
var sb = [];
|
|
|
|
while (x < width) {
|
|
|
|
sb.push(new paper.Point(x,y));
|
|
|
|
x++;
|
|
|
|
sb.push(new paper.Point(x,y));
|
|
|
|
y = y == 0 ? height : 0;
|
|
|
|
}
|
|
|
|
y = height - 1;
|
|
|
|
x = width;
|
|
|
|
while (y > 0) {
|
|
|
|
sb.push(new paper.Point(x,y));
|
|
|
|
x = (x == 0 ? width : 0);
|
|
|
|
sb.push(new paper.Point(x,y));
|
|
|
|
y--;
|
|
|
|
}
|
|
|
|
const vRect = new paper.Shape.Rectangle(new paper.Point(0,0), new paper.Point(120,90));
|
|
|
|
vRect.fillColor = '#fff';
|
|
|
|
vRect.guide = true;
|
|
|
|
vRect.locked = true;
|
|
|
|
const vPath = new paper.Path(sb);
|
|
|
|
vPath.fillRule = 'evenodd';
|
|
|
|
vPath.fillColor = color;
|
|
|
|
vPath.guide = true;
|
|
|
|
vPath.locked = true;
|
|
|
|
const vGroup = new paper.Group([vRect, vPath]);
|
|
|
|
return vGroup;
|
|
|
|
}
|
|
|
|
|
2017-10-24 13:21:57 -04:00
|
|
|
const _makeBackgroundGuideLayer = function () {
|
|
|
|
const guideLayer = new paper.Layer();
|
|
|
|
guideLayer.locked = true;
|
2018-04-07 01:59:52 -04:00
|
|
|
|
|
|
|
const vBackground = _makeBackgroundPaper(120, 90, '#E5E5E5');
|
|
|
|
vBackground.position = paper.view.center;
|
|
|
|
vBackground.scaling = new paper.Point(4,4);
|
|
|
|
vBackground.guide = true;
|
|
|
|
vBackground.locked = true;
|
2017-10-24 13:21:57 -04:00
|
|
|
|
|
|
|
const vLine = new paper.Path.Line(new paper.Point(0, -7), new paper.Point(0, 7));
|
|
|
|
vLine.strokeWidth = 2;
|
|
|
|
vLine.strokeColor = '#ccc';
|
|
|
|
vLine.position = paper.view.center;
|
|
|
|
vLine.guide = true;
|
|
|
|
vLine.locked = true;
|
|
|
|
|
|
|
|
const hLine = new paper.Path.Line(new paper.Point(-7, 0), new paper.Point(7, 0));
|
|
|
|
hLine.strokeWidth = 2;
|
|
|
|
hLine.strokeColor = '#ccc';
|
|
|
|
hLine.position = paper.view.center;
|
|
|
|
hLine.guide = true;
|
|
|
|
hLine.locked = true;
|
|
|
|
|
|
|
|
const circle = new paper.Shape.Circle(new paper.Point(0, 0), 5);
|
|
|
|
circle.strokeWidth = 2;
|
|
|
|
circle.strokeColor = '#ccc';
|
|
|
|
circle.position = paper.view.center;
|
|
|
|
circle.guide = true;
|
|
|
|
circle.locked = true;
|
|
|
|
|
|
|
|
guideLayer.data.isBackgroundGuideLayer = true;
|
|
|
|
return guideLayer;
|
|
|
|
};
|
|
|
|
|
|
|
|
const setupLayers = function () {
|
2017-11-02 17:19:42 -04:00
|
|
|
const backgroundGuideLayer = _makeBackgroundGuideLayer();
|
|
|
|
const paintLayer = _makePaintingLayer();
|
|
|
|
const guideLayer = _makeGuideLayer();
|
|
|
|
backgroundGuideLayer.sendToBack();
|
|
|
|
guideLayer.bringToFront();
|
|
|
|
paintLayer.activate();
|
2017-10-24 13:21:57 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
export {
|
2017-11-02 17:19:42 -04:00
|
|
|
hideGuideLayers,
|
|
|
|
showGuideLayers,
|
2017-10-24 13:21:57 -04:00
|
|
|
getGuideLayer,
|
|
|
|
setupLayers
|
|
|
|
};
|