miniPaint/src/js/modules/layer/flatten.js
2020-12-04 17:52:02 -05:00

64 lines
1.6 KiB
JavaScript

import app from './../../app.js';
import config from './../../config.js';
import Base_layers_class from './../../core/base-layers.js';
import alertify from './../../../../node_modules/alertifyjs/build/alertify.min.js';
class Layer_flatten_class {
constructor() {
this.Base_layers = new Base_layers_class();
}
flatten() {
if (config.layers.length == 1) {
alertify.error('Needs at least 2 layers.');
return;
}
window.State.save();
//create tmp canvas
var canvas = document.createElement('canvas');
canvas.width = config.WIDTH;
canvas.height = config.HEIGHT;
var ctx = canvas.getContext("2d");
var layers_sorted = this.Base_layers.get_sorted_layers();
//paint layers
for (var i = layers_sorted.length - 1; i >= 0; i--) {
var layer = layers_sorted[i];
ctx.globalAlpha = layer.opacity / 100;
ctx.globalCompositeOperation = layer.composition;
this.Base_layers.render_object(ctx, layer);
}
//create requested layer
var params = [];
params.type = 'image';
params.name = 'Merged';
params.data = canvas.toDataURL("image/png");
//remove rest of layers
let delete_actions = [];
for (var i = config.layers.length - 1; i >= 0; i--) {
delete_actions.push(new app.Actions.Delete_layer_action(config.layers[i].id));
}
console.log(delete_actions);
// Run actions
app.State.do_action(
new app.Actions.Bundle_action('flatten_image', 'Flatten Image', [
new app.Actions.Insert_layer_action(params),
...delete_actions
])
);
canvas.width = 1;
canvas.height = 1;
}
}
export default Layer_flatten_class;