mirror of
https://github.com/viliusle/miniPaint.git
synced 2026-02-06 15:51:47 +00:00
64 lines
1.6 KiB
JavaScript
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; |